diff options
author | Max Horn | 2011-06-16 15:51:04 +0200 |
---|---|---|
committer | Max Horn | 2011-06-17 10:38:16 +0200 |
commit | da3fff8ab38bce529ed6cbd1dea2731c93314030 (patch) | |
tree | a9e5ad3716f76595b3e111c8fb73175949adc1da | |
parent | 520b18d2ac183c4d671b9bd59935bec2aea0d4c6 (diff) | |
download | scummvm-rg350-da3fff8ab38bce529ed6cbd1dea2731c93314030.tar.gz scummvm-rg350-da3fff8ab38bce529ed6cbd1dea2731c93314030.tar.bz2 scummvm-rg350-da3fff8ab38bce529ed6cbd1dea2731c93314030.zip |
COMMON: Make use of Common::parseBool
-rw-r--r-- | common/config-manager.cpp | 8 | ||||
-rw-r--r-- | gui/ThemeParser.cpp | 22 |
2 files changed, 12 insertions, 18 deletions
diff --git a/common/config-manager.cpp b/common/config-manager.cpp index 03fcb20abf..3941e27cc1 100644 --- a/common/config-manager.cpp +++ b/common/config-manager.cpp @@ -491,11 +491,9 @@ int ConfigManager::getInt(const String &key, const String &domName) const { bool ConfigManager::getBool(const String &key, const String &domName) const { String value(get(key, domName)); - - if ((value == "true") || (value == "yes") || (value == "1")) - return true; - if ((value == "false") || (value == "no") || (value == "0")) - return false; + bool val; + if (Common::parseBool(value, val)) + return val; error("ConfigManager::getBool(%s,%s): '%s' is not a valid bool", key.c_str(), domName.c_str(), value.c_str()); diff --git a/gui/ThemeParser.cpp b/gui/ThemeParser.cpp index 5b1faa4075..55a76e856e 100644 --- a/gui/ThemeParser.cpp +++ b/gui/ThemeParser.cpp @@ -352,11 +352,8 @@ bool ThemeParser::parserCallback_drawdata(ParserNode *node) { } if (node->values.contains("cache")) { - if (node->values["cache"] == "true") - cached = true; - else if (node->values["cache"] == "false") - cached = false; - else return parserError("'Parsed' value must be either true or false."); + if (!Common::parseBool(node->values["cache"], cached)) + return parserError("'Parsed' value must be either true or false."); } if (_theme->addDrawData(node->values["id"], cached) == false) @@ -595,9 +592,7 @@ bool ThemeParser::parserCallback_widget(ParserNode *node) { bool enabled = true; if (node->values.contains("enabled")) { - if (node->values["enabled"] == "false") - enabled = false; - else if (node->values["enabled"] != "true") + if (!Common::parseBool(node->values["enabled"], enabled)) return parserError("Invalid value for Widget enabling (expecting true/false)"); } @@ -641,9 +636,7 @@ bool ThemeParser::parserCallback_dialog(ParserNode *node) { } if (node->values.contains("enabled")) { - if (node->values["enabled"] == "false") - enabled = false; - else if (node->values["enabled"] != "true") + if (!Common::parseBool(node->values["enabled"], enabled)) return parserError("Invalid value for Dialog enabling (expecting true/false)"); } @@ -677,16 +670,19 @@ bool ThemeParser::parserCallback_import(ParserNode *node) { bool ThemeParser::parserCallback_layout(ParserNode *node) { int spacing = -1; + bool center; if (node->values.contains("spacing")) { if (!parseIntegerKey(node->values["spacing"], 1, &spacing)) return false; } + Common::parseBool(node->values["center"], center); + if (node->values["type"] == "vertical") - _theme->getEvaluator()->addLayout(GUI::ThemeLayout::kLayoutVertical, spacing, node->values["center"] == "true"); + _theme->getEvaluator()->addLayout(GUI::ThemeLayout::kLayoutVertical, spacing, center); else if (node->values["type"] == "horizontal") - _theme->getEvaluator()->addLayout(GUI::ThemeLayout::kLayoutHorizontal, spacing, node->values["center"] == "true"); + _theme->getEvaluator()->addLayout(GUI::ThemeLayout::kLayoutHorizontal, spacing, center); else return parserError("Invalid layout type. Only 'horizontal' and 'vertical' layouts allowed."); |