diff options
| author | Magnus Auvinen <magnus.auvinen@gmail.com> | 2007-08-22 07:52:33 +0000 |
|---|---|---|
| committer | Magnus Auvinen <magnus.auvinen@gmail.com> | 2007-08-22 07:52:33 +0000 |
| commit | 8b3c16e6152a527f9aec1a88a9eed74119de7000 (patch) | |
| tree | f0bde5cea15e696e42cade06a3b12ff6b13acc57 /src/engine/config.cpp | |
| parent | 9899666a7ce6679a3b9667ab09f615f4d0769c16 (diff) | |
| download | zcatch-8b3c16e6152a527f9aec1a88a9eed74119de7000.tar.gz zcatch-8b3c16e6152a527f9aec1a88a9eed74119de7000.zip | |
major engine cleanup. dependency on baselib removed. engine is now C code (not ansi tho). some other cruft removed aswell
Diffstat (limited to 'src/engine/config.cpp')
| -rw-r--r-- | src/engine/config.cpp | 148 |
1 files changed, 0 insertions, 148 deletions
diff --git a/src/engine/config.cpp b/src/engine/config.cpp deleted file mode 100644 index 508f6368..00000000 --- a/src/engine/config.cpp +++ /dev/null @@ -1,148 +0,0 @@ -#include <baselib/system.h> -#include <baselib/stream/file.h> -#include <baselib/stream/line.h> - -#include <cstring> -#include <cstdio> -#include <cstdlib> - -#include "config.h" - -configuration config; - -using namespace baselib; - -void config_reset() -{ - #define MACRO_CONFIG_INT(name,def,min,max) config.name = def; - #define MACRO_CONFIG_STR(name,len,def) strncpy(config.name, def, len); - - #include "config_variables.h" - - #undef MACRO_CONFIG_INT - #undef MACRO_CONFIG_STR -} - -void strip_spaces(char **p) -{ - char *&s = *p; - - while (*s == ' ') - ++s; - - char *end = s + strlen(s); - while (end > s && *(end - 1) == ' ') - *--end = 0; -} - -void config_set(const char *line) -{ - const char *c = strchr(line, '='); - if (c) - { - char var[256]; - char val[256]; - - strcpy(val, c+1); - - mem_copy(var, line, c - line); - var[c - line] = 0; - - char *var_str = var; - char *val_str = val; - - strip_spaces(&var_str); - strip_spaces(&val_str); - - #define MACRO_CONFIG_INT(name,def,min,max) { if (strcmp(#name, var_str) == 0) config_set_ ## name (&config, atoi(val_str)); } - #define MACRO_CONFIG_STR(name,len,def) { if (strcmp(#name, var_str) == 0) { config_set_ ## name (&config, val_str); } } - - #include "config_variables.h" - - #undef MACRO_CONFIG_INT - #undef MACRO_CONFIG_STR - } -} - -void config_load(const char *filename) -{ - char full_path[1024]; - if (filename[0] == '~') - { - char *home = getenv("HOME"); - if (home) - { - sprintf(full_path, "%s%s", home, filename+1); - filename = full_path; - } - } - - - dbg_msg("config/load", "loading %s", filename); - - file_stream file; - - if (file.open_r(filename)) - { - char *line; - line_stream lstream(&file); - - while ((line = lstream.get_line())) - config_set(line); - - file.close(); - } -} - -void config_save(const char *filename) -{ - char full_path[1024]; - if (filename[0] == '~') - { - char *home = getenv("HOME"); - if (home) - { - sprintf(full_path, "%s%s", home, filename+1); - filename = full_path; - } - } - - - dbg_msg("config/save", "saving config to %s", filename); - - file_stream file; - - if (file.open_w(filename)) - { -#if defined(CONF_FAMILY_WINDOWS) - const char newline[] = "\r\n"; -#else - const char newline[] = "\n"; -#endif - const int newline_len = sizeof(newline)-1; - - #define MACRO_CONFIG_INT(name,def,min,max) { char str[256]; sprintf(str, "%s=%i", #name, config.name); file.write(str, strlen(str)); file.write(newline, newline_len); } - #define MACRO_CONFIG_STR(name,len,def) { file.write(#name, strlen(#name)); file.write("=", 1); file.write(config.name, strlen(config.name)); file.write(newline, newline_len); } - - #include "config_variables.h" - - #undef MACRO_CONFIG_INT - #undef MACRO_CONFIG_STR - - file.close(); - } - else - dbg_msg("config/save", "couldn't open %s for writing. :(", filename); -} - -#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; } -#include "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 (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) { strncpy(c->name, str, len-1); c->name[sizeof(c->name)-1] = 0; } -#include "config_variables.h" -#undef MACRO_CONFIG_INT -#undef MACRO_CONFIG_STR |