aboutsummaryrefslogtreecommitdiffstats
path: root/src/test.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/test.c273
1 files changed, 0 insertions, 273 deletions
diff --git a/src/test.c b/src/test.c
deleted file mode 100644
index 4a94a42..0000000
--- a/src/test.c
+++ /dev/null
@@ -1,273 +0,0 @@
-/**
- * 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 <http://www.gnu.org/licenses/>.
- */
-#include "libcoopgamma.h"
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-
-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;
-}
-