aboutsummaryrefslogtreecommitdiffstats
path: root/src/blind-colour-srgb.c
blob: 53fb7841c3f3a4e5dd2e9203462ea57adca4a43b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/* See LICENSE file for copyright and license details. */
#include "util.h"

USAGE("[-d depth] [-l] red green blue")

int
main(int argc, char *argv[])
{
	unsigned long long int max;
	double red, green, blue, X, Y, Z;
	int depth = 8, linear = 0;

	ARGBEGIN {
	case 'd':
		depth = etoi_flag('d', EARG(), 1, 64);
		break;
	case 'l':
		linear = 1;
		break;
	default:
		usage();
	} ARGEND;

	if (argc != 3)
		usage();

	max   = 1ULL << (depth - 1);
	max  |= max - 1;
	red   = etolf_arg("the red value",   argv[0]) / max;
	green = etolf_arg("the green value", argv[1]) / max;
	blue  = etolf_arg("the blue value",  argv[2]) / max;
	if (!linear) {
		red   = srgb_decode(red);
		green = srgb_decode(green);
		blue  = srgb_decode(blue);
	}

	srgb_to_ciexyz(red, green, blue, &X, &Y, &Z);
	printf("%lf %lf %lf\n", X, Y, Z);

	efshut(stdout, "<stdout>");
	return 0;
}