blob: d49d244cf8382c6cc38ca44105755440cda6e36d [file] [log] [blame]
/*
* Copyright (C) 2020 CESNET, https://photonics.cesnet.cz/
*
* Written by Václav Kubernát <kubernat@cesnet.cz>
*
*/
#include <experimental/iterator>
#include "parser.hpp"
#include "utils.hpp"
namespace std {
std::ostream& operator<<(std::ostream& s, const Completions& completion)
{
s << std::endl << "Completions {" << std::endl << " m_completions: ";
std::transform(completion.m_completions.begin(), completion.m_completions.end(),
std::experimental::make_ostream_joiner(s, ", "),
[] (auto it) { return '"' + it + '"'; });
s << std::endl << " m_contextLength: " << completion.m_contextLength << std::endl;
s << "}" << std::endl;
return s;
}
std::ostream& operator<<(std::ostream& s, const std::optional<std::string>& opt)
{
s << (opt ? *opt : "std::nullopt");
return s;
}
std::ostream& operator<<(std::ostream& s, const DatastoreAccess::Tree& map)
{
s << std::endl
<< "{";
for (const auto& it : map) {
s << "{\"" << it.first << "\", " << leafDataToString(it.second) << "}" << std::endl;
}
s << "}" << std::endl;
return s;
}
std::ostream& operator<<(std::ostream& s, const yang::LeafDataType& type)
{
s << std::endl
<< leafDataTypeToString(type);
if (std::holds_alternative<yang::Enum>(type)) {
s << "{";
auto values = std::get<yang::Enum>(type).m_allowedValues;
std::transform(values.begin(), values.end(), std::experimental::make_ostream_joiner(s, ", "), [](const auto& value) {
return value.m_value;
});
s << "}";
}
if (std::holds_alternative<yang::IdentityRef>(type)) {
s << "{";
auto values = std::get<yang::IdentityRef>(type).m_allowedValues;
std::transform(values.begin(), values.end(), std::experimental::make_ostream_joiner(s, ", "), [](const auto& value) {
std::string res;
if (value.m_prefix) {
res += value.m_prefix->m_name;
res += ":";
}
res += value.m_value;
return res;
});
s << "}";
}
if (std::holds_alternative<yang::LeafRef>(type)) {
s << "{" << std::get<yang::LeafRef>(type).m_targetXPath << "," << std::get<yang::LeafRef>(type).m_targetType->m_type << "}";
}
if (std::holds_alternative<yang::Union>(type)) {
s << "{" << std::endl;
auto types = std::get<yang::Union>(type).m_unionTypes;
std::transform(types.begin(), types.end(), std::experimental::make_ostream_joiner(s, ",\n"), [] (const auto& type) {
return type.m_type;
});
}
s << std::endl;
return s;
}
std::ostream& operator<<(std::ostream& s, const yang::TypeInfo& type)
{
s << type.m_type << (type.m_units ? " units: " + *type.m_units : "");
return s;
}
std::ostream& operator<<(std::ostream& s, const boost::optional<std::string>& opt)
{
s << (opt ? *opt : "std::nullopt");
return s;
}
}
std::ostream& operator<<(std::ostream& s, const boost::variant<dataPath_, schemaPath_, module_>& path)
{
if (path.type() == typeid(module_)) {
s << "module: " << boost::get<module_>(path).m_name << "\n";
} else if (path.type() == typeid(dataPath_)) {
s << "dataPath: " << pathToDataString(boost::get<dataPath_>(path), Prefixes::WhenNeeded) << "\n";
} else {
s << "schemaPath: " << pathToSchemaString(boost::get<schemaPath_>(path), Prefixes::WhenNeeded) << "\n";
}
return s;
}