xlnt/source/packaging/manifest.cpp

116 lines
3.8 KiB
C++
Raw Normal View History

2015-12-24 17:10:02 -05:00
// Copyright (c) 2014-2016 Thomas Fussell
// Copyright (c) 2010-2015 openpyxl
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, WRISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE
//
// @license: http://www.opensource.org/licenses/mit-license.php
// @author: see AUTHORS file
2015-11-01 09:48:51 -05:00
#include <algorithm>
#include <stdexcept>
2015-11-01 09:48:51 -05:00
#include <xlnt/packaging/manifest.hpp>
2015-10-29 13:46:56 -04:00
2015-10-30 18:54:04 -04:00
namespace {
bool match_path(const std::string &path, const std::string &comparand)
2015-10-30 18:54:04 -04:00
{
if (path == comparand)
2015-10-30 18:54:04 -04:00
{
return true;
}
if (path[0] != '/' && path[0] != '.' && comparand[0] == '/')
2015-10-30 18:54:04 -04:00
{
return match_path("/" + path, comparand);
}
else if (comparand[0] != '/' && comparand[0] != '.' && path[0] == '/')
2015-10-30 18:54:04 -04:00
{
return match_path(path, "/" + comparand);
}
2015-10-30 18:54:04 -04:00
return false;
}
2015-10-30 18:54:04 -04:00
} // namespace
2015-10-29 13:46:56 -04:00
namespace xlnt {
bool manifest::has_default_type(const std::string &extension) const
2015-10-29 13:46:56 -04:00
{
return std::find_if(default_types_.begin(), default_types_.end(),
[&](const default_type &d) { return d.get_extension() == extension; }) != default_types_.end();
2015-10-29 13:46:56 -04:00
}
bool manifest::has_override_type(const std::string &part_name) const
2015-10-29 13:46:56 -04:00
{
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-30 18:54:04 -04:00
}
void manifest::add_default_type(const std::string &extension, const std::string &content_type)
2015-10-30 18:54:04 -04:00
{
2015-11-01 23:52:19 -05:00
if(has_default_type(extension)) return;
2015-10-30 18:54:04 -04: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-10-30 18:54:04 -04:00
{
2015-11-01 23:52:19 -05:00
if(has_override_type(part_name)) return;
2015-10-30 18:54:04 -04:00
override_types_.push_back(override_type(part_name, content_type));
2015-10-29 13:46:56 -04:00
}
std::string manifest::get_default_type(const std::string &extension) const
2015-10-29 13:46:56 -04:00
{
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-29 13:46:56 -04:00
{
throw std::runtime_error("no default type found for extension: " + extension);
2015-10-29 13:46:56 -04:00
}
2015-10-29 13:46:56 -04:00
return match->get_content_type();
}
std::string manifest::get_override_type(const std::string &part_name) const
2015-10-29 13:46:56 -04:00
{
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-29 13:46:56 -04:00
{
throw std::runtime_error("no default type found for part name: " + part_name);
2015-10-29 13:46:56 -04:00
}
2015-10-29 13:46:56 -04:00
return match->get_content_type();
}
const std::vector<default_type> &manifest::get_default_types() const
{
return default_types_;
}
const std::vector<override_type> &manifest::get_override_types() const
{
return override_types_;
}
2015-10-29 13:46:56 -04:00
} // namespace xlnt