// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*- // Copyright (c) 2001-2007 International Computer Science Institute // // 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, subject to the conditions // listed in the XORP LICENSE file. These conditions include: you must // preserve this copyright notice, and you cannot mention the copyright // holders in advertising related to the Software without their permission. // The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This // notice is a summary of the XORP LICENSE file; the license in that file is // legally binding. #ident "$XORP: xorp/rtrmgr/command_tree.cc,v 1.13 2007/02/16 22:47:21 pavlin Exp $" #include "rtrmgr_module.h" #include "libxorp/xorp.h" #include "libxorp/xlog.h" #include "libxorp/debug.h" #include "command_tree.hh" #include "template_tree_node.hh" CommandTreeNode::CommandTreeNode(const string& name, const ConfigTreeNode* ctn, const TemplateTreeNode* ttn) : _name(name), _config_tree_node(ctn), _template_tree_node(ttn) { _parent = NULL; _has_command = false; } CommandTreeNode::~CommandTreeNode() { list::iterator iter; for (iter = _children.begin(); iter != _children.end(); ++iter) { delete *iter; } } void CommandTreeNode::add_child(CommandTreeNode* child) { _children.push_back(child); child->set_parent(this); } string CommandTreeNode::str() const { if (_parent == NULL) { return ""; } else { string s = _parent->str(); if (s != "") s += " "; s += _name; if (_has_command) s += "[*]"; return s; } } #if 0 const CommandTreeNode* CommandTreeNode::subroot(list path) const { if (path.empty()) { return this; } list::const_iterator iter; for (iter = _children.begin(); iter != _children.end(); ++iter) { if ((*iter)->name() == path.front()) { path.pop_front(); return (*iter)->subroot(path); } } // Debugging only below this point XLOG_TRACE(_verbose, "ERROR doing subroot at node >%s<\n", _name.c_str()); for (iter =_children.begin(); iter != _children.end(); ++iter) { XLOG_TRACE(_verbose, "Child: %s\n", (*iter)->name().c_str()); } while (!path.empty()) { XLOG_TRACE(_verbose, "Path front is >%s<\n", path.front().c_str()); path.pop_front(); } return NULL; } #endif // 0 string CommandTreeNode::subtree_str() const { string s; s = c_format("Node: %s\n", str().c_str()); list::const_iterator iter; for (iter = _children.begin(); iter != _children.end(); ++iter) { s += (*iter)->subtree_str(); } return s; } const string& CommandTreeNode::help() const { return _template_tree_node->help(); } CommandTree::CommandTree() : _root_node("ROOT", NULL, NULL) { _current_node = &_root_node; } CommandTree::~CommandTree() { } void CommandTree::push(const string& str) { _temp_path.push_back(str); } void CommandTree::pop() { if (_temp_path.empty()) { _current_node = _current_node->parent(); } else { _temp_path.pop_back(); } } void CommandTree::instantiate(const ConfigTreeNode* ctn, const TemplateTreeNode* ttn, bool has_command) { XLOG_ASSERT(! _temp_path.empty()); list::const_iterator iter; for (iter = _temp_path.begin(); iter != _temp_path.end(); ++iter) { debug_msg("Instantiating node >%s<\n", iter->c_str()); CommandTreeNode* new_ctn = new CommandTreeNode(*iter, ctn, ttn); _current_node->add_child(new_ctn); _current_node = new_ctn; } if (has_command) _current_node->set_has_command(); _temp_path.clear(); } void CommandTree::activate_current() { _current_node->set_has_command(); } string CommandTree::tree_str() const { return _root_node.subtree_str(); }