diff options
Diffstat (limited to 'src/cstore/ctemplate.hpp')
-rw-r--r-- | src/cstore/ctemplate.hpp | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/src/cstore/ctemplate.hpp b/src/cstore/ctemplate.hpp new file mode 100644 index 0000000..b9d1d8c --- /dev/null +++ b/src/cstore/ctemplate.hpp @@ -0,0 +1,126 @@ +/* + * Copyright (C) 2010 Vyatta, Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef _CTEMPLATE_H_ +#define _CTEMPLATE_H_ + +#include <tr1/memory> + +#include <cli_cstore.h> +#include <cstore/cstore.hpp> + +namespace cstore { // begin namespace cstore + +using namespace std; + +class Ctemplate { +public: + Ctemplate(tr1::shared_ptr<vtw_def> def) : _def(def) {}; + ~Ctemplate() {}; + + bool isValue() const { return _def->is_value; }; + bool isMulti() const { return _def->multi; }; + bool isTag() const { return _def->tag; }; + bool isTagNode() const { return (isTag() && !isValue()); }; + bool isTagValue() const { return (isTag() && isValue()); }; + bool isLeafValue() const { return (!isTag() && isValue()); }; + bool isTypeless(size_t tnum = 1) const { + /* note: the current "multi-type" implementation only supports two types. + * the interface here is generalized so it can support more in the + * future. + * + * isTypeless(i) implies isTypeless(j) for all (j > i). + * therefore, isTypeless() means the node has no types at all + * and is equivalent to isTypeless(1). + * + * originally, some "users" of vtw_def checks both is_value and + * def_type for typeless nodes. this should not be necessary so + * here we only check def_type. + */ + return ((tnum == 1) ? (_def->def_type == ERROR_TYPE) + : (_def->def_type2 == ERROR_TYPE)); + }; + bool isSingleLeafNode() const { + return (!isValue() && !isMulti() && !isTag() && !isTypeless()); + }; + bool isSingleLeafValue() const { + // assume isValue implies !isTypeless + return (isValue() && !isMulti() && !isTag()); + }; + bool isMultiLeafNode() const { + // assume isMulti implies !isTag && !isTypeless + return (!isValue() && isMulti()); + }; + bool isMultiLeafValue() const { + // assume isMulti implies !isTag && !isTypeless + return (isValue() && isMulti()); + }; + + size_t getNumTypes() const { + return (isTypeless(1) ? 0 : (isTypeless(2) ? 1 : 2)); + }; + vtw_type_e getType(size_t tnum = 1) const { + return ((tnum == 1) ? _def->def_type : _def->def_type2); + }; + const char *getTypeName(size_t tnum = 1) const { + return type_to_name(getType(tnum)); + }; + const char *getDefault() const { return _def->def_default; }; + const char *getNodeHelp() const { return _def->def_node_help; }; + const char *getEnumeration() const { return _def->def_enumeration; }; + const char *getAllowed() const { return _def->def_allowed; }; + const vtw_list *getActions(vtw_act_type act) const { + return &(_def->actions[act]); + }; + const char *getCompHelp() const { return _def->def_comp_help; }; + const char *getValHelp() const { return _def->def_val_help; }; + unsigned int getTagLimit() const { return _def->def_tag; }; + unsigned int getMultiLimit() const { return _def->def_multi; }; + + void setIsValue(bool is_val) { _def->is_value = is_val; }; + + const vtw_def *getDef() const { + /* XXX this is a hack for code that has not been converted and is still + * using vtw_def directly. this should go away once the transition + * is completed. + */ + return _def.get(); + }; + +private: + /* XXX ideally, template should be parsed directly into this class instead + * of wrapping the vtw_def struct in here. however, the legacy code + * (e.g., commit and code used by commit) still requires vtw_def, so + * need to keep it around for now until the transition is completed. + * + * note that the use of shared_ptr deals with the memory of the vtw_def + * struct *itself*. however, various members of vtw_def are allocated + * dynamically by the parser and were never freed before, i.e., they + * have always been leaked since the beginning. such leaks are not going + * to be fixed by the shared_ptr use here. + * + * once the transition is completed, vtw_def can be eliminated, and + * template data should be stored directly in this class using more + * suitable containers so that memory allocation/deallocation can be + * handled properly. + */ + tr1::shared_ptr<vtw_def> _def; +}; + +} // end namespace cstore + +#endif /* _CTEMPLATE_H_ */ + |