5 #include <ctu_config_api.h>
28 #define CFG_TYPE(id, name) id,
39 #define CFG_ARG(id, name, prefix) id,
54 #define CT_ARG_SHORT(name) { .style = eArgShort, .arg = (name) }
55 #define CT_ARG_LONG(name) { .style = eArgLong, .arg = (name) }
56 #define CT_ARG_DOS(name) { .style = eArgDOS, .arg = (name) }
57 #define CT_ARGS(it) { .args = (it), .count = sizeof(it) / sizeof(cfg_arg_t) }
#define RET_NOTNULL
annotate the return value as not being null
#define CT_PUREFN
mark a function as pure, always returns the same value for the same arguments
#define STA_FIELD_STRING
annotate a field as being a null terminated string
#define CT_NODISCARD
mark a function as returning a value that must be used
#define IN_NOTNULL
annotate a parameter as not being null
#define IN_DOMAIN(cmp, it)
annotate a parameter as being bounded by the expression of cmp and it
#define CT_CONSTFN
mark a function as const, has no side effects and always returns the same value for the same argument...
CT_CONFIG_API cfg_field_t * config_enum(cfg_group_t *group, const cfg_info_t *info, cfg_enum_t cfg)
add a new choice field to a configuration group
CT_CONFIG_API cfg_field_t * config_int(cfg_group_t *group, const cfg_info_t *info, cfg_int_t cfg)
add a new integer field to a configuration group
CT_CONFIG_API cfg_field_t * config_string(cfg_group_t *group, const cfg_info_t *info, const char *initial)
add a new string field to a configuration group
CT_CONFIG_API cfg_field_t * config_vector(cfg_group_t *group, const cfg_info_t *info, vector_t *initial)
add a new vector field to a configuration group
CT_CONFIG_API cfg_group_t * config_group(cfg_group_t *group, const cfg_info_t *info)
add a new configuration group to a configuration group
CT_CONFIG_API cfg_field_t * config_bool(cfg_group_t *group, const cfg_info_t *info, bool initial)
add a new yes/no field to a configuration group
CT_CONFIG_API cfg_field_t * config_flags(cfg_group_t *group, const cfg_info_t *info, cfg_enum_t cfg)
add a new flags field to a configuration group
CT_PUREFN CT_CONFIG_API const char * cfg_string_value(const cfg_field_t *field)
get the current string value of a configuration field
CT_PUREFN CT_CONFIG_API vector_t * cfg_vector_value(const cfg_field_t *field)
get the current vector value of a configuration field
CT_PUREFN CT_CONFIG_API size_t cfg_flags_value(const cfg_field_t *field)
get the current flags value of a configuration field
CT_PUREFN CT_CONFIG_API bool cfg_bool_value(const cfg_field_t *field)
get the current boolean value of a configuration field
CT_PUREFN CT_CONFIG_API int cfg_int_value(const cfg_field_t *field)
get the current integer value of a configuration field
CT_PUREFN CT_CONFIG_API size_t cfg_enum_value(const cfg_field_t *field)
get the current enum value of a configuration field
CT_PUREFN CT_CONFIG_API const vector_t * cfg_vector_info(const cfg_field_t *field)
get the information about a vector field
CT_CONSTFN CT_CONFIG_API const char * cfg_arg_string(arg_style_t style)
get the name of an argument style
CT_CONSTFN CT_CONFIG_API const char * cfg_arg_prefix(arg_style_t style)
get the prefix for an argument style
CT_PUREFN CT_CONFIG_API bool cfg_bool_info(const cfg_field_t *field)
get the information about a yes/no field
CT_PUREFN CT_CONFIG_API const cfg_info_t * cfg_group_info(const cfg_group_t *config)
get the information about a configuration group
CT_CONSTFN CT_CONFIG_API const char * cfg_type_string(cfg_type_t type)
get the name of a configuration type
CT_PUREFN CT_CONFIG_API typevec_t * cfg_get_groups(const cfg_group_t *config)
get all subgroups in a configuration group
CT_PUREFN CT_CONFIG_API const cfg_int_t * cfg_int_info(const cfg_field_t *field)
get the information about an integer field
CT_PUREFN CT_CONFIG_API const cfg_enum_t * cfg_enum_info(const cfg_field_t *field)
get the information about a choice field
CT_PUREFN CT_CONFIG_API const cfg_enum_t * cfg_flags_info(const cfg_field_t *field)
get the information about a flags field
CT_PUREFN CT_CONFIG_API const char * cfg_string_info(const cfg_field_t *field)
get the information about a string field
CT_PUREFN CT_CONFIG_API vector_t * cfg_get_fields(const cfg_group_t *config)
get all fields in a configuration group
CT_PUREFN CT_CONFIG_API cfg_type_t cfg_get_type(const cfg_field_t *field)
get the type of a configuration field
CT_PUREFN CT_CONFIG_API const cfg_info_t * cfg_get_info(const cfg_field_t *field)
get the information about a configuration field
CT_CONFIG_API void cfg_vector_push(cfg_field_t *field, char *value)
push a new value onto an array field
CT_NODISCARD CT_CONFIG_API bool cfg_set_int(cfg_field_t *field, int value)
set the current value of an int field
CT_CONFIG_API void cfg_set_enum_value(cfg_field_t *field, size_t value)
set the current value of an enum field set the value via an integer value
CT_NODISCARD CT_CONFIG_API bool cfg_set_flag(cfg_field_t *field, const char *choice, bool set)
set the current value of a flags field set the value via a string name
CT_CONFIG_API void cfg_set_string(cfg_field_t *field, char *value)
set the current value of a string field
CT_CONFIG_API bool cfg_set_enum(cfg_field_t *field, const char *choice)
set the current value of an enum field set the value via a string name
CT_CONFIG_API void cfg_set_bool(cfg_field_t *field, bool value)
set the current value of a bool field
CT_CONFIG_API void cfg_set_flag_value(cfg_field_t *field, size_t value)
set the current value of a flags field set the value via an integer value
cfg_type_t
the type of a configuration field
CT_CONFIG_API cfg_group_t * config_root(const cfg_info_t *info, arena_t *arena)
create a new configuration group
a choice in a set of options
STA_FIELD_STRING const char * text
the name of this choice
size_t value
the value of this choice
a choice from a set of options
STA_FIELD_SIZE(count) const cfg_choice_t *options
the choices in this set
size_t initial
the initial choice this must match the value of one of the choices
size_t count
the number of choices in this set
information about a configuration field
STA_FIELD_STRING const char * brief
a brief description of this field
cfg_arg_array_t args
the spellings to use for this field
STA_FIELD_STRING const char * name
the name of this field
STA_FIELD_RANGE(min, INT_MAX) int max
maximum value
STA_FIELD_RANGE(min, max) int initial
default value
STA_FIELD_RANGE(INT_MIN, max) int min
minimum value
A vector with a fixed type size.
a generic vector of pointers