/** * libcoopgamma -- Library for interfacing with cooperative gamma servers * Copyright (C) 2016 Mattias Andrée (maandree@kth.se) * * This library 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 3 of the License, or * (at your option) any later version. * * This library 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 library. If not, see . */ #include "libcoopgamma.h" #include #include #include static int streq(const char* a, const char* b) { if ((a == NULL) != (b == NULL)) return 0; return (a == NULL) || !strcmp(a, b); } static int rampseq(const libcoopgamma_ramps_t* a, const libcoopgamma_ramps_t* b, libcoopgamma_depth_t depth) { size_t nr, ng, nb, width; if ((a->u8.red_size != b->u8.red_size) || (a->u8.green_size != b->u8.green_size) || (a->u8.blue_size != b->u8.blue_size)) return 0; if (depth == -2) width = sizeof(double); else if (depth == -1) width = sizeof(float); else width = ((size_t)depth) / 8; nr = a->u8.red_size * width; ng = a->u8.green_size * width; nb = a->u8.blue_size * width; if (memcmp(a->u8.red, b->u8.red, nr + ng + nb)) return 0; if (memcmp(a->u8.green, b->u8.green, ng + nb)) return 0; if (memcmp(a->u8.blue, b->u8.blue, nb)) return 0; return 1; } int main(void) { libcoopgamma_filter_t filter1, filter2; libcoopgamma_crtc_info_t crtc1, crtc2; libcoopgamma_filter_query_t query1, query2; libcoopgamma_filter_table_t table1, table2; libcoopgamma_context_t ctx1, ctx2; libcoopgamma_async_context_t async1, async2; size_t n, m, i; char* buf; filter1.priority = INT64_MIN; filter1.crtc = "CRTC"; filter1.class = "A::B::C::D"; filter1.lifespan = LIBCOOPGAMMA_UNTIL_REMOVAL; filter1.depth = LIBCOOPGAMMA_DOUBLE; filter1.ramps.d.red_size = 4; filter1.ramps.d.green_size = 5; filter1.ramps.d.blue_size = 6; filter1.ramps.d.red = (double[]){0.0, 0.1, 0.2, 0.5, 0.3, 0.11, 0.22, 0.45, 0.9, -1, -0.5, 0, 0.5, 1, 1.5}; filter1.ramps.d.green = filter1.ramps.d.red + filter1.ramps.d.red_size; filter1.ramps.d.blue = filter1.ramps.d.green + filter1.ramps.d.green_size; crtc1.cooperative = 0; crtc1.depth = LIBCOOPGAMMA_DOUBLE; crtc1.supported = LIBCOOPGAMMA_YES; crtc1.red_size = 4; crtc1.green_size = 5; crtc1.blue_size = 6; crtc1.colourspace = LIBCOOPGAMMA_SRGB; crtc1.have_gamut = 1; crtc1.red_x = 100; crtc1.red_y = 50; crtc1.green_x = 300; crtc1.green_y = 350; crtc1.blue_x = 200; crtc1.blue_y = 260; crtc1.white_x = 500; crtc1.white_y = 999; query1.high_priority = INT64_MIN; query1.low_priority = INT64_MIN; query1.crtc = "crtc"; query1.coalesce = 1; table1.red_size = 4; table1.green_size = 5; table1.blue_size = 6; table1.filter_count = 2; table1.filters = (libcoopgamma_queried_filter_t[]){ { .priority = UINT64_MAX, .class = "a::b::c", .ramps.d = { .red_size = 4, .green_size = 5, .blue_size = 6, .red = (double[]){0.0, 0.1, 0.2, 0.5, 0.3, 0.11, 0.22, 0.45, 0.9, -1, -0.5, 0, 0.5, 1, 1.5} } }, { .priority = UINT64_MAX - 1, .class = NULL, .ramps.d = { .red_size = 4, .green_size = 5, .blue_size = 6, .red = (double[]){0.02, 0.12, 0.22, 0.52, 0.32, 0.112, 0.222, 0.452, 0.92, -12, -0.52, 0.2, 0.52, 12, 1.52} } } }; table1.depth = LIBCOOPGAMMA_DOUBLE; table1.filters[0].ramps.d.green = table1.filters[0].ramps.d.red + table1.filters[0].ramps.d.red_size; table1.filters[1].ramps.d.green = table1.filters[1].ramps.d.red + table1.filters[1].ramps.d.red_size; table1.filters[0].ramps.d.blue = table1.filters[0].ramps.d.green + table1.filters[0].ramps.d.green_size; table1.filters[1].ramps.d.blue = table1.filters[1].ramps.d.green + table1.filters[1].ramps.d.green_size; ctx1.error.number = UINT64_MAX; ctx1.error.custom = 1; ctx1.error.server_side = 0; ctx1.error.description = "description"; ctx1.fd = 3; ctx1.have_all_headers = 1; ctx1.bad_message = 0; ctx1.blocking = 2; ctx1.message_id = UINT32_MAX; ctx1.in_response_to = UINT32_MAX - 1; ctx1.outbound = "0123456789"; ctx1.outbound_head = 7; ctx1.outbound_tail = 2; ctx1.outbound_size = 10; ctx1.inbound = "abcdefghi"; ctx1.inbound_head = 6; ctx1.inbound_tail = 3; ctx1.inbound_size = 9; ctx1.length = 100; ctx1.curline = 5; async1.message_id = UINT32_MAX; async1.coalesce = 1; n = libcoopgamma_filter_marshal(&filter1, NULL); n += libcoopgamma_crtc_info_marshal(&crtc1, NULL); n += libcoopgamma_filter_query_marshal(&query1, NULL); n += libcoopgamma_filter_table_marshal(&table1, NULL); n += libcoopgamma_context_marshal(&ctx1, NULL); n += libcoopgamma_async_context_marshal(&async1, NULL); buf = malloc(n); n = libcoopgamma_filter_marshal(&filter1, buf); n += libcoopgamma_crtc_info_marshal(&crtc1, buf + n); n += libcoopgamma_filter_query_marshal(&query1, buf + n); n += libcoopgamma_filter_table_marshal(&table1, buf + n); n += libcoopgamma_context_marshal(&ctx1, buf + n); n += libcoopgamma_async_context_marshal(&async1, buf + n); if (libcoopgamma_filter_unmarshal(&filter2, buf, &m)) return 1; else n = m; if (libcoopgamma_crtc_info_unmarshal(&crtc2, buf + n, &m)) return 2; else n += m; if (libcoopgamma_filter_query_unmarshal(&query2, buf + n, &m)) return 3; else n += m; if (libcoopgamma_filter_table_unmarshal(&table2, buf + n, &m)) return 4; else n += m; if (libcoopgamma_context_unmarshal(&ctx2, buf + n, &m)) return 5; else n += m; if (libcoopgamma_async_context_unmarshal(&async2, buf + n, &m)) return 6; free(buf); if ((filter1.priority != filter2.priority) || (!streq(filter1.crtc, filter2.crtc)) || (!streq(filter1.class, filter2.class)) || (filter1.lifespan != filter2.lifespan) || (filter1.depth != filter2.depth) || (!rampseq(&(filter1.ramps), &(filter2.ramps), filter1.depth))) return 7; if ((crtc1.cooperative != crtc2.cooperative) || (crtc1.depth != crtc2.depth) || (crtc1.supported != crtc2.supported) || (crtc1.red_size != crtc2.red_size) || (crtc1.green_size != crtc2.green_size) || (crtc1.blue_size != crtc2.blue_size) || (crtc1.colourspace != crtc2.colourspace) || (crtc1.have_gamut != crtc2.have_gamut) || (crtc1.red_x != crtc2.red_x) || (crtc1.red_y != crtc2.red_y) || (crtc1.green_x != crtc2.green_x) || (crtc1.green_y != crtc2.green_y) || (crtc1.blue_x != crtc2.blue_x) || (crtc1.blue_y != crtc2.blue_y) || (crtc1.white_x != crtc2.white_x) || (crtc1.white_y != crtc2.white_y)) return 8; if ((query1.high_priority != query2.high_priority) || (query1.low_priority != query2.low_priority) || !streq(query1.crtc, query2.crtc) || (query1.coalesce != query2.coalesce)) return 9; if ((table1.red_size != table2.red_size) || (table1.green_size != table2.green_size) || (table1.blue_size != table2.blue_size) || (table1.filter_count != table2.filter_count) || (table1.depth != table2.depth)) return 10; for (i = 0; i < table1.filter_count; i++) if ((table1.filters[i].priority != table2.filters[i].priority) || !streq(table1.filters[i].class, table2.filters[i].class) || !rampseq(&(table1.filters[i].ramps), &(table2.filters[i].ramps), table1.depth)) return 11; if ((ctx1.error.number != ctx2.error.number) || (ctx1.error.custom != ctx2.error.custom) || (ctx1.error.server_side != ctx2.error.server_side) || !streq(ctx1.error.description, ctx2.error.description)) return 12; if ((ctx1.fd != ctx2.fd) || (ctx1.have_all_headers != ctx2.have_all_headers) || (ctx1.bad_message != ctx2.bad_message) || (ctx1.blocking != ctx2.blocking) || (ctx1.message_id != ctx2.message_id) || (ctx1.in_response_to != ctx2.in_response_to) || (ctx1.length != ctx2.length) || (ctx1.curline != ctx2.curline)) return 13; if ((ctx2.outbound_head > ctx2.outbound_size) || (ctx2.outbound_tail > ctx2.outbound_size) || (ctx2.inbound_head > ctx2.inbound_size) || (ctx2.inbound_tail > ctx2.inbound_size)) return 14; if (((n = ctx1.outbound_head - ctx1.outbound_tail) != ctx2.outbound_head - ctx2.outbound_tail) || ((m = ctx1.inbound_head - ctx1.inbound_tail) != ctx2.inbound_head - ctx2.inbound_tail)) return 15; if (memcmp(ctx1.outbound + ctx1.outbound_tail, ctx2.outbound + ctx2.outbound_tail, n) || memcmp(ctx1.inbound + ctx1.inbound_tail, ctx2.inbound + ctx2.inbound_tail, m)) return 16; if ((async1.message_id != async2.message_id) || (async1.coalesce != async2.coalesce)) return 17; return 0; }