From 8b3c16e6152a527f9aec1a88a9eed74119de7000 Mon Sep 17 00:00:00 2001 From: Magnus Auvinen Date: Wed, 22 Aug 2007 07:52:33 +0000 Subject: major engine cleanup. dependency on baselib removed. engine is now C code (not ansi tho). some other cruft removed aswell --- src/engine/config.cpp | 148 -------------------------------------------------- 1 file changed, 148 deletions(-) delete mode 100644 src/engine/config.cpp (limited to 'src/engine/config.cpp') 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 -#include -#include - -#include -#include -#include - -#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 -- cgit 1.4.1