blob: f768461b12d0071b60f124b137d5d296fffb9fc1 [file] [log] [blame]
/*
* Copyright (C) 2018 CESNET, https://photonics.cesnet.cz/
* Copyright (C) 2018 FIT CVUT, https://fit.cvut.cz/
*
* Written by Václav Kubernát <kubervac@fit.cvut.cz>
*
*/
#pragma once
#include <boost/fusion/adapted/struct/adapt_struct.hpp>
#include <boost/fusion/include/adapt_struct.hpp>
#include <boost/fusion/include/std_pair.hpp>
#include <boost/variant/variant.hpp>
#include <map>
#include <vector>
#include "ast_values.hpp"
enum class Prefixes {
Always,
WhenNeeded
};
struct nodeup_ {
bool operator==(const nodeup_&) const
{
return true;
}
};
struct container_ {
container_() = default;
container_(const std::string& name);
bool operator==(const container_& b) const;
std::string m_name;
};
struct leaf_ {
leaf_() = default;
leaf_(const std::string& name);
bool operator==(const leaf_& b) const;
std::string m_name;
};
struct leafList_ {
leafList_();
leafList_(const std::string& name);
bool operator==(const leafList_& b) const;
std::string m_name;
};
struct leafListElement_ {
bool operator==(const leafListElement_& b) const;
std::string m_name;
leaf_data_ m_value;
};
struct listElement_ {
listElement_() {}
listElement_(const std::string& listName, const std::map<std::string, leaf_data_>& keys);
bool operator==(const listElement_& b) const;
std::string m_name;
std::map<std::string, leaf_data_> m_keys;
};
struct list_ {
list_() {}
list_(const std::string& listName);
bool operator==(const list_& b) const;
std::string m_name;
};
struct schemaNode_ {
boost::optional<module_> m_prefix;
boost::variant<container_, list_, nodeup_, leaf_, leafList_> m_suffix;
schemaNode_();
schemaNode_(decltype(m_suffix) node);
schemaNode_(module_ module, decltype(m_suffix) node);
bool operator==(const schemaNode_& b) const;
};
struct dataNode_ {
boost::optional<module_> m_prefix;
boost::variant<container_, listElement_, nodeup_, leaf_, leafListElement_, leafList_, list_> m_suffix;
dataNode_();
dataNode_(decltype(m_suffix) node);
dataNode_(module_ module, decltype(m_suffix) node);
bool operator==(const dataNode_& b) const;
};
enum class TrailingSlash {
Present,
NonPresent
};
enum class Scope {
Absolute,
Relative
};
struct schemaPath_ {
bool operator==(const schemaPath_& b) const;
Scope m_scope = Scope::Relative;
std::vector<schemaNode_> m_nodes;
TrailingSlash m_trailingSlash = TrailingSlash::NonPresent;
};
struct dataPath_ {
bool operator==(const dataPath_& b) const;
Scope m_scope = Scope::Relative;
std::vector<dataNode_> m_nodes;
TrailingSlash m_trailingSlash = TrailingSlash::NonPresent;
};
std::string nodeToSchemaString(decltype(dataPath_::m_nodes)::value_type node);
std::string pathToDataString(const dataPath_& path, Prefixes prefixes);
std::string pathToSchemaString(const schemaPath_& path, Prefixes prefixes);
std::string pathToSchemaString(const dataPath_& path, Prefixes prefixes);
schemaNode_ dataNodeToSchemaNode(const dataNode_& node);
schemaPath_ dataPathToSchemaPath(const dataPath_& path);
std::string escapeListKeyString(const std::string& what);
BOOST_FUSION_ADAPT_STRUCT(container_, m_name)
BOOST_FUSION_ADAPT_STRUCT(listElement_, m_name, m_keys)
BOOST_FUSION_ADAPT_STRUCT(leafListElement_, m_name, m_value)
BOOST_FUSION_ADAPT_STRUCT(module_, m_name)
BOOST_FUSION_ADAPT_STRUCT(dataNode_, m_prefix, m_suffix)
BOOST_FUSION_ADAPT_STRUCT(schemaNode_, m_prefix, m_suffix)
BOOST_FUSION_ADAPT_STRUCT(dataPath_, m_scope, m_nodes, m_trailingSlash)
BOOST_FUSION_ADAPT_STRUCT(schemaPath_, m_scope, m_nodes, m_trailingSlash)