/*
* The ManaPlus Client
* Copyright (C) 2013-2016 The ManaPlus Developers
*
* This file is part of The ManaPlus Client.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#include "catch.hpp"
#include "client.h"
#include "graphicsmanager.h"
#include "logger.h"
#include "being/actorsprite.h"
#include "resources/sdlimagehelper.h"
#ifdef USE_SDL2
#include "resources/surfaceimagehelper.h"
#endif // USE_SDL2
#include "resources/dye/dye.h"
#include "resources/dye/dyepalette.h"
#include "resources/image/image.h"
#include "resources/loaders/imageloader.h"
#include "resources/resourcemanager/resourcemanager.h"
#include "utils/delete2.h"
#include "utils/env.h"
#include "utils/physfstools.h"
#ifndef USE_SDL2
#include
#endif // USE_SDL2
#ifndef SDL_BIG_ENDIAN
#include
#endif // SDL_BYTEORDER
#include "debug.h"
#if SDL_BYTEORDER == SDL_BIG_ENDIAN
#define buildHex(a, b, c, d) \
(d) * 16777216U + (c) * 65536U + (b) * 256U + CAST_U32(a)
#else // SDL_BYTEORDER == SDL_BIG_ENDIAN
#define buildHex(a, b, c, d) \
(a) * 16777216U + (b) * 65536U + (c) * 256U + CAST_U32(d)
#endif // SDL_BYTEORDER == SDL_BIG_ENDIAN
#ifdef USE_OPENGL
TEST_CASE("Dye replaceSOGLColor 1 1")
{
DyePalette palette("#00ff00,000011", 6);
uint32_t data[1];
data[0] = buildHex(0x01, 0x02, 0x03, 0x10);
palette.replaceSOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x01, 0x02, 0x03, 0x10));
}
TEST_CASE("Dye replaceSOGLColor 1 2")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[1];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
palette.replaceSOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
}
TEST_CASE("Dye replaceSOGLColor 1 3")
{
DyePalette palette("#404040,200000,0100ee,102030", 6);
uint32_t data[1];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceSOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x40, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceSOGLColor 2 1")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[2];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
palette.replaceSOGLColor(&data[0], 2);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
}
TEST_CASE("Dye replaceSOGLColor 4 1")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[4];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
data[2] = buildHex(0x40, 0x02, 0xff, 0x01);
data[3] = buildHex(0x50, 0x02, 0xff, 0x02);
palette.replaceSOGLColor(&data[0], 4);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[2] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[3] == buildHex(0x50, 0x02, 0xff, 0x02));
}
TEST_CASE("Dye replaceSOGLColor 8 1")
{
DyePalette palette("#01ff02,030411,01ee02,010203", 6);
uint32_t data[8];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
data[2] = buildHex(0x40, 0x02, 0xff, 0x01);
data[3] = buildHex(0x50, 0x02, 0xff, 0x02);
data[4] = buildHex(0x20, 0x02, 0xff, 0x01);
data[5] = buildHex(0x30, 0x02, 0xff, 0x01);
data[6] = buildHex(0x40, 0x02, 0xff, 0x01);
data[7] = buildHex(0x60, 0x02, 0xff, 0x02);
palette.replaceSOGLColor(&data[0], 8);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[2] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[3] == buildHex(0x50, 0x02, 0xff, 0x02));
REQUIRE(data[4] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[5] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[6] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[7] == buildHex(0x60, 0x02, 0xff, 0x02));
}
TEST_CASE("Dye replaceSOGLColor 1 1 default")
{
DyePalette palette("#00ff00,000011", 6);
uint32_t data[1];
data[0] = buildHex(0x01, 0x02, 0x03, 0x10);
palette.replaceSOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x01, 0x02, 0x03, 0x10));
}
TEST_CASE("Dye replaceSOGLColor 1 2 default")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[1];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
palette.replaceSOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
}
TEST_CASE("Dye replaceSOGLColor 1 3 default")
{
DyePalette palette("#404040,200000,0100ee,102030", 6);
uint32_t data[1];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceSOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x40, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceSOGLColor 2 1 default")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[2];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
palette.replaceSOGLColorDefault(&data[0], 2);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
}
TEST_CASE("Dye replaceSOGLColor 4 1 default")
{
DyePalette palette("#01ff02,030411", 6);
uint32_t data[4];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
data[2] = buildHex(0x40, 0x02, 0xff, 0x01);
data[3] = buildHex(0x50, 0x02, 0xff, 0x02);
palette.replaceSOGLColorDefault(&data[0], 4);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[2] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[3] == buildHex(0x50, 0x02, 0xff, 0x02));
}
TEST_CASE("Dye replaceSOGLColor 8 1 default")
{
DyePalette palette("#01ff02,030411,01ee02,010203", 6);
uint32_t data[8];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
data[2] = buildHex(0x40, 0x02, 0xff, 0x01);
data[3] = buildHex(0x50, 0x02, 0xff, 0x02);
data[4] = buildHex(0x20, 0x02, 0xff, 0x01);
data[5] = buildHex(0x30, 0x02, 0xff, 0x01);
data[6] = buildHex(0x40, 0x02, 0xff, 0x01);
data[7] = buildHex(0x60, 0x02, 0xff, 0x02);
palette.replaceSOGLColorDefault(&data[0], 8);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[2] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[3] == buildHex(0x50, 0x02, 0xff, 0x02));
REQUIRE(data[4] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[5] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[6] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[7] == buildHex(0x60, 0x02, 0xff, 0x02));
}
TEST_CASE("Dye replaceSOGLColor 8 1 simd")
{
DyePalette palette("#01ff02,030411,01ee02,010203", 6);
uint32_t data[8];
data[0] = buildHex(0x20, 0x02, 0xff, 0x01);
data[1] = buildHex(0x30, 0x02, 0xff, 0x01);
data[2] = buildHex(0x40, 0x02, 0xff, 0x01);
data[3] = buildHex(0x50, 0x02, 0xff, 0x02);
data[4] = buildHex(0x20, 0x02, 0xff, 0x01);
data[5] = buildHex(0x30, 0x02, 0xff, 0x01);
data[6] = buildHex(0x40, 0x02, 0xff, 0x01);
data[7] = buildHex(0x60, 0x02, 0xff, 0x02);
palette.replaceSOGLColorSimd(&data[0], 8);
REQUIRE(data[0] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[1] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[2] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[3] == buildHex(0x50, 0x02, 0xff, 0x02));
REQUIRE(data[4] == buildHex(0x20, 0x11, 0x04, 0x03));
REQUIRE(data[5] == buildHex(0x30, 0x11, 0x04, 0x03));
REQUIRE(data[6] == buildHex(0x40, 0x11, 0x04, 0x03));
REQUIRE(data[7] == buildHex(0x60, 0x02, 0xff, 0x02));
}
TEST_CASE("Dye replaceAOGLColor 1 1")
{
DyePalette palette("#00ff0010,00001120", 8);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceAOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceAOGLColor 1 2")
{
DyePalette palette("#00ff0120,020311ff", 8);
uint32_t data[1];
data[0] = buildHex(0x20, 0x01, 0xff, 0x00);
palette.replaceAOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0xff, 0x11, 0x03, 0x02));
}
TEST_CASE("Dye replaceAOGLColor 1 3")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[1];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 2 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[2];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColor(&data[0], 2);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 4 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[4];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
data[2] = buildHex(0x41, 0xee, 0x00, 0x01);
data[3] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColor(&data[0], 4);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[2] == buildHex(0x41, 0xee, 0x00, 0x01));
REQUIRE(data[3] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 8 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
data[2] = buildHex(0x41, 0xee, 0x00, 0x01);
data[3] = buildHex(0x40, 0xee, 0x00, 0x01);
data[4] = buildHex(0x40, 0xee, 0x00, 0x01);
data[5] = buildHex(0x40, 0x40, 0x40, 0x40);
data[6] = buildHex(0x41, 0xe0, 0x00, 0x01);
data[7] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColor(&data[0], 8);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[2] == buildHex(0x41, 0xee, 0x00, 0x01));
REQUIRE(data[3] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[4] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[5] == buildHex(0x00, 0x00, 0x00, 0x20));
REQUIRE(data[6] == buildHex(0x41, 0xe0, 0x00, 0x01));
REQUIRE(data[7] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 1 1 default")
{
DyePalette palette("#00ff0010,00001120", 8);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceAOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceAOGLColor 1 2 default")
{
DyePalette palette("#00ff0120,020311ff", 8);
uint32_t data[1];
data[0] = buildHex(0x20, 0x01, 0xff, 0x00);
palette.replaceAOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0xff, 0x11, 0x03, 0x02));
}
TEST_CASE("Dye replaceAOGLColor 1 3 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[1];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 2 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[2];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColorDefault(&data[0], 2);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 4 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[4];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
data[2] = buildHex(0x41, 0xee, 0x00, 0x01);
data[3] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColorDefault(&data[0], 4);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[2] == buildHex(0x41, 0xee, 0x00, 0x01));
REQUIRE(data[3] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 8 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
data[2] = buildHex(0x41, 0xee, 0x00, 0x01);
data[3] = buildHex(0x40, 0xee, 0x00, 0x01);
data[4] = buildHex(0x40, 0xee, 0x00, 0x01);
data[5] = buildHex(0x40, 0x40, 0x40, 0x40);
data[6] = buildHex(0x41, 0xe0, 0x00, 0x01);
data[7] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColorDefault(&data[0], 8);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[2] == buildHex(0x41, 0xee, 0x00, 0x01));
REQUIRE(data[3] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[4] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[5] == buildHex(0x00, 0x00, 0x00, 0x20));
REQUIRE(data[6] == buildHex(0x41, 0xe0, 0x00, 0x01));
REQUIRE(data[7] == buildHex(0xff, 0x30, 0x20, 0x10));
}
TEST_CASE("Dye replaceAOGLColor 8 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x40, 0xee, 0x00, 0x01);
data[1] = buildHex(0x40, 0xee, 0x00, 0x01);
data[2] = buildHex(0x41, 0xee, 0x00, 0x01);
data[3] = buildHex(0x40, 0xee, 0x00, 0x01);
data[4] = buildHex(0x40, 0xee, 0x00, 0x01);
data[5] = buildHex(0x40, 0x40, 0x40, 0x40);
data[6] = buildHex(0x41, 0xe0, 0x00, 0x01);
data[7] = buildHex(0x40, 0xee, 0x00, 0x01);
palette.replaceAOGLColorSimd(&data[0], 8);
REQUIRE(data[0] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[1] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[2] == buildHex(0x41, 0xee, 0x00, 0x01));
REQUIRE(data[3] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[4] == buildHex(0xff, 0x30, 0x20, 0x10));
REQUIRE(data[5] == buildHex(0x00, 0x00, 0x00, 0x20));
REQUIRE(data[6] == buildHex(0x41, 0xe0, 0x00, 0x01));
REQUIRE(data[7] == buildHex(0xff, 0x30, 0x20, 0x10));
}
#endif // USE_OPENGL
TEST_CASE("Dye replaceSColor 1 1")
{
DyePalette palette("#00ff00,000011", 6);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceSColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceSColor 1 2")
{
DyePalette palette("#403020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0x40, 0x30, 0x20, 0x10);
palette.replaceSColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 1 3")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
palette.replaceSColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 2 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[2];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColor(&data[0], 2);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 3 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[3];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x30, 0x20, 0x30);
palette.replaceSColor(&data[0], 3);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0x70, 0x60, 0x50, 0x30));
}
TEST_CASE("Dye replaceSColor 4 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[4];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColor(&data[0], 4);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 5 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[5];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x30);
data[4] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColor(&data[0], 5);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x30));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 7 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[7];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
palette.replaceSColor(&data[0], 7);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
}
TEST_CASE("Dye replaceSColor 8 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[8];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
palette.replaceSColor(&data[0], 8);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
}
TEST_CASE("Dye replaceSColor 9 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[9];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0xff, 0x30, 0x20, 0x70);
palette.replaceSColor(&data[0], 9);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x70, 0x60, 0x50, 0x70));
}
TEST_CASE("Dye replaceSColor 10 1")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[10];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0x12, 0x34, 0x56, 0x70);
data[9] = buildHex(0xff, 0x30, 0x20, 0x80);
palette.replaceSColor(&data[0], 10);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x00, 0x00, 0x00, 0x70));
REQUIRE(data[9] == buildHex(0x70, 0x60, 0x50, 0x80));
}
TEST_CASE("Dye replaceSColor 1 1 default")
{
DyePalette palette("#00ff00,000011", 6);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceSColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceSColor 1 2 default")
{
DyePalette palette("#403020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0x40, 0x30, 0x20, 0x10);
palette.replaceSColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 1 3 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
palette.replaceSColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 2 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[2];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorDefault(&data[0], 2);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 3 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[3];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x30, 0x20, 0x30);
palette.replaceSColorDefault(&data[0], 3);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0x70, 0x60, 0x50, 0x30));
}
TEST_CASE("Dye replaceSColor 4 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[4];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorDefault(&data[0], 4);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 5 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[5];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x30);
data[4] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorDefault(&data[0], 5);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x30));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 7 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[7];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
palette.replaceSColorDefault(&data[0], 7);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
}
TEST_CASE("Dye replaceSColor 8 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[8];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
palette.replaceSColorDefault(&data[0], 8);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
}
TEST_CASE("Dye replaceSColor 9 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[9];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0xff, 0x30, 0x20, 0x70);
palette.replaceSColorDefault(&data[0], 9);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x70, 0x60, 0x50, 0x70));
}
TEST_CASE("Dye replaceSColor 10 1 default")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[10];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0x12, 0x34, 0x56, 0x70);
data[9] = buildHex(0xff, 0x30, 0x20, 0x80);
palette.replaceSColorDefault(&data[0], 10);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x00, 0x00, 0x00, 0x70));
REQUIRE(data[9] == buildHex(0x70, 0x60, 0x50, 0x80));
}
TEST_CASE("Dye replaceSColor 1 1 simd")
{
DyePalette palette("#00ff00,000011", 6);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceSColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceSColor 1 2 simd")
{
DyePalette palette("#403020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0x40, 0x30, 0x20, 0x10);
palette.replaceSColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 1 3 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[1];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
palette.replaceSColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
}
TEST_CASE("Dye replaceSColor 2 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[2];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorSimd(&data[0], 2);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 3 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[3];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x30, 0x20, 0x30);
palette.replaceSColorSimd(&data[0], 3);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0x70, 0x60, 0x50, 0x30));
}
TEST_CASE("Dye replaceSColor 4 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[4];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorSimd(&data[0], 4);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 5 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[5];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x30);
data[4] = buildHex(0xff, 0x30, 0x20, 0x20);
palette.replaceSColorSimd(&data[0], 5);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x30));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x20));
}
TEST_CASE("Dye replaceSColor 7 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[7];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
palette.replaceSColorSimd(&data[0], 7);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
}
TEST_CASE("Dye replaceSColor 8 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[8];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
palette.replaceSColorSimd(&data[0], 8);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
}
TEST_CASE("Dye replaceSColor 9 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[9];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0xff, 0x30, 0x20, 0x70);
palette.replaceSColorSimd(&data[0], 9);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x70, 0x60, 0x50, 0x70));
}
TEST_CASE("Dye replaceSColor 10 1 simd")
{
DyePalette palette("#123456,000000,ff3020,706050", 6);
uint32_t data[10];
data[0] = buildHex(0xff, 0x30, 0x20, 0x10);
data[1] = buildHex(0xff, 0x30, 0x20, 0x20);
data[2] = buildHex(0xff, 0x40, 0x20, 0x10);
data[3] = buildHex(0xff, 0x30, 0x20, 0x20);
data[4] = buildHex(0xff, 0x30, 0x20, 0x10);
data[5] = buildHex(0xff, 0x30, 0x20, 0x40);
data[6] = buildHex(0xff, 0x40, 0x20, 0x50);
data[7] = buildHex(0xff, 0x30, 0x20, 0x60);
data[8] = buildHex(0x12, 0x34, 0x56, 0x70);
data[9] = buildHex(0xff, 0x30, 0x20, 0x80);
palette.replaceSColorSimd(&data[0], 10);
REQUIRE(data[0] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[1] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[2] == buildHex(0xff, 0x40, 0x20, 0x10));
REQUIRE(data[3] == buildHex(0x70, 0x60, 0x50, 0x20));
REQUIRE(data[4] == buildHex(0x70, 0x60, 0x50, 0x10));
REQUIRE(data[5] == buildHex(0x70, 0x60, 0x50, 0x40));
REQUIRE(data[6] == buildHex(0xff, 0x40, 0x20, 0x50));
REQUIRE(data[7] == buildHex(0x70, 0x60, 0x50, 0x60));
REQUIRE(data[8] == buildHex(0x00, 0x00, 0x00, 0x70));
REQUIRE(data[9] == buildHex(0x70, 0x60, 0x50, 0x80));
}
TEST_CASE("Dye replaceAColor 1 1")
{
DyePalette palette("#00ff0010,00001120", 8);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceAColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceAColor 1 2")
{
DyePalette palette("#02ff0120,040311ff", 8);
uint32_t data[1];
data[0] = buildHex(0x02, 0xff, 0x01, 0x20);
palette.replaceAColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x04, 0x03, 0x11, 0xff));
}
TEST_CASE("Dye replaceAColor 1 3")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[1];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColor(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye replaceAColor 2 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[2];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 2);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 3 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[3];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x50, 0x40, 0x40, 0x30);
data[2] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 3);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x50, 0x40, 0x40, 0x30));
REQUIRE(data[2] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 4 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[4];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 4);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 5 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[5];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x50, 0x40, 0x40, 0x60);
data[4] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 5);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x50, 0x40, 0x40, 0x60));
REQUIRE(data[4] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 7 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[7];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
palette.replaceAColor(&data[0], 7);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
}
TEST_CASE("Dye replaceAColor 8 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 8);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 9 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[9];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColor(&data[0], 9);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 10 1")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[10];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
data[9] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColor(&data[0], 10);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[9] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye replaceAColor 1 1 default")
{
DyePalette palette("#00ff0010,00001120", 8);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceAColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceAColor 1 2 default")
{
DyePalette palette("#02ff0120,040311ff", 8);
uint32_t data[1];
data[0] = buildHex(0x02, 0xff, 0x01, 0x20);
palette.replaceAColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x04, 0x03, 0x11, 0xff));
}
TEST_CASE("Dye replaceAColor 1 3 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[1];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColorDefault(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye replaceAColor 2 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[2];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 2);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 3 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[3];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x50, 0x40, 0x40, 0x30);
data[2] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 3);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x50, 0x40, 0x40, 0x30));
REQUIRE(data[2] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 4 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[4];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 4);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 5 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[5];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x50, 0x40, 0x40, 0x60);
data[4] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 5);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x50, 0x40, 0x40, 0x60));
REQUIRE(data[4] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 7 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[7];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
palette.replaceAColorDefault(&data[0], 7);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
}
TEST_CASE("Dye replaceAColor 8 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 8);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 9 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[9];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorDefault(&data[0], 9);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 10 1 default")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[10];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
data[9] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColorDefault(&data[0], 10);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[9] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye replaceAColor 1 1 simd")
{
DyePalette palette("#00ff0010,00001120", 8);
uint32_t data[1];
data[0] = buildHex(0x10, 0x03, 0x02, 0x01);
palette.replaceAColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x03, 0x02, 0x01));
}
TEST_CASE("Dye replaceAColor 1 2 simd")
{
DyePalette palette("#02ff0120,040311ff", 8);
uint32_t data[1];
data[0] = buildHex(0x02, 0xff, 0x01, 0x20);
palette.replaceAColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x04, 0x03, 0x11, 0xff));
}
TEST_CASE("Dye replaceAColor 1 3 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[1];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColorSimd(&data[0], 1);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye replaceAColor 2 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[2];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 2);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 3 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[3];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x50, 0x40, 0x40, 0x30);
data[2] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 3);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x50, 0x40, 0x40, 0x30));
REQUIRE(data[2] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 4 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[4];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 4);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 5 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[5];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x50, 0x40, 0x40, 0x60);
data[4] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 5);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x50, 0x40, 0x40, 0x60));
REQUIRE(data[4] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 7 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[7];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
palette.replaceAColorSimd(&data[0], 7);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
}
TEST_CASE("Dye replaceAColor 8 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[8];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 8);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 9 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[9];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
palette.replaceAColorSimd(&data[0], 9);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
}
TEST_CASE("Dye replaceAColor 10 1 simd")
{
DyePalette palette("#40404040,20000000,0100ee40,102030ff", 8);
uint32_t data[10];
data[0] = buildHex(0x01, 0x00, 0xee, 0x40);
data[1] = buildHex(0x40, 0x40, 0x40, 0x40);
data[2] = buildHex(0x01, 0x00, 0xee, 0x50);
data[3] = buildHex(0x40, 0x40, 0x40, 0x40);
data[4] = buildHex(0x01, 0x00, 0xee, 0x40);
data[5] = buildHex(0x40, 0x40, 0x41, 0x40);
data[6] = buildHex(0x01, 0x00, 0xee, 0x50);
data[7] = buildHex(0x02, 0x40, 0x40, 0x40);
data[8] = buildHex(0x40, 0x40, 0x40, 0x40);
data[9] = buildHex(0x01, 0x00, 0xee, 0x40);
palette.replaceAColorSimd(&data[0], 10);
REQUIRE(data[0] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[1] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[2] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[3] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[4] == buildHex(0x10, 0x20, 0x30, 0xff));
REQUIRE(data[5] == buildHex(0x40, 0x40, 0x41, 0x40));
REQUIRE(data[6] == buildHex(0x01, 0x00, 0xee, 0x50));
REQUIRE(data[7] == buildHex(0x02, 0x40, 0x40, 0x40));
REQUIRE(data[8] == buildHex(0x20, 0x00, 0x00, 0x00));
REQUIRE(data[9] == buildHex(0x10, 0x20, 0x30, 0xff));
}
TEST_CASE("Dye normalDye 1")
{
Dye dye("R:#203040,506070");
uint32_t data[1];
data[0] = buildHex(0x50, 0x00, 0x00, 0x55);
dye.normalDye(&data[0], 1);
REQUIRE(data[0] == buildHex(0x14, 0x1e, 0x28, 0x55));
}
TEST_CASE("Dye normalDye 2")
{
Dye dye("G:#203040,506070");
uint32_t data[1];
data[0] = buildHex(0x00, 0x50, 0x00, 0x60);
dye.normalDye(&data[0], 1);
REQUIRE(data[0] == buildHex(0x14, 0x1e, 0x28, 0x60));
}
#ifdef USE_OPENGL
TEST_CASE("Dye normalOGLDye 1")
{
Dye dye("R:#203040,506070");
uint32_t data[1];
data[0] = buildHex(0x50, 0x00, 0x00, 0x55);
dye.normalOGLDye(&data[0], 1);
REQUIRE(data[0] == buildHex(0x50, 0x2a, 0x20, 0x15));
}
#endif // USE_OPENGL
static void dyeCheck(const std::string &dyeString,
const std::string &dstName)
{
const std::string srcName = "arrow_up.png";
Image *const image1 = Loader::getImage(srcName + dyeString);
Image *const image2 = Loader::getImage(dstName);
REQUIRE(image1 != nullptr);
REQUIRE(image2 != nullptr);
SDL_Surface *const surface1 = image1->getSDLSurface();
SDL_Surface *const surface2 = image2->getSDLSurface();
REQUIRE(surface1 != nullptr);
REQUIRE(surface2 != nullptr);
REQUIRE(surface1->w == surface2->w);
REQUIRE(surface1->h == surface2->h);
REQUIRE(surface1->pixels != nullptr);
REQUIRE(surface2->pixels != nullptr);
const uint32_t *const ptr1 = static_cast(
surface1->pixels);
const uint32_t *const ptr2 = static_cast(
surface2->pixels);
const size_t sz = surface1->w * surface1->h;
for (size_t idx = 0; idx < sz; idx ++)
{
REQUIRE(ptr1[idx] == ptr2[idx]);
}
image2->decRef();
image1->decRef();
}
TEST_CASE("Dye real dye")
{
setEnv("SDL_VIDEODRIVER", "dummy");
client = new Client;
PHYSFS_init("manaplus");
dirSeparator = "/";
SDL_Init(SDL_INIT_VIDEO);
logger = new Logger();
ResourceManager::init();
resourceManager->addToSearchPath("data/test", Append_false);
resourceManager->addToSearchPath("../data/test", Append_false);
#ifdef USE_SDL2
imageHelper = new SurfaceImageHelper;
SDLImageHelper::setRenderer(graphicsManager.createRenderer(
graphicsManager.createWindow(640, 480, 0,
SDL_WINDOW_SHOWN | SDL_SWSURFACE), SDL_RENDERER_SOFTWARE));
#else // USE_SDL2
imageHelper = new SDLImageHelper;
graphicsManager.createWindow(640, 480, 0, SDL_ANYFORMAT | SDL_SWSURFACE);
#endif // USE_SDL2
ActorSprite::load();
SECTION("B dye")
{
dyeCheck("|B:#FFC88A", "arrow_up_B.png");
}
SECTION("S dye")
{
dyeCheck("|S:#0000FF,FF0000", "arrow_up_S.png");
}
SECTION("A dye")
{
dyeCheck("|A:#0000FFFF,FF000050", "arrow_up_A.png");
}
delete2(client);
}