/* * 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); }