1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
/*
* Copyright (c) 2011-2018 Isode Limited.
* All rights reserved.
* See the COPYING file for more information.
*/
#include <Swiften/Parser/AttributeMap.h>
#include <algorithm>
#include <boost/optional.hpp>
using namespace Swift;
AttributeMap::AttributeMap() {
}
std::string AttributeMap::getAttribute(const std::string& attribute, const std::string& ns) const {
const auto i = std::find_if(attributes.begin(), attributes.end(), [&](const Entry& entry) {
return entry.getAttribute() == Attribute(attribute, ns);
});
if (i == attributes.end()) {
return "";
}
else {
return i->getValue();
}
}
bool AttributeMap::getBoolAttribute(const std::string& attribute, bool defaultValue) const {
const auto i = std::find_if(attributes.begin(), attributes.end(), [&](const Entry& entry) {
return entry.getAttribute() == Attribute(attribute, "");
});
if (i == attributes.end()) {
return defaultValue;
}
else {
return i->getValue() == "true" || i->getValue() == "1";
}
}
boost::optional<std::string> AttributeMap::getAttributeValue(const std::string& attribute) const {
const auto i = std::find_if(attributes.begin(), attributes.end(), [&](const Entry& entry) {
return entry.getAttribute() == Attribute(attribute, "");
});
if (i == attributes.end()) {
return boost::optional<std::string>();
}
else {
return i->getValue();
}
}
void AttributeMap::addAttribute(const std::string& name, const std::string& ns, const std::string& value) {
attributes.push_back(Entry(Attribute(name, ns), value));
}
void AttributeMap::addAttribute(const std::string& name, const std::string& ns, const std::string& prefix, const std::string& value) {
attributes.push_back(Entry(Attribute(name, ns, prefix), value));
}
|