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.
openmw-tes3mp/extern/shiny/Main/PropertyBase.cpp

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';
}
}
}