#include "fallback.hpp" #include #include namespace Fallback { std::map Map::mFallbackMap; void Map::init(const std::map& fallback) { mFallbackMap = fallback; } std::string Map::getString(const std::string& fall) { std::map::const_iterator it; if ((it = mFallbackMap.find(fall)) == mFallbackMap.end()) { return std::string(); } return it->second; } float Map::getFloat(const std::string& fall) { const std::string& fallback = getString(fall); if (!fallback.empty()) { try { // We have to rely on Boost because std::stof from C++11 // uses the current locale for separators which we don't want and often silently ignores parsing errors. return boost::lexical_cast(fallback); } catch (boost::bad_lexical_cast&) { Log(Debug::Error) << "Error: '" << fall << "' setting value (" << fallback << ") is not a valid number, using 0 as a fallback"; } } return 0; } int Map::getInt(const std::string& fall) { const std::string& fallback = getString(fall); if (!fallback.empty()) { try { return std::stoi(fallback); } catch (const std::invalid_argument&) { Log(Debug::Error) << "Error: '" << fall << "' setting value (" << fallback << ") is not a valid number, using 0 as a fallback"; } catch (const std::out_of_range&) { Log(Debug::Error) << "Error: '" << fall << "' setting value (" << fallback << ") is out of range, using 0 as a fallback"; } } return 0; } bool Map::getBool(const std::string& fall) { const std::string& fallback = getString(fall); return !fallback.empty() && fallback != "0"; } osg::Vec4f Map::getColour(const std::string& fall) { const std::string& sum = getString(fall); if (!sum.empty()) { try { std::string ret[3]; unsigned int j = 0; for (unsigned int i = 0; i < sum.length(); ++i) { if(sum[i]==',') j++; else if (sum[i] != ' ') ret[j]+=sum[i]; } return osg::Vec4f(std::stoi(ret[0])/255.f,std::stoi(ret[1])/255.f,std::stoi(ret[2])/255.f, 1.f); } catch (const std::invalid_argument&) { Log(Debug::Error) << "Error: '" << fall << "' setting value (" << sum << ") is not a valid color, using middle gray as a fallback"; } } return osg::Vec4f(0.5f,0.5f,0.5f,1.f); } }