forked from mirror/openmw-tes3mp
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
303 lines
7.2 KiB
C++
303 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';
|
|
}
|
|
}
|
|
}
|