about summary refs log tree commit diff
path: root/src/engine/e_config.c
diff options
context:
space:
mode:
authorMagnus Auvinen <magnus.auvinen@gmail.com>2008-10-21 18:05:06 +0000
committerMagnus Auvinen <magnus.auvinen@gmail.com>2008-10-21 18:05:06 +0000
commit9acb3e5e713d1ab6b2312aa4cdc7946f85f875d0 (patch)
tree93189cbe6fc70c2ca1b5e374a2114156d55e371a /src/engine/e_config.c
parent142b5ad5143ddcfc9d7fee2563bee753a968f011 (diff)
downloadzcatch-9acb3e5e713d1ab6b2312aa4cdc7946f85f875d0.tar.gz
zcatch-9acb3e5e713d1ab6b2312aa4cdc7946f85f875d0.zip
continued on ban support. cleaned up settings a bit. reworked the datadir autodetection. introduced engine_openfile, engine_getpath and engine_listdir. never use fs_listdir or io_open directly
Diffstat (limited to 'src/engine/e_config.c')
-rw-r--r--src/engine/e_config.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/src/engine/e_config.c b/src/engine/e_config.c
index 1746b682..67a4c81a 100644
--- a/src/engine/e_config.c
+++ b/src/engine/e_config.c
@@ -14,8 +14,8 @@ CONFIGURATION config;
 
 void config_reset()
 {
-    #define MACRO_CONFIG_INT(name,def,min,max) config.name = def;
-    #define MACRO_CONFIG_STR(name,len,def) str_copy(config.name, def, len);
+    #define MACRO_CONFIG_INT(name,def,min,max,flags,desc) config.name = def;
+    #define MACRO_CONFIG_STR(name,len,def,flags,desc) str_copy(config.name, def, len);
  
     #include "e_config_variables.h" 
  
@@ -27,8 +27,8 @@ void config_save()
 {
 	char linebuf[1024*2];
 	
-	#define MACRO_CONFIG_INT(name,def,min,max) { str_format(linebuf, sizeof(linebuf), "%s %i", #name, config.name); engine_config_write_line(linebuf); }
-	#define MACRO_CONFIG_STR(name,len,def) { str_format(linebuf, sizeof(linebuf), "%s %s", #name, config.name); engine_config_write_line(linebuf); }
+	#define MACRO_CONFIG_INT(name,def,min,max,flags,desc) if((flags)&CFGFLAG_SAVE){ str_format(linebuf, sizeof(linebuf), "%s %i", #name, config.name); engine_config_write_line(linebuf); }
+	#define MACRO_CONFIG_STR(name,len,def,flags,desc) if((flags)&CFGFLAG_SAVE){ str_format(linebuf, sizeof(linebuf), "%s %s", #name, config.name); engine_config_write_line(linebuf); }
 
 	#include "e_config_variables.h" 
 
@@ -36,14 +36,14 @@ void config_save()
 	#undef MACRO_CONFIG_STR 
 }
 
-#define MACRO_CONFIG_INT(name,def,min,max) int config_get_ ## name (CONFIGURATION *c) { return c->name; }
-#define MACRO_CONFIG_STR(name,len,def) const char *config_get_ ## name (CONFIGURATION *c) { return c->name; }
+#define MACRO_CONFIG_INT(name,def,min,max,flags,desc) int config_get_ ## name (CONFIGURATION *c) { return c->name; }
+#define MACRO_CONFIG_STR(name,len,def,flags,desc) const char *config_get_ ## name (CONFIGURATION *c) { return c->name; }
 #include "e_config_variables.h"
 #undef MACRO_CONFIG_INT
 #undef MACRO_CONFIG_STR
 
-#define MACRO_CONFIG_INT(name,def,min,max) void config_set_ ## name (CONFIGURATION *c, int val) { if(min != max) { if (val < min) val = min; if (max != 0 && val > max) val = max; } c->name = val; }
-#define MACRO_CONFIG_STR(name,len,def) void config_set_ ## name (CONFIGURATION *c, const char *str) { str_copy(c->name, str, len-1); c->name[sizeof(c->name)-1] = 0; }
+#define MACRO_CONFIG_INT(name,def,min,max,flags,desc) void config_set_ ## name (CONFIGURATION *c, int val) { if(min != max) { if (val < min) val = min; if (max != 0 && val > max) val = max; } c->name = val; }
+#define MACRO_CONFIG_STR(name,len,def,flags,desc) void config_set_ ## name (CONFIGURATION *c, const char *str) { str_copy(c->name, str, len-1); c->name[sizeof(c->name)-1] = 0; }
 #include "e_config_variables.h"
 #undef MACRO_CONFIG_INT
 #undef MACRO_CONFIG_STR