|
|
|
@ -106,164 +106,127 @@ TEST_CASE("Visual") {
|
|
|
|
|
// write a checkerboard pattern and verify the NCBLIT_2x2 output
|
|
|
|
|
SUBCASE("Quadblitter") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
constexpr int DIMY = 10;
|
|
|
|
|
constexpr int DIMX = 11; // odd number to get checkerboard effect
|
|
|
|
|
auto rgba = new uint32_t[DIMY * DIMX];
|
|
|
|
|
for(int i = 0 ; i < DIMY * DIMX ; ++i){
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[i], 0xff));
|
|
|
|
|
if(i % 2){
|
|
|
|
|
CHECK(0 == ncpixel_set_b(&rgba[i], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_g(&rgba[i], 0));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0 == ncpixel_set_g(&rgba[i], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_b(&rgba[i], 0));
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
constexpr int DIMY = 10;
|
|
|
|
|
constexpr int DIMX = 11; // odd number to get checkerboard effect
|
|
|
|
|
auto rgba = new uint32_t[DIMY * DIMX];
|
|
|
|
|
for(int i = 0 ; i < DIMY * DIMX ; ++i){
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[i], 0xff));
|
|
|
|
|
if(i % 2){
|
|
|
|
|
CHECK(0 == ncpixel_set_b(&rgba[i], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_g(&rgba[i], 0));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0 == ncpixel_set_g(&rgba[i], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_b(&rgba[i], 0));
|
|
|
|
|
}
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[i], 0));
|
|
|
|
|
}
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[i], 0));
|
|
|
|
|
}
|
|
|
|
|
auto ncv = ncvisual_from_rgba(rgba, DIMY, DIMX * sizeof(uint32_t), DIMX);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts{};
|
|
|
|
|
vopts.n = n_;
|
|
|
|
|
vopts.blitter = NCBLIT_2x2;
|
|
|
|
|
vopts.flags = NCVISUAL_OPTION_NODEGRADE;
|
|
|
|
|
CHECK(n_ == ncvisual_render(nc_, ncv, &vopts));
|
|
|
|
|
CHECK(0 == notcurses_render(nc_));
|
|
|
|
|
for(int y = 0 ; y < DIMY / 2 ; ++y){
|
|
|
|
|
for(int x = 0 ; x < DIMX / 2 ; ++x){
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
char* egc = notcurses_at_yx(nc_, y, x, &stylemask, &channels);
|
|
|
|
|
REQUIRE(nullptr != egc);
|
|
|
|
|
CHECK((htole(rgba[(y * 2 * DIMX) + (x * 2)]) & 0xffffff) == channels_fg_rgb(channels));
|
|
|
|
|
CHECK((htole(rgba[(y * 2 + 1) * DIMX + (x * 2) + 1]) & 0xffffff) == channels_fg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
auto ncv = ncvisual_from_rgba(rgba, DIMY, DIMX * sizeof(uint32_t), DIMX);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts{};
|
|
|
|
|
vopts.n = n_;
|
|
|
|
|
vopts.blitter = NCBLIT_2x2;
|
|
|
|
|
vopts.flags = NCVISUAL_OPTION_NODEGRADE;
|
|
|
|
|
CHECK(n_ == ncvisual_render(nc_, ncv, &vopts));
|
|
|
|
|
CHECK(0 == notcurses_render(nc_));
|
|
|
|
|
for(int y = 0 ; y < DIMY / 2 ; ++y){
|
|
|
|
|
for(int x = 0 ; x < DIMX / 2 ; ++x){
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
char* egc = notcurses_at_yx(nc_, y, x, &stylemask, &channels);
|
|
|
|
|
REQUIRE(nullptr != egc);
|
|
|
|
|
CHECK((htole(rgba[(y * 2 * DIMX) + (x * 2)]) & 0xffffff) == channels_fg_rgb(channels));
|
|
|
|
|
CHECK((htole(rgba[(y * 2 + 1) * DIMX + (x * 2) + 1]) & 0xffffff) == channels_fg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
delete[] rgba;
|
|
|
|
|
}
|
|
|
|
|
delete[] rgba;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// close-in verification of each quadblitter output EGC
|
|
|
|
|
SUBCASE("QuadblitterEGCs") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
// there are 16 configurations, each mapping four (2x2) pixels
|
|
|
|
|
int DIMX = 32;
|
|
|
|
|
int DIMY = 2;
|
|
|
|
|
auto rgba = new uint32_t[DIMY * DIMX];
|
|
|
|
|
memset(rgba, 0, sizeof(*rgba) * DIMY * DIMX);
|
|
|
|
|
// the top has 4 configurations of 4 each, each being 2 columns
|
|
|
|
|
for(int top = 0 ; top < 4 ; ++top){
|
|
|
|
|
for(int idx = 0 ; idx < 4 ; ++idx){
|
|
|
|
|
const int itop = (top * 4 + idx) * 2; // index of first column
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[itop], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[itop + 1], 0xff));
|
|
|
|
|
if(top == 1 || top == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[itop], 0xff));
|
|
|
|
|
}
|
|
|
|
|
if(top == 2 || top == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[itop + 1], 0xff));
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
// there are 16 configurations, each mapping four (2x2) pixels
|
|
|
|
|
int DIMX = 32;
|
|
|
|
|
int DIMY = 2;
|
|
|
|
|
auto rgba = new uint32_t[DIMY * DIMX];
|
|
|
|
|
memset(rgba, 0, sizeof(*rgba) * DIMY * DIMX);
|
|
|
|
|
// the top has 4 configurations of 4 each, each being 2 columns
|
|
|
|
|
for(int top = 0 ; top < 4 ; ++top){
|
|
|
|
|
for(int idx = 0 ; idx < 4 ; ++idx){
|
|
|
|
|
const int itop = (top * 4 + idx) * 2; // index of first column
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[itop], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[itop + 1], 0xff));
|
|
|
|
|
if(top == 1 || top == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[itop], 0xff));
|
|
|
|
|
}
|
|
|
|
|
if(top == 2 || top == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[itop + 1], 0xff));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
for(int bot = 0 ; bot < 4 ; ++bot){
|
|
|
|
|
for(int idx = 0 ; idx < 4 ; ++idx){
|
|
|
|
|
const int ibot = (bot * 4 + idx) * 2 + DIMX;
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[ibot], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[ibot + 1], 0xff));
|
|
|
|
|
if(idx == 1 || idx == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[ibot], 0xff));
|
|
|
|
|
}
|
|
|
|
|
if(idx == 2 || idx == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[ibot + 1], 0xff));
|
|
|
|
|
for(int bot = 0 ; bot < 4 ; ++bot){
|
|
|
|
|
for(int idx = 0 ; idx < 4 ; ++idx){
|
|
|
|
|
const int ibot = (bot * 4 + idx) * 2 + DIMX;
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[ibot], 0xff));
|
|
|
|
|
CHECK(0 == ncpixel_set_a(&rgba[ibot + 1], 0xff));
|
|
|
|
|
if(idx == 1 || idx == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[ibot], 0xff));
|
|
|
|
|
}
|
|
|
|
|
if(idx == 2 || idx == 3){
|
|
|
|
|
CHECK(0 == ncpixel_set_r(&rgba[ibot + 1], 0xff));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
auto ncv = ncvisual_from_rgba(rgba, DIMY, DIMX * sizeof(uint32_t), DIMX);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts{};
|
|
|
|
|
vopts.n = n_;
|
|
|
|
|
vopts.blitter = NCBLIT_2x2;
|
|
|
|
|
vopts.flags = NCVISUAL_OPTION_NODEGRADE;
|
|
|
|
|
CHECK(n_ == ncvisual_render(nc_, ncv, &vopts));
|
|
|
|
|
CHECK(0 == notcurses_render(nc_));
|
|
|
|
|
for(int y = 0 ; y < DIMY / 2 ; ++y){
|
|
|
|
|
for(int x = 0 ; x < DIMX / 2 ; ++x){
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
char* egc = notcurses_at_yx(nc_, y, x, &stylemask, &channels);
|
|
|
|
|
REQUIRE(nullptr != egc);
|
|
|
|
|
/* FIXME need to match
|
|
|
|
|
[▀] 00000000 00000000
|
|
|
|
|
[▜] 00000000 00ff0000
|
|
|
|
|
[▛] 00000000 00ff0000
|
|
|
|
|
[▀] 00000000 00ff0000
|
|
|
|
|
[▟] 00000000 00ff0000
|
|
|
|
|
[▋] 00ff0000 00000000
|
|
|
|
|
[▚] 00ff0000 00000000
|
|
|
|
|
[▙] 00ff0000 00000000
|
|
|
|
|
[▙] 00000000 00ff0000
|
|
|
|
|
[▚] 00000000 00ff0000
|
|
|
|
|
[▋] 00000000 00ff0000
|
|
|
|
|
[▟] 00ff0000 00000000
|
|
|
|
|
[▀] 00ff0000 00000000
|
|
|
|
|
[▛] 00ff0000 00000000
|
|
|
|
|
[▜] 00ff0000 00000000
|
|
|
|
|
[▀] 00ff0000 00ff0000
|
|
|
|
|
*/
|
|
|
|
|
free(egc);
|
|
|
|
|
auto ncv = ncvisual_from_rgba(rgba, DIMY, DIMX * sizeof(uint32_t), DIMX);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts{};
|
|
|
|
|
vopts.n = n_;
|
|
|
|
|
vopts.blitter = NCBLIT_2x2;
|
|
|
|
|
vopts.flags = NCVISUAL_OPTION_NODEGRADE;
|
|
|
|
|
CHECK(n_ == ncvisual_render(nc_, ncv, &vopts));
|
|
|
|
|
CHECK(0 == notcurses_render(nc_));
|
|
|
|
|
for(int y = 0 ; y < DIMY / 2 ; ++y){
|
|
|
|
|
for(int x = 0 ; x < DIMX / 2 ; ++x){
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
char* egc = notcurses_at_yx(nc_, y, x, &stylemask, &channels);
|
|
|
|
|
REQUIRE(nullptr != egc);
|
|
|
|
|
/* FIXME need to match
|
|
|
|
|
[▀] 00000000 00000000
|
|
|
|
|
[▜] 00000000 00ff0000
|
|
|
|
|
[▛] 00000000 00ff0000
|
|
|
|
|
[▀] 00000000 00ff0000
|
|
|
|
|
[▟] 00000000 00ff0000
|
|
|
|
|
[▋] 00ff0000 00000000
|
|
|
|
|
[▚] 00ff0000 00000000
|
|
|
|
|
[▙] 00ff0000 00000000
|
|
|
|
|
[▙] 00000000 00ff0000
|
|
|
|
|
[▚] 00000000 00ff0000
|
|
|
|
|
[▋] 00000000 00ff0000
|
|
|
|
|
[▟] 00ff0000 00000000
|
|
|
|
|
[▀] 00ff0000 00000000
|
|
|
|
|
[▛] 00ff0000 00000000
|
|
|
|
|
[▜] 00ff0000 00000000
|
|
|
|
|
[▀] 00ff0000 00ff0000
|
|
|
|
|
*/
|
|
|
|
|
free(egc);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
delete[] rgba;
|
|
|
|
|
}
|
|
|
|
|
delete[] rgba;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// quadblitter with all 4 colors equal ought generate space
|
|
|
|
|
SUBCASE("Quadblitter4Same") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
const uint32_t pixels[4] = { htole(0xff605040), htole(0xff605040), htole(0xff605040), htole(0xff605040) };
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels, 2, 2 * sizeof(*pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(" ", egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0x405060 == channels_bg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// quadblitter with three pixels equal ought generate three-quarter block
|
|
|
|
|
SUBCASE("Quadblitter3Same") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
const uint32_t pixels[4][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xff605040), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▟", "▙", "▜", "▛" };
|
|
|
|
|
for(int i = 0 ; i < 4 ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
const uint32_t pixels[4] = { htole(0xff605040), htole(0xff605040), htole(0xff605040), htole(0xff605040) };
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels, 2, 2 * sizeof(*pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
@ -286,62 +249,109 @@ TEST_CASE("Visual") {
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == strcmp(" ", egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_bg_rgb(channels));
|
|
|
|
|
CHECK(0x405060 == channels_bg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// quadblitter with two sets of two equal pixels
|
|
|
|
|
SUBCASE("Quadblitter2Pairs") {
|
|
|
|
|
// quadblitter with three pixels equal ought generate three-quarter block
|
|
|
|
|
SUBCASE("Quadblitter3Same") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xffcccccc), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffcccccc), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▀", "▌", "▚", "▚", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
if(i >= 3){
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
const uint32_t pixels[4][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xff605040), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▟", "▙", "▜", "▛" };
|
|
|
|
|
for(int i = 0 ; i < 4 ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_bg_rgb(channels));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0x405060 == channels_bg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_fg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// quadblitter with two sets of two equal pixels
|
|
|
|
|
SUBCASE("Quadblitter2Pairs") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xffcccccc), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffcccccc), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▀", "▌", "▚", "▚", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
if(i >= 3){
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_bg_rgb(channels));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0x405060 == channels_bg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_fg_rgb(channels));
|
|
|
|
|
}
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -349,49 +359,51 @@ TEST_CASE("Visual") {
|
|
|
|
|
// quadblitter with one pair plus two split
|
|
|
|
|
SUBCASE("Quadblitter1Pair") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff444444), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff444444), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xff444444) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff444444), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffeeeeee), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffeeeeee), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▟", "▜", "▟", "▙", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
if(i > 3){
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xdddddd == channels_bg_rgb(channels));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0x424c57 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_bg_rgb(channels));
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff444444), htole(0xff605040), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff444444), htole(0xff605040), htole(0xffcccccc), htole(0xff605040) },
|
|
|
|
|
{ htole(0xffcccccc), htole(0xff605040), htole(0xff605040), htole(0xff444444) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffcccccc), htole(0xff444444), htole(0xff605040) },
|
|
|
|
|
{ htole(0xff605040), htole(0xffeeeeee), htole(0xff605040), htole(0xffcccccc) },
|
|
|
|
|
{ htole(0xff605040), htole(0xff605040), htole(0xffeeeeee), htole(0xffcccccc) } };
|
|
|
|
|
const char* egcs[] = { "▟", "▜", "▟", "▙", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
if(i > 3){
|
|
|
|
|
CHECK(0x405060 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xdddddd == channels_bg_rgb(channels));
|
|
|
|
|
}else{
|
|
|
|
|
CHECK(0x424c57 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xcccccc == channels_bg_rgb(channels));
|
|
|
|
|
}
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -399,43 +411,45 @@ TEST_CASE("Visual") {
|
|
|
|
|
// quadblitter with one pair plus two split
|
|
|
|
|
SUBCASE("QuadblitterAllDifferent") {
|
|
|
|
|
if(notcurses_canutf8(nc_)){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffdddddd), htole(0xff000000), htole(0xff111111), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff000000), htole(0xff111111), htole(0xffdddddd), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff111111), htole(0xffdddddd), htole(0xff000000), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff000000), htole(0xffcccccc), htole(0xff222222), htole(0xffeeeeee) },
|
|
|
|
|
{ htole(0xff222222), htole(0xff000000), htole(0xffeeeeee), htole(0xffcccccc), } };
|
|
|
|
|
const char* egcs[] = { "▟", "▜", "▙", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
CHECK(0x111111 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xdddddd == channels_bg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
if(nc_->tcache.quadrants){
|
|
|
|
|
const uint32_t pixels[6][4] = {
|
|
|
|
|
{ htole(0xffdddddd), htole(0xff000000), htole(0xff111111), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff000000), htole(0xff111111), htole(0xffdddddd), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff111111), htole(0xffdddddd), htole(0xff000000), htole(0xff222222) },
|
|
|
|
|
{ htole(0xff000000), htole(0xffcccccc), htole(0xff222222), htole(0xffeeeeee) },
|
|
|
|
|
{ htole(0xff222222), htole(0xff000000), htole(0xffeeeeee), htole(0xffcccccc), } };
|
|
|
|
|
const char* egcs[] = { "▟", "▜", "▙", "▌", "▀" };
|
|
|
|
|
for(size_t i = 0 ; i < sizeof(egcs) / sizeof(*egcs) ; ++i){
|
|
|
|
|
auto ncv = ncvisual_from_rgba(pixels[i], 2, 2 * sizeof(**pixels), 2);
|
|
|
|
|
REQUIRE(nullptr != ncv);
|
|
|
|
|
struct ncvisual_options vopts = {
|
|
|
|
|
.n = nullptr,
|
|
|
|
|
.scaling = NCSCALE_NONE,
|
|
|
|
|
.y = 0,
|
|
|
|
|
.x = 0,
|
|
|
|
|
.begy = 0,
|
|
|
|
|
.begx = 0,
|
|
|
|
|
.leny = 0,
|
|
|
|
|
.lenx = 0,
|
|
|
|
|
.blitter = NCBLIT_2x2,
|
|
|
|
|
.flags = 0,
|
|
|
|
|
};
|
|
|
|
|
auto ncvp = ncvisual_render(nc_, ncv, &vopts);
|
|
|
|
|
REQUIRE(nullptr != ncvp);
|
|
|
|
|
int dimy, dimx;
|
|
|
|
|
ncplane_dim_yx(ncvp, &dimy, &dimx);
|
|
|
|
|
CHECK(1 == dimy);
|
|
|
|
|
CHECK(1 == dimx);
|
|
|
|
|
uint16_t stylemask;
|
|
|
|
|
uint64_t channels;
|
|
|
|
|
auto egc = ncplane_at_yx(ncvp, 0, 0, &stylemask, &channels);
|
|
|
|
|
CHECK(0 == strcmp(egcs[i], egc));
|
|
|
|
|
CHECK(0 == stylemask);
|
|
|
|
|
CHECK(0x111111 == channels_fg_rgb(channels));
|
|
|
|
|
CHECK(0xdddddd == channels_bg_rgb(channels));
|
|
|
|
|
free(egc);
|
|
|
|
|
ncvisual_destroy(ncv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|