153 lines
4.5 KiB
C
153 lines
4.5 KiB
C
|
/* redshift.h -- Main program header
|
||
|
This file is part of Redshift.
|
||
|
|
||
|
Redshift 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.
|
||
|
|
||
|
Redshift 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 Redshift. If not, see <http://www.gnu.org/licenses/>.
|
||
|
|
||
|
Copyright (c) 2013-2017 Jon Lund Steffensen <jonlst@gmail.com>
|
||
|
*/
|
||
|
|
||
|
#ifndef REDSHIFT_REDSHIFT_H
|
||
|
#define REDSHIFT_REDSHIFT_H
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
/* The color temperature when no adjustment is applied. */
|
||
|
#define NEUTRAL_TEMP 6500
|
||
|
|
||
|
|
||
|
/* Location */
|
||
|
typedef struct {
|
||
|
float lat;
|
||
|
float lon;
|
||
|
} location_t;
|
||
|
|
||
|
/* Periods of day. */
|
||
|
typedef enum {
|
||
|
PERIOD_NONE = 0,
|
||
|
PERIOD_DAYTIME,
|
||
|
PERIOD_NIGHT,
|
||
|
PERIOD_TRANSITION
|
||
|
} period_t;
|
||
|
|
||
|
/* Color setting */
|
||
|
typedef struct {
|
||
|
int temperature;
|
||
|
float gamma[3];
|
||
|
float brightness;
|
||
|
} color_setting_t;
|
||
|
|
||
|
/* Program modes. */
|
||
|
typedef enum {
|
||
|
PROGRAM_MODE_CONTINUAL,
|
||
|
PROGRAM_MODE_ONE_SHOT,
|
||
|
PROGRAM_MODE_PRINT,
|
||
|
PROGRAM_MODE_RESET,
|
||
|
PROGRAM_MODE_MANUAL
|
||
|
} program_mode_t;
|
||
|
|
||
|
/* Time range.
|
||
|
Fields are offsets from midnight in seconds. */
|
||
|
typedef struct {
|
||
|
int start;
|
||
|
int end;
|
||
|
} time_range_t;
|
||
|
|
||
|
/* Transition scheme.
|
||
|
The solar elevations at which the transition begins/ends,
|
||
|
and the association color settings. */
|
||
|
typedef struct {
|
||
|
double high;
|
||
|
double low;
|
||
|
int use_time; /* When enabled, ignore elevation and use time ranges. */
|
||
|
time_range_t dawn;
|
||
|
time_range_t dusk;
|
||
|
color_setting_t day;
|
||
|
color_setting_t night;
|
||
|
} transition_scheme_t;
|
||
|
|
||
|
|
||
|
/* Gamma adjustment method */
|
||
|
typedef struct gamma_state gamma_state_t;
|
||
|
|
||
|
typedef int gamma_method_init_func(gamma_state_t **state);
|
||
|
typedef int gamma_method_start_func(gamma_state_t *state);
|
||
|
typedef void gamma_method_free_func(gamma_state_t *state);
|
||
|
typedef void gamma_method_print_help_func(FILE *f);
|
||
|
typedef int gamma_method_set_option_func(gamma_state_t *state, const char *key,
|
||
|
const char *value);
|
||
|
typedef void gamma_method_restore_func(gamma_state_t *state);
|
||
|
typedef int gamma_method_set_temperature_func(
|
||
|
gamma_state_t *state, const color_setting_t *setting, int preserve);
|
||
|
|
||
|
typedef struct {
|
||
|
char *name;
|
||
|
|
||
|
/* If true, this method will be tried if none is explicitly chosen. */
|
||
|
int autostart;
|
||
|
|
||
|
/* Initialize state. Options can be set between init and start. */
|
||
|
gamma_method_init_func *init;
|
||
|
/* Allocate storage and make connections that depend on options. */
|
||
|
gamma_method_start_func *start;
|
||
|
/* Free all allocated storage and close connections. */
|
||
|
gamma_method_free_func *free;
|
||
|
|
||
|
/* Print help on options for this adjustment method. */
|
||
|
gamma_method_print_help_func *print_help;
|
||
|
/* Set an option key, value-pair */
|
||
|
gamma_method_set_option_func *set_option;
|
||
|
|
||
|
/* Restore the adjustment to the state before start was called. */
|
||
|
gamma_method_restore_func *restore;
|
||
|
/* Set a specific color temperature. */
|
||
|
gamma_method_set_temperature_func *set_temperature;
|
||
|
} gamma_method_t;
|
||
|
|
||
|
|
||
|
/* Location provider */
|
||
|
typedef struct location_state location_state_t;
|
||
|
|
||
|
typedef int location_provider_init_func(location_state_t **state);
|
||
|
typedef int location_provider_start_func(location_state_t *state);
|
||
|
typedef void location_provider_free_func(location_state_t *state);
|
||
|
typedef void location_provider_print_help_func(FILE *f);
|
||
|
typedef int location_provider_set_option_func(
|
||
|
location_state_t *state, const char *key, const char *value);
|
||
|
typedef int location_provider_get_fd_func(location_state_t *state);
|
||
|
typedef int location_provider_handle_func(
|
||
|
location_state_t *state, location_t *location, int *available);
|
||
|
|
||
|
typedef struct {
|
||
|
char *name;
|
||
|
|
||
|
/* Initialize state. Options can be set between init and start. */
|
||
|
location_provider_init_func *init;
|
||
|
/* Allocate storage and make connections that depend on options. */
|
||
|
location_provider_start_func *start;
|
||
|
/* Free all allocated storage and close connections. */
|
||
|
location_provider_free_func *free;
|
||
|
|
||
|
/* Print help on options for this location provider. */
|
||
|
location_provider_print_help_func *print_help;
|
||
|
/* Set an option key, value-pair. */
|
||
|
location_provider_set_option_func *set_option;
|
||
|
|
||
|
/* Listen and handle location updates. */
|
||
|
location_provider_get_fd_func *get_fd;
|
||
|
location_provider_handle_func *handle;
|
||
|
} location_provider_t;
|
||
|
|
||
|
|
||
|
#endif /* ! REDSHIFT_REDSHIFT_H */
|