diff options
author | Vicent Marti | 2008-06-12 23:13:58 +0000 |
---|---|---|
committer | Vicent Marti | 2008-06-12 23:13:58 +0000 |
commit | ace171e22f98f9f9195447893b12fcf4ea79561c (patch) | |
tree | 436f6321dfdb43940c1ffc489745c035841ae87c /gui/ThemeParser.cpp | |
parent | 7a9a74691fef580467d93c713c03be613a6d289b (diff) | |
download | scummvm-rg350-ace171e22f98f9f9195447893b12fcf4ea79561c.tar.gz scummvm-rg350-ace171e22f98f9f9195447893b12fcf4ea79561c.tar.bz2 scummvm-rg350-ace171e22f98f9f9195447893b12fcf4ea79561c.zip |
Parser update.
svn-id: r32686
Diffstat (limited to 'gui/ThemeParser.cpp')
-rw-r--r-- | gui/ThemeParser.cpp | 119 |
1 files changed, 106 insertions, 13 deletions
diff --git a/gui/ThemeParser.cpp b/gui/ThemeParser.cpp index 26745ac5a6..73086e942c 100644 --- a/gui/ThemeParser.cpp +++ b/gui/ThemeParser.cpp @@ -26,6 +26,8 @@ #include "common/util.h" #include "common/system.h" #include "common/events.h" +#include "common/hashmap.h" +#include "common/hash-str.h" #include "gui/ThemeParser.h" @@ -46,39 +48,104 @@ inline bool isValidNameChar(char c) { c != '<' && c != '>' && c != '='; } +void ThemeParser::debug_testEval() { + static const char *debug_config_text = + "<drawdata id = \"background_default\" cache = true>" + "<draw func = \"roundedsq\" /*/fill = \"gradient\" gradient_start = \"255, 255, 128\" gradient_end = \"128, 128, 128\" size = \"auto\"/>" + "/*<draw func = \"roundedsq\" fill = \"none\" color = \"0, 0, 0\" size = \"auto\"/>*/" + "</drawdata>/* lol this is just a simple test*/"; + + _text = strdup(debug_config_text); + parseDrawData(); +} + + void ThemeParser::parserError(const char *error_string) { _state = kParserError; + printf("PARSER ERROR: %s\n", error_string); +} + +void ThemeParser::parseActiveKey(bool closed) { + printf("Parsed key %s.\n", _activeKey.top().c_str()); + + for (Common::StringMap::const_iterator t = _keyValues.begin(); t != _keyValues.end(); ++t) + printf(" Key %s = %s\n", t->_key.c_str(), t->_value.c_str()); + + if (closed) + _activeKey.pop(); + + _keyValues.clear(); +} + +void ThemeParser::parseKeyValue(Common::String &key_name) { + assert(_text[_pos++] == '='); + + while (isspace(_text[_pos])) + _pos++; + + Common::String data; + + if (_text[_pos] == '"') { + data += _text[_pos++]; + + while (_text[_pos] != '"') + data += _text[_pos++]; + + data += _text[_pos++]; + } else { + while (isValidNameChar(_text[_pos])) + data += _text[_pos++]; + } + + _keyValues[key_name] = data; } bool ThemeParser::parseDrawData() { _state = kParserNeedKey; + _pos = 0; + _keyValues.clear(); - while (_text[_pos++]) { - + while (_text[_pos]) { while (isspace(_text[_pos])) _pos++; // comment handling: skip everything between /* and */ - if (_text[_pos] == '/') { - if (_text[++_pos] != '*') { - parserError("Malformed comment string."); - return false; + if (_text[_pos] == '/' && _text[_pos + 1] == '*') { + _pos += 2; + while (_text[_pos++]) { + if (_text[_pos - 2] == '*' && _text[_pos - 1] == '/') + break; } - - _pos++; - - while (_text[_pos] != '*' && _text[_pos + 1] != '/') - _pos++; + continue; } switch (_state) { case kParserNeedKey: - if (_text[_pos] != '<') { + if (_text[_pos++] != '<') { parserError("Expecting key start."); return false; } + if (_text[_pos] == '/') { + _pos++; + _token.clear(); + while (isValidNameChar(_text[_pos])) + _token += _text[_pos++]; + + if (_token == _activeKey.top()) { + _activeKey.pop(); + + while (isspace(_text[_pos]) || _text[_pos] == '>') + _pos++; + + break; + } else { + parserError("Unexpected closure."); + return false; + } + } + _state = kParserKeyNeedName; break; @@ -87,16 +154,38 @@ bool ThemeParser::parseDrawData() { while (isValidNameChar(_text[_pos])) _token += _text[_pos++]; - if (!isspace(_text[_pos])) { + if (!isspace(_text[_pos]) && _text[_pos] != '>') { parserError("Invalid character in token name."); return false; } _state = kParserKeyNeedToken; + _activeKey.push(_token); break; case kParserKeyNeedToken: _token.clear(); + + if ((_text[_pos] == '/' && _text[_pos + 1] == '>') || _text[_pos] == '>') { + bool closed = _text[_pos] == '/'; + parseActiveKey(closed); + _pos += closed ? 2 : 1; + _state = kParserNeedKey; + break; + } + + while (isValidNameChar(_text[_pos])) + _token += _text[_pos++]; + + while (isspace(_text[_pos])) + _pos++; + + if (_text[_pos] != '=') { + parserError("Unexpected character after key name."); + return false; + } + + parseKeyValue(_token); break; default: @@ -104,6 +193,10 @@ bool ThemeParser::parseDrawData() { } } + if (_state != kParserNeedKey || !_activeKey.empty()) { + parserError("Unexpected end of file."); + } + return true; } |