diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/state.c | 117 | 
1 files changed, 117 insertions, 0 deletions
| diff --git a/src/state.c b/src/state.c index cf2a2dd..a3219fa 100644 --- a/src/state.c +++ b/src/state.c @@ -20,10 +20,32 @@  #include <string.h>  #include <stdlib.h>  #include <errno.h> +#include <limits.h>  #include <libgamma.h> +  #define try(...)  do { if (!(__VA_ARGS__)) goto fail; } while (0) +#define t(...)    do { if   (__VA_ARGS__)  goto fail; } while (0) + + + +/** + * The name of the process. + */ +extern char *argv0; + + + +/** + * All sites. + */ +static libgamma_site_state_t *sites = NULL; + +/** + * The number of sites stored in `sites`. + */ +static size_t sites_n = 0; @@ -179,3 +201,98 @@ fail:  	return saved_errno = errno, free(env), free(display), errno = saved_errno, rc;  } + +/** + * Parse a value for the -d option, or select preferred adjustment method. + *  + * @param   display  The argument for the -d option. `NULL` for the preferred adjustment method. + * @return           The adjustment method. -1 if not found. + */ +static int +get_clut_method(const char *display) +{ +	int method; +	const char *env; + +	if (!display) { +		if (!libgamma_list_methods(&method, 1, 0)) { +			fprintf(stderr, "No display was found.\n" +			                "DRM support missing.\n" +			                "Can you even see?\n"); +			return errno = 0, -1; +		} +		return method; +	} +	if (!strcasecmp(display, "none"))  return INT_MAX; +	if (!strcasecmp(display, "drm"))   return LIBGAMMA_METHOD_LINUX_DRM; +	if (!strchr(display, '=')) { +		fprintf(stderr, "Specified display\n" +		                "cannot be recognised.\n" +		                "Try something else.\n"); +		return errno = 0, -1; +	} + +	for (method = 0; method < LIBGAMMA_METHOD_COUNT; method++) { +		env = libgamma_method_default_site_variable(method); +		if (env && (strstr(display, env) == display) && (display[strlen(env)] == '=')) +			return method; +	} + +	fprintf(stderr, "Specified display\n" +	                "cannot be recognised.\n" +	                "Try to recompile.\n"); +	return errno = 0, -1; +} + + +/** + * Initialise the CLUT support. + *  + * @param   settings  The settings. + * @return            0 on success, -1 on error. + */ +int +initialise_clut(const struct settings *settings) +{ +	int method, error = 0, is_none = 0; +	const char *sitename_; +	char *sitename = NULL; +	void *new; +	size_t i; +	int saved_errno; + +	try (sites = calloc(settings->monitors_n + 2, sizeof(*sites))); + +	for (i = 0; i < settings->monitors_n; i++) { +		switch (settings->monitors_arg[i]) { +		case 'd': +			t ((method = get_clut_method(sitename_ = settings->monitors_id[i])) < 0); +			if ((is_none = (method == INT_MAX))) +				break; +			sitename_ = strchr(sitename_, '='); +			if (sitename_)  try ((sitename = strdup(sitename_ + 1))); +			t ((error = libgamma_site_initialise(sites + sites_n, method, sitename))); +			sitename = NULL; +			sites_n++; +			break; + +		case 'm': +			;/* TODO -m */ +			break; + +		case 'e': +			;/* TODO -e */ +			break; +		} +	} + +	new = realloc(sites, (sites_n + 1) * sizeof(*sites)); +	sites = new ? new : sites; + +	return 0; +fail: +	if (error)  libgamma_perror(argv0, error), errno = 0; +	saved_errno = errno, free(sitename), errno = saved_errno; +	return -1; +} + | 
