mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 03:26:37 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			302 lines
		
	
	
	
		
			7.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			302 lines
		
	
	
	
		
			7.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "PropertyBase.hpp"
 | |
| 
 | |
| #include <vector>
 | |
| #include <iostream>
 | |
| 
 | |
| #include <boost/lexical_cast.hpp>
 | |
| #include <boost/algorithm/string.hpp>
 | |
| 
 | |
| #include <fstream>
 | |
| 
 | |
| namespace sh
 | |
| {
 | |
| 
 | |
| 	IntValue::IntValue(int in)
 | |
| 		: mValue(in)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	IntValue::IntValue(const std::string& in)
 | |
| 	{
 | |
| 		mValue = boost::lexical_cast<int>(in);
 | |
| 	}
 | |
| 
 | |
| 	std::string IntValue::serialize()
 | |
| 	{
 | |
| 		return boost::lexical_cast<std::string>(mValue);
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	BooleanValue::BooleanValue (bool in)
 | |
| 		: mValue(in)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	BooleanValue::BooleanValue (const std::string& in)
 | |
| 	{
 | |
| 		if (in == "true")
 | |
| 			mValue = true;
 | |
| 		else if (in == "false")
 | |
| 			mValue = false;
 | |
| 		else
 | |
| 		{
 | |
| 			std::stringstream msg;
 | |
| 			msg << "sh::BooleanValue: Warning: Unrecognized value \"" << in << "\" for property value of type BooleanValue";
 | |
| 			throw std::runtime_error(msg.str());
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	std::string BooleanValue::serialize ()
 | |
| 	{
 | |
| 		if (mValue)
 | |
| 			return "true";
 | |
| 		else
 | |
| 			return "false";
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	StringValue::StringValue (const std::string& in)
 | |
| 	{
 | |
| 		mStringValue = in;
 | |
| 	}
 | |
| 
 | |
| 	std::string StringValue::serialize()
 | |
| 	{
 | |
| 		return mStringValue;
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	LinkedValue::LinkedValue (const std::string& in)
 | |
| 	{
 | |
| 		mStringValue = in;
 | |
| 		mStringValue.erase(0, 1);
 | |
| 	}
 | |
| 
 | |
| 	std::string LinkedValue::serialize()
 | |
| 	{
 | |
| 		throw std::runtime_error ("can't directly get a linked value");
 | |
| 	}
 | |
| 
 | |
| 	std::string LinkedValue::get(PropertySetGet* context) const
 | |
| 	{
 | |
| 		PropertyValuePtr p = context->getProperty(mStringValue);
 | |
| 		return retrieveValue<StringValue>(p, NULL).get();
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	FloatValue::FloatValue (float in)
 | |
| 	{
 | |
| 		mValue = in;
 | |
| 	}
 | |
| 
 | |
| 	FloatValue::FloatValue (const std::string& in)
 | |
| 	{
 | |
| 		mValue = boost::lexical_cast<float>(in);
 | |
| 	}
 | |
| 
 | |
| 	std::string FloatValue::serialize ()
 | |
| 	{
 | |
| 		return boost::lexical_cast<std::string>(mValue);
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	Vector2::Vector2 (float x, float y)
 | |
| 		: mX(x)
 | |
| 		, mY(y)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	Vector2::Vector2 (const std::string& in)
 | |
| 	{
 | |
| 		std::vector<std::string> tokens;
 | |
| 		boost::split(tokens, in, boost::is_any_of(" "));
 | |
| 		assert ((tokens.size() == 2) && "Invalid Vector2 conversion");
 | |
| 		mX = boost::lexical_cast<float> (tokens[0]);
 | |
| 		mY = boost::lexical_cast<float> (tokens[1]);
 | |
| 	}
 | |
| 
 | |
| 	std::string Vector2::serialize ()
 | |
| 	{
 | |
| 		return boost::lexical_cast<std::string>(mX) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mY);
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	Vector3::Vector3 (float x, float y, float z)
 | |
| 		: mX(x)
 | |
| 		, mY(y)
 | |
| 		, mZ(z)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	Vector3::Vector3 (const std::string& in)
 | |
| 	{
 | |
| 		std::vector<std::string> tokens;
 | |
| 		boost::split(tokens, in, boost::is_any_of(" "));
 | |
| 		assert ((tokens.size() == 3) && "Invalid Vector3 conversion");
 | |
| 		mX = boost::lexical_cast<float> (tokens[0]);
 | |
| 		mY = boost::lexical_cast<float> (tokens[1]);
 | |
| 		mZ = boost::lexical_cast<float> (tokens[2]);
 | |
| 	}
 | |
| 
 | |
| 	std::string Vector3::serialize ()
 | |
| 	{
 | |
| 		return boost::lexical_cast<std::string>(mX) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mY) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mZ);
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	Vector4::Vector4 (float x, float y, float z, float w)
 | |
| 		: mX(x)
 | |
| 		, mY(y)
 | |
| 		, mZ(z)
 | |
| 		, mW(w)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	Vector4::Vector4 (const std::string& in)
 | |
| 	{
 | |
| 		std::vector<std::string> tokens;
 | |
| 		boost::split(tokens, in, boost::is_any_of(" "));
 | |
| 		assert ((tokens.size() == 4) && "Invalid Vector4 conversion");
 | |
| 		mX = boost::lexical_cast<float> (tokens[0]);
 | |
| 		mY = boost::lexical_cast<float> (tokens[1]);
 | |
| 		mZ = boost::lexical_cast<float> (tokens[2]);
 | |
| 		mW = boost::lexical_cast<float> (tokens[3]);
 | |
| 	}
 | |
| 
 | |
| 	std::string Vector4::serialize ()
 | |
| 	{
 | |
| 		return boost::lexical_cast<std::string>(mX) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mY) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mZ) + " "
 | |
| 			+ boost::lexical_cast<std::string>(mW);
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	void PropertySet::setProperty (const std::string& name, PropertyValuePtr &value, PropertySetGet* context)
 | |
| 	{
 | |
| 		if (!setPropertyOverride (name, value, context))
 | |
| 		{
 | |
| 			std::stringstream msg;
 | |
| 			msg << "sh::PropertySet: Warning: No match for property with name '" << name << "'";
 | |
| 			throw std::runtime_error(msg.str());
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	bool PropertySet::setPropertyOverride (const std::string& name, PropertyValuePtr &value, PropertySetGet* context)
 | |
| 	{
 | |
| 		// if we got here, none of the sub-classes were able to make use of the property
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	// ------------------------------------------------------------------------------
 | |
| 
 | |
| 	PropertySetGet::PropertySetGet (PropertySetGet* parent)
 | |
| 		: mParent(parent)
 | |
| 		, mContext(NULL)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	PropertySetGet::PropertySetGet ()
 | |
| 		: mParent(NULL)
 | |
| 		, mContext(NULL)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::setParent (PropertySetGet* parent)
 | |
| 	{
 | |
| 		mParent = parent;
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::setContext (PropertySetGet* context)
 | |
| 	{
 | |
| 		mContext = context;
 | |
| 	}
 | |
| 
 | |
| 	PropertySetGet* PropertySetGet::getContext()
 | |
| 	{
 | |
| 		return mContext;
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::setProperty (const std::string& name, PropertyValuePtr value)
 | |
| 	{
 | |
| 		mProperties [name] = value;
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::deleteProperty(const std::string &name)
 | |
| 	{
 | |
| 		mProperties.erase(name);
 | |
| 	}
 | |
| 
 | |
| 	PropertyValuePtr& PropertySetGet::getProperty (const std::string& name)
 | |
| 	{
 | |
| 		bool found = (mProperties.find(name) != mProperties.end());
 | |
| 
 | |
| 		if (!found)
 | |
| 		{
 | |
| 			if (!mParent)
 | |
| 				throw std::runtime_error ("Trying to retrieve property \"" + name + "\" that does not exist");
 | |
| 			else
 | |
| 				return mParent->getProperty (name);
 | |
| 		}
 | |
| 		else
 | |
| 			return mProperties[name];
 | |
| 	}
 | |
| 
 | |
| 	bool PropertySetGet::hasProperty (const std::string& name) const
 | |
| 	{
 | |
| 		bool found = (mProperties.find(name) != mProperties.end());
 | |
| 
 | |
| 		if (!found)
 | |
| 		{
 | |
| 			if (!mParent)
 | |
| 				return false;
 | |
| 			else
 | |
| 				return mParent->hasProperty (name);
 | |
| 		}
 | |
| 		else
 | |
| 			return true;
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::copyAll (PropertySet* target, PropertySetGet* context, bool copyParent)
 | |
| 	{
 | |
| 		if (mParent && copyParent)
 | |
| 			mParent->copyAll (target, context);
 | |
| 		for (PropertyMap::iterator it = mProperties.begin(); it != mProperties.end(); ++it)
 | |
| 		{
 | |
| 			target->setProperty(it->first, it->second, context);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::copyAll (PropertySetGet* target, PropertySetGet* context, bool copyParent)
 | |
| 	{
 | |
| 		if (mParent && copyParent)
 | |
| 			mParent->copyAll (target, context);
 | |
| 		for (PropertyMap::iterator it = mProperties.begin(); it != mProperties.end(); ++it)
 | |
| 		{
 | |
| 			std::string val = retrieveValue<StringValue>(it->second, this).get();
 | |
| 			target->setProperty(it->first, sh::makeProperty(new sh::StringValue(val)));
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	void PropertySetGet::save(std::ofstream &stream, const std::string& indentation)
 | |
| 	{
 | |
| 		for (PropertyMap::iterator it = mProperties.begin(); it != mProperties.end(); ++it)
 | |
| 		{
 | |
| 			if (typeid( *(it->second) ) == typeid(LinkedValue))
 | |
| 				stream << indentation << it->first << " " << "$" + static_cast<LinkedValue*>(&*(it->second))->_getStringValue() << '\n';
 | |
| 			else
 | |
| 				stream << indentation << it->first << " " << retrieveValue<StringValue>(it->second, this).get() << '\n';
 | |
| 		}
 | |
| 	}
 | |
| }
 |