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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
|
/*
* command line and config file parser
*/
#ifndef __CONFIG_H
#define __CONFIG_H
#define CONF_TYPE_FLAG 0
#define CONF_TYPE_INT 1
#define CONF_TYPE_FLOAT 2
#define CONF_TYPE_STRING 3
#define CONF_TYPE_FUNC 4
#define CONF_TYPE_FUNC_PARAM 5
#define CONF_TYPE_PRINT 6
#define CONF_TYPE_FUNC_FULL 7
#define CONF_TYPE_SUBCONFIG 8
#define ERR_NOT_AN_OPTION -1
#define ERR_MISSING_PARAM -2
#define ERR_OUT_OF_RANGE -3
#define ERR_FUNC_ERR -4
#define CONF_MIN (1<<0)
#define CONF_MAX (1<<1)
#define CONF_RANGE (CONF_MIN|CONF_MAX)
#define CONF_NOCFG (1<<2)
#define CONF_NOCMD (1<<3)
#define CONF_GLOBAL (1<<4)
#define CONF_NOSAVE (1<<5)
typedef struct config config_t;
typedef struct m_config m_config_t;
typedef struct config_save config_save_t;
#include "playtree.h"
typedef void (*cfg_default_func_t)(config_t *, char*);
struct config {
char *name;
void *p;
unsigned int type;
unsigned int flags;
float min,max;
/* Use this field when your need to do something before a new value is
assigned to your option */
cfg_default_func_t default_func;
};
struct m_config {
config_t** opt_list;
config_save_t** config_stack;
int cs_level;
int parser_mode; /* COMMAND_LINE or CONFIG_FILE */
int flags;
char* sub_conf; // When we save a subconfig
play_tree_t* pt; // play tree we use for playlist option, etc
play_tree_t* last_entry; // last added entry
play_tree_t* last_parent; // if last_entry is NULL we must create child of this
int recursion_depth;
};
struct config_save {
config_t* opt;
union {
int as_int;
float as_float;
void* as_pointer;
} param;
char* opt_name;
};
typedef int (*cfg_func_arg_param_t)(config_t *, char *, char *);
typedef int (*cfg_func_param_t)(config_t *, char *);
typedef int (*cfg_func_t)(config_t *);
/* parse_config_file returns:
* -1 on error (can't malloc, invalid option...)
* 0 if can't open configfile
* 1 on success
*/
int m_config_parse_config_file(m_config_t *config, char *conffile);
/* parse_command_line returns:
* -1 on error (invalid option...)
* 1 otherwise
*/
int m_config_parse_command_line(m_config_t* config, int argc, char **argv, char **envp);
m_config_t* m_config_new(play_tree_t* pt);
void m_config_free(m_config_t* config);
void m_config_push(m_config_t* config);
/*
* Return 0 on error 1 on success
*/
int m_config_pop(m_config_t* config);
/*
* Return 0 on error 1 on success
*/
int m_config_register_options(m_config_t *config,config_t *args);
/*
* For all the following function when it's a subconfig option
* you must give an option name like 'tv:channel' and not just
* 'channel'
*/
/*
* Return 1 on sucess 0 on failure
*/
int m_config_set_option(m_config_t *config,char *opt, char *param);
/*
* Get the config struct defining an option
* Return NULL on error
*/
config_t* m_config_get_option(m_config_t *config, char* arg);
/*
* Get the p field of the struct defining an option
* Return NULL on error
*/
void* m_config_get_option_ptr(m_config_t *config, char* arg);
/*
* Tell is an option is alredy set or not
* Return -1 one error (requested option arg exist)
* Otherwise 0 or 1
*/
int m_config_is_option_set(m_config_t *config, char* arg);
/*
* Return 0 on error 1 on success
*/
int m_config_switch_flag(m_config_t *config, char* opt);
/*
* Return 0 on error 1 on success
*/
int m_config_set_flag(m_config_t *config, char* opt, int max);
/*
* Return the value of a flag (O or 1) and -1 on error
*/
int m_config_get_flag(m_config_t *config, char* opt);
/*
* Set the value of an int option
* Return 0 on error 1 on success
*/
int
m_config_set_int(m_config_t *config, char* arg,int val);
/*
* Get the value of an int option
* Return the option value or -1 on error
* If err_ret is not NULL it's set to 1 on error
*/
int
m_config_get_int (m_config_t *config, char* arg,int* err_ret);
/*
* Set the value of a float option
* Return 0 on error 1 on success
*/
int
m_config_set_float(m_config_t *config, char* arg,float val);
/*
* Get the value of a float option
* Return the option value or -1 on error
* If err_ret is not NULL it's set to 1 on error
*/
float
m_config_get_float (m_config_t *config, char* arg,int* err_ret);
#endif /* __CONFIG_H */
|