xlnt/source/workbook/manifest.cpp

125 lines
3.3 KiB
C++
Raw Normal View History

2015-11-01 22:48:51 +08:00
#include <algorithm>
2015-10-30 01:46:56 +08:00
#include <xlnt/workbook/manifest.hpp>
2015-10-31 06:54:04 +08:00
namespace {
bool match_path(const std::string &path, const std::string &comparand)
{
if (path == comparand)
2015-10-31 06:54:04 +08:00
{
return true;
}
if (path[0] != '/' && path[0] != '.' && comparand[0] == '/')
2015-10-31 06:54:04 +08:00
{
return match_path("/" + path, comparand);
}
else if (comparand[0] != '/' && comparand[0] != '.' && path[0] == '/')
2015-10-31 06:54:04 +08:00
{
return match_path(path, "/" + comparand);
}
2015-10-31 06:54:04 +08:00
return false;
}
2015-10-31 06:54:04 +08:00
} // namespace
2015-10-30 01:46:56 +08:00
namespace xlnt {
2015-10-31 06:54:04 +08:00
default_type::default_type()
{
}
default_type::default_type(const std::string &extension, const std::string &content_type)
: extension_(extension), content_type_(content_type)
2015-10-31 06:54:04 +08:00
{
}
default_type::default_type(const default_type &other) : extension_(other.extension_), content_type_(other.content_type_)
2015-10-31 06:54:04 +08:00
{
}
default_type &default_type::operator=(const default_type &other)
{
extension_ = other.extension_;
content_type_ = other.content_type_;
2015-10-31 06:54:04 +08:00
return *this;
}
override_type::override_type()
{
}
override_type::override_type(const std::string &part_name, const std::string &content_type)
: part_name_(part_name), content_type_(content_type)
2015-10-31 06:54:04 +08:00
{
}
override_type::override_type(const override_type &other)
: part_name_(other.part_name_), content_type_(other.content_type_)
2015-10-31 06:54:04 +08:00
{
}
override_type &override_type::operator=(const override_type &other)
{
part_name_ = other.part_name_;
content_type_ = other.content_type_;
2015-10-31 06:54:04 +08:00
return *this;
}
2015-10-30 01:46:56 +08:00
bool manifest::has_default_type(const std::string &extension) const
{
return std::find_if(default_types_.begin(), default_types_.end(),
[&](const default_type &d) { return d.get_extension() == extension; }) != default_types_.end();
2015-10-30 01:46:56 +08:00
}
bool manifest::has_override_type(const std::string &part_name) const
{
return std::find_if(override_types_.begin(), override_types_.end(), [&](const override_type &d) {
return match_path(d.get_part_name(), part_name);
}) != override_types_.end();
2015-10-31 06:54:04 +08:00
}
void manifest::add_default_type(const std::string &extension, const std::string &content_type)
{
2015-11-02 12:52:19 +08:00
if(has_default_type(extension)) return;
2015-10-31 06:54:04 +08:00
default_types_.push_back(default_type(extension, content_type));
}
void manifest::add_override_type(const std::string &part_name, const std::string &content_type)
{
2015-11-02 12:52:19 +08:00
if(has_override_type(part_name)) return;
2015-10-31 06:54:04 +08:00
override_types_.push_back(override_type(part_name, content_type));
2015-10-30 01:46:56 +08:00
}
std::string manifest::get_default_type(const std::string &extension) const
{
auto match = std::find_if(default_types_.begin(), default_types_.end(),
[&](const default_type &d) { return d.get_extension() == extension; });
if (match == default_types_.end())
2015-10-30 01:46:56 +08:00
{
throw std::runtime_error("no default type found for extension: " + extension);
}
2015-10-30 01:46:56 +08:00
return match->get_content_type();
}
std::string manifest::get_override_type(const std::string &part_name) const
{
auto match = std::find_if(override_types_.begin(), override_types_.end(),
[&](const override_type &d) { return match_path(d.get_part_name(), part_name); });
if (match == override_types_.end())
2015-10-30 01:46:56 +08:00
{
throw std::runtime_error("no default type found for part name: " + part_name);
}
2015-10-30 01:46:56 +08:00
return match->get_content_type();
}
} // namespace xlnt