More fixes for new config system

This commit is contained in:
Ron Pedde 2006-02-21 03:08:14 +00:00
parent 87f84ded09
commit 1d0a3c4149
4 changed files with 120 additions and 32 deletions

View File

@ -26,10 +26,11 @@
* Config file reading and writing
*/
#ifdef HAVE_CONFIG_H
#ifdef HAVE_conf_H
# include "config.h"
#endif
#include <pthread.h>
#include <stdio.h>
#include <string.h>
@ -40,9 +41,10 @@
/** Globals */
static int ecode;
static LL_HANDLE config_main=NULL;
static LL_HANDLE conf_main=NULL;
static pthread_mutex_t conf_mutex = PTHREAD_MUTEX_INITIALIZER;
#define CONFIG_LINEBUFFER 128
#define conf_LINEBUFFER 128
#define CONF_T_INT 0
#define CONF_T_STRING 1
@ -51,7 +53,8 @@ static LL_HANDLE config_main=NULL;
static int _conf_verify(LL_HANDLE pll);
static LL_ITEM *_conf_fetch_item(LL_HANDLE pll, char *section, char *term);
static int _conf_exists(LL_HANDLE pll, char *section, char *term);
static void _conf_lock(void);
static void _conf_unlock(void);
typedef struct _CONF_ELEMENTS {
@ -90,6 +93,30 @@ static CONF_ELEMENTS conf_elements[] = {
{ 0, 0, CONF_T_INT, NULL, NULL }
};
/**
* lock the conf mutex
*/
void _conf_lock() {
int err;
if((err=pthread_mutex_lock(&conf_mutex))) {
DPRINTF(E_FATAL,L_CONF,"Cannot lock configuration mutex: %s\n",
strerror(err));
}
}
/**
* unlock the conf mutex
*/
void _conf_unlock() {
int err;
if((err = pthread_mutex_unlock(&conf_mutex))) {
DPRINTF(E_FATAL,L_CONF,"Cannot unlock configuration mutex %s\n",
strerror(err));
}
}
/**
* fetch item based on section/term basis, rather than just a single
* level deep, like ll_fetch_item does
@ -149,12 +176,13 @@ int _conf_verify(LL_HANDLE pll) {
pce = &conf_elements[0];
while(pce->section) {
if(pce->required) {
if(!_conf_exists(pll,pce->section, pce->term))
if(!_conf_exists(pll,pce->section, pce->term)) {
DPRINTF(E_LOG,L_CONF,"Missing configuration entry "
" %s/%s. Please review the sample config\n",
pce->section, pce->term);
is_valid=FALSE;
}
}
if(pce->deprecated) {
DPRINTF(E_LOG,L_CONF,"Config entry %s/%s is deprecated. Please "
"review the sample config\n",
@ -176,11 +204,11 @@ int _conf_verify(LL_HANDLE pll) {
* @param file file to read
* @returns TRUE if successful, FALSE otherwise
*/
int config_read(char *file) {
int conf_read(char *file) {
FILE *fin;
int err;
LL_HANDLE pllnew, plltemp, pllcurrent;
char linebuffer[CONFIG_LINEBUFFER+1];
char linebuffer[conf_LINEBUFFER+1];
char *comment, *term, *value, *delim;
int compat_mode=1;
int line=0;
@ -201,9 +229,9 @@ int config_read(char *file) {
/* got what will be the root of the config tree, now start walking through
* the input file, populating the tree
*/
while(fgets(linebuffer,CONFIG_LINEBUFFER,fin)) {
while(fgets(linebuffer,conf_LINEBUFFER,fin)) {
line++;
linebuffer[CONFIG_LINEBUFFER] = '\0';
linebuffer[conf_LINEBUFFER] = '\0';
comment=strchr(linebuffer,'#');
if(comment) {
@ -278,10 +306,18 @@ int config_read(char *file) {
fclose(fin);
/* Sanity check */
_conf_verify(pllnew);
ll_dump(pllnew);
if(_conf_verify(pllnew)) {
DPRINTF(E_INF,L_CONF,"Loading new config file.\n");
_conf_lock();
if(conf_main) {
ll_destroy(conf_main);
}
conf_main = pllnew;
_conf_unlock();
} else {
ll_destroy(pllnew);
DPRINTF(E_LOG,L_CONF,"Could not validate config file. Ignoring\n");
}
return CONF_E_SUCCESS;
}
@ -289,9 +325,9 @@ int config_read(char *file) {
/**
* do final config file shutdown
*/
int config_close(void) {
if(config_main)
ll_destroy(config_main);
int conf_close(void) {
if(conf_main)
ll_destroy(conf_main);
return CONF_E_SUCCESS;
}
@ -302,11 +338,60 @@ int config_close(void) {
*
* @param section section name to search in
* @param key key to search for
* @param default default value to return if key not found
* @returns value as integer if found, default value otherwise
* @param dflt default value to return if key not found
* @returns value as integer if found, dflt value otherwise
*/
int config_get_int(char *section, char *key, int default) {
int conf_get_int(char *section, char *key, int dflt) {
LL_ITEM *pitem;
int retval;
_conf_lock();
pitem = _conf_fetch_item(conf_main,section,key);
if((!pitem) || (pitem->type != LL_TYPE_STRING)) {
retval = dflt;
} else {
retval = atoi(pitem->value.as_string);
}
_conf_unlock();
return retval;
}
/**
* read a value from the CURRENT config tree as a string
*
* @param section section name to search in
* @param key key to search for
* @param dflt default value to return if key not found
* @param out buffer to put resulting string in
* @param size pointer to size of buffer
* @returns CONF_E_SUCCESS with out filled on success,
* or CONF_E_OVERFLOW, with size set to required buffer size
*/
int conf_get_string(char *section, char *key, char *dflt, char *out, int *size) {
LL_ITEM *pitem;
char *result;
int len;
_conf_lock();
pitem = _conf_fetch_item(conf_main,section,key);
if((!pitem) || (pitem->type != LL_TYPE_STRING)) {
result = dflt;
} else {
result = pitem->value.as_string;
}
len = strlen(result) + 1;
if(len <= *size) {
*size = len;
strcpy(out,result);
} else {
_conf_unlock();
*size = len;
return CONF_E_OVERFLOW;
}
_conf_unlock();
return CONF_E_SUCCESS;
}

View File

@ -27,12 +27,14 @@
#define CONF_E_UNKNOWN 2
#define CONF_E_BADHEADER 3
#define CONF_E_PARSE 4
#define CONF_E_OVERFLOW 5 /** <Buffer passed too small */
extern int config_read(char *file);
extern int config_close(void);
extern int config_get_int(char *section, char *key, int default);
extern int config_get_string(char *section, char *key, char *default,
char *out, int size);
extern int conf_read(char *file);
extern int conf_close(void);
extern int conf_get_int(char *section, char *key, int dflt);
extern int conf_get_string(char *section, char *key, char *dflt,
char *out, int *size);
#endif /* _CONFIG_H_ */

View File

@ -14,10 +14,10 @@ int main(int argc, char *argv[]) {
printf("Reading %s\n",argv[1]);
if((err=config_read(argv[1])) != CONF_E_SUCCESS) {
if((err=conf_read(argv[1])) != CONF_E_SUCCESS) {
printf("Error reading config: %d\n",err);
} else {
printf("Read config!\n");
}
config_close();
conf_close();
}

View File

@ -25,6 +25,7 @@
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "ll.h"