X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=src%2Fconf.h;h=8bc9d6b345dd995e0fe6f01bb0548f666fbaf5a3;hb=158cbe99f972a1613b7d4d95abfe5fe48e019e67;hp=b4064cd11716b378e7f510de888acfab2cbac7bc;hpb=eefa28059ab989c915a7d95fb4ae728abd7ce713;p=meshlink diff --git a/src/conf.h b/src/conf.h index b4064cd1..8bc9d6b3 100644 --- a/src/conf.h +++ b/src/conf.h @@ -1,7 +1,6 @@ /* conf.h -- header for conf.c - Copyright (C) 1998-2003 Ivo Timmermans - 2000-2003 Guus Sliepen + Copyright (C) 2014 Guus Sliepen This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,17 +12,16 @@ 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 this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - - $Id: conf.h,v 1.6.4.40 2003/07/22 20:55:19 guus Exp $ + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef __TINC_CONF_H__ #define __TINC_CONF_H__ -#include "avl_tree.h" +#include "splay_tree.h" +#include "list.h" typedef struct config_t { char *variable; @@ -32,32 +30,30 @@ typedef struct config_t { int line; } config_t; -#include "subnet.h" - -extern avl_tree_t *config_tree; +extern splay_tree_t *config_tree; +extern int pinginterval; extern int pingtimeout; extern int maxtimeout; extern bool bypass_security; -extern char *confbase; -extern char *netname; -extern void init_configuration(avl_tree_t **); -extern void exit_configuration(avl_tree_t **); -extern config_t *new_config(void) __attribute__ ((malloc)); +extern void init_configuration(splay_tree_t **); +extern void exit_configuration(splay_tree_t **); +extern config_t *new_config(void) __attribute__ ((__malloc__)); extern void free_config(config_t *); -extern void config_add(avl_tree_t *, config_t *); -extern config_t *lookup_config(avl_tree_t *, char *); -extern config_t *lookup_config_next(avl_tree_t *, config_t *); -extern bool get_config_bool(config_t *, bool *); -extern bool get_config_int(config_t *, int *); -extern bool get_config_string(config_t *, char **); -extern bool get_config_address(config_t *, struct addrinfo **); -extern bool get_config_subnet(config_t *, struct subnet_t **); - -extern int read_config_file(avl_tree_t *, const char *); +extern void config_add(splay_tree_t *, config_t *); +extern config_t *lookup_config(splay_tree_t *, char *); +extern config_t *lookup_config_next(splay_tree_t *, const config_t *); +extern bool get_config_bool(const config_t *, bool *); +extern bool get_config_int(const config_t *, int *); +extern bool get_config_string(const config_t *, char **); +extern bool get_config_address(const config_t *, struct addrinfo **); + +extern config_t *parse_config_line(char *, const char *, int); +extern bool read_config_file(splay_tree_t *, const char *); +extern void read_config_options(splay_tree_t *, const char *); extern bool read_server_config(void); -extern FILE *ask_and_safe_open(const char *, const char *, bool, const char *); -extern bool is_safe_path(const char *); +extern bool read_host_config(splay_tree_t *, const char *); +extern bool append_config_file(const char *, const char *, const char *); -#endif /* __TINC_CONF_H__ */ +#endif /* __TINC_CONF_H__ */