mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 11:56:37 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "fallback.hpp"
 | |
| 
 | |
| #include <components/debug/debuglog.hpp>
 | |
| 
 | |
| #include <boost/lexical_cast.hpp>
 | |
| 
 | |
| namespace Fallback
 | |
| {
 | |
|     Map::Map(const std::map<std::string,std::string>& fallback):mFallbackMap(fallback)
 | |
|     {}
 | |
| 
 | |
|     std::string Map::getFallbackString(const std::string& fall) const
 | |
|     {
 | |
|         std::map<std::string,std::string>::const_iterator it;
 | |
|         if ((it = mFallbackMap.find(fall)) == mFallbackMap.end())
 | |
|         {
 | |
|             return std::string();
 | |
|         }
 | |
|         return it->second;
 | |
|     }
 | |
| 
 | |
|     float Map::getFallbackFloat(const std::string& fall) const
 | |
|     {
 | |
|         std::string fallback = getFallbackString(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<float>(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::getFallbackInt(const std::string& fall) const
 | |
|     {
 | |
|         std::string fallback = getFallbackString(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::getFallbackBool(const std::string& fall) const
 | |
|     {
 | |
|         std::string fallback = getFallbackString(fall);
 | |
|         return !fallback.empty() && fallback != "0";
 | |
|     }
 | |
| 
 | |
|     osg::Vec4f Map::getFallbackColour(const std::string& fall) const
 | |
|     {
 | |
|         std::string sum = getFallbackString(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);
 | |
|     }
 | |
| 
 | |
| }
 |