2 * SDLEMU library - Free sdl related functions library
3 * Copyrigh(c) 1999-2002 sdlemu development crew
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 #include "sdlemu_config.h"
22 #include <stdlib.h> // For atoi()
23 #include <cstring> // For strcmp()
32 token_list(const string &name) : m_name(name), m_value(""), m_token("") {}
33 void add_token_variable(const string &var) { m_token = var; }
34 void add_token_value(const string &value) { m_value = value; }
35 const string &LineName() const { return m_name; }
36 const string &Token() const { return m_token; }
37 const string &Value() const { return m_value; }
44 std::list<token_list> vec;
46 void string_tokenize_variable()
48 list<token_list>::iterator p;
49 const string delim = " ";
50 for(p = vec.begin(); p != vec.end(); p++) {
51 string::size_type lastPos = (*p).LineName().find_first_not_of(delim, 0);
52 string::size_type pos = (*p).LineName().find_first_of(delim, lastPos);
54 if(string::npos != pos && string::npos != lastPos) {
55 string s = (*p).LineName().substr(lastPos, pos - lastPos);
56 (*p).add_token_variable(s);
61 void string_tokenize_value()
63 list<token_list>::iterator p;
64 const string delim = " =\n\t\r"; // "\r" needed for Win32 compatibility...
66 for(p = vec.begin(); p != vec.end(); p++) {
67 string::size_type lastPos = (*p).LineName().find_first_of(delim, 0);
68 string::size_type pos = (*p).LineName().find_first_not_of(delim, lastPos);
70 if(string::npos != pos && string::npos != lastPos) {
71 string s = (*p).LineName().substr(pos);
72 (*p).add_token_value(s);
77 int sdlemu_init_config(const char *filename)
79 FILE *f = fopen(filename, "r");
82 fseek(f, 0, SEEK_END);
84 fseek(f, 0, SEEK_SET);
86 char *s = new char[len];
90 const string delim = "\n\r"; // "\r" needed for Win32 compatibility...
91 string::size_type lastPos = str.find_first_not_of(delim, 0);
92 string::size_type pos = str.find_first_of(delim, lastPos);
94 while (string::npos != pos || string::npos != lastPos) {
95 string string = str.substr(lastPos, pos - lastPos);
99 else if(string[0] == '[')
104 vec.push_back(string);
106 lastPos = str.find_first_not_of(delim, pos);
107 pos = str.find_first_of(delim, lastPos);
109 string_tokenize_variable();
110 string_tokenize_value();
116 const char *sdlemu_getval_string(const char *key_string, const char *default_string)
118 list<token_list>::iterator p;
119 for(p = vec.begin(); p != vec.end(); p++) {
121 if(strcmp((*p).Token().c_str(), key_string) == 0)
122 return (*p).Value().c_str();
124 return default_string;
127 int sdlemu_getval_int(const char *key_string, int default_int)
129 list<token_list>::iterator p;
130 for(p = vec.begin(); p != vec.end(); p++) {
132 if(strcmp((*p).Token().c_str(), key_string) == 0) {
133 const char *ret = (*p).Value().c_str();
134 if(ret) return atoi(ret);
140 int sdlemu_getval_bool(const char *key_string, int default_int)
142 list<token_list>::iterator p;
143 for(p = vec.begin(); p != vec.end(); p++) {
145 if(strcmp((*p).Token().c_str(), key_string) == 0) {
146 const char *ret = (*p).Value().c_str();
147 if(ret) return atoi(ret)>0;