forked from teamnwah/openmw-tes3coop
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.
141 lines
4.2 KiB
C++
141 lines
4.2 KiB
C++
#include "escape.hpp"
|
|
|
|
#include <boost/algorithm/string/replace.hpp>
|
|
#include <boost/program_options.hpp>
|
|
|
|
namespace Files
|
|
{
|
|
const int escape_hash_filter::sEscape = '@';
|
|
const int escape_hash_filter::sEscapeIdentifier = 'a';
|
|
const int escape_hash_filter::sHashIdentifier = 'h';
|
|
|
|
escape_hash_filter::escape_hash_filter() : mNext(), mPrevious(), mSeenNonWhitespace(false), mFinishLine(false)
|
|
{
|
|
}
|
|
|
|
escape_hash_filter::~escape_hash_filter()
|
|
{
|
|
}
|
|
|
|
unescape_hash_filter::unescape_hash_filter() : expectingIdentifier(false)
|
|
{
|
|
}
|
|
|
|
unescape_hash_filter::~unescape_hash_filter()
|
|
{
|
|
}
|
|
|
|
std::string EscapeHashString::processString(const std::string & str)
|
|
{
|
|
std::string temp = boost::replace_all_copy<std::string>(str, std::string() + (char)escape_hash_filter::sEscape + (char)escape_hash_filter::sHashIdentifier, "#");
|
|
boost::replace_all(temp, std::string() + (char)escape_hash_filter::sEscape + (char)escape_hash_filter::sEscapeIdentifier, std::string((char)escape_hash_filter::sEscape, 1));
|
|
return temp;
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString() : mData()
|
|
{
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString(const std::string & str) : mData(EscapeHashString::processString(str))
|
|
{
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString(const std::string & str, size_t pos, size_t len) : mData(EscapeHashString::processString(str), pos, len)
|
|
{
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString(const char * s) : mData(EscapeHashString::processString(std::string(s)))
|
|
{
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString(const char * s, size_t n) : mData(EscapeHashString::processString(std::string(s)), 0, n)
|
|
{
|
|
}
|
|
|
|
EscapeHashString::EscapeHashString(size_t n, char c) : mData(n, c)
|
|
{
|
|
}
|
|
|
|
template <class InputIterator>
|
|
EscapeHashString::EscapeHashString(InputIterator first, InputIterator last) : mData(EscapeHashString::processString(std::string(first, last)))
|
|
{
|
|
}
|
|
|
|
std::string EscapeHashString::toStdString() const
|
|
{
|
|
return std::string(mData);
|
|
}
|
|
|
|
std::istream & operator>> (std::istream & is, EscapeHashString & eHS)
|
|
{
|
|
std::string temp;
|
|
is >> temp;
|
|
eHS = EscapeHashString(temp);
|
|
return is;
|
|
}
|
|
|
|
std::ostream & operator<< (std::ostream & os, const EscapeHashString & eHS)
|
|
{
|
|
os << eHS.mData;
|
|
return os;
|
|
}
|
|
|
|
EscapeStringVector::EscapeStringVector() : mVector()
|
|
{
|
|
}
|
|
|
|
EscapeStringVector::~EscapeStringVector()
|
|
{
|
|
}
|
|
|
|
std::vector<std::string> EscapeStringVector::toStdStringVector() const
|
|
{
|
|
std::vector<std::string> temp = std::vector<std::string>();
|
|
for (std::vector<EscapeHashString>::const_iterator it = mVector.begin(); it != mVector.end(); ++it)
|
|
{
|
|
temp.push_back(it->toStdString());
|
|
}
|
|
return temp;
|
|
}
|
|
|
|
// boost program options validation
|
|
|
|
void validate(boost::any &v, const std::vector<std::string> &tokens, Files::EscapeHashString * eHS, int a)
|
|
{
|
|
boost::program_options::validators::check_first_occurrence(v);
|
|
|
|
if (v.empty())
|
|
v = boost::any(EscapeHashString(boost::program_options::validators::get_single_string(tokens)));
|
|
}
|
|
|
|
void validate(boost::any &v, const std::vector<std::string> &tokens, EscapeStringVector *, int)
|
|
{
|
|
if (v.empty())
|
|
v = boost::any(EscapeStringVector());
|
|
|
|
EscapeStringVector * eSV = boost::any_cast<EscapeStringVector>(&v);
|
|
|
|
for (std::vector<std::string>::const_iterator it = tokens.begin(); it != tokens.end(); ++it)
|
|
eSV->mVector.push_back(EscapeHashString(*it));
|
|
}
|
|
|
|
PathContainer EscapePath::toPathContainer(const EscapePathContainer & escapePathContainer)
|
|
{
|
|
PathContainer temp;
|
|
for (EscapePathContainer::const_iterator it = escapePathContainer.begin(); it != escapePathContainer.end(); ++it)
|
|
temp.push_back(it->mPath);
|
|
return temp;
|
|
}
|
|
|
|
std::istream & operator>> (std::istream & istream, EscapePath & escapePath)
|
|
{
|
|
boost::iostreams::filtering_istream filteredStream;
|
|
filteredStream.push(unescape_hash_filter());
|
|
filteredStream.push(istream);
|
|
|
|
filteredStream >> escapePath.mPath;
|
|
|
|
return istream;
|
|
}
|
|
}
|