X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Console%2FNode.cci;h=242881fd8243419df201436d4654f29d8e06c65d;hb=9e7071473642404359c8b7a88c78fe02f00baf16;hp=0193989b31695bd22ca88b07466b4c59f1210461;hpb=33525a7447ddd7b56b23cb12fd83a7e293db303e;p=senf.git diff --git a/Console/Node.cci b/Console/Node.cci index 0193989..242881f 100644 --- a/Console/Node.cci +++ b/Console/Node.cci @@ -23,7 +23,7 @@ /** \file \brief Node inline non-template implementation */ -//#include "Node.ih" +#include "Node.ih" // Custom includes #include "../Utils/senfassert.hh" @@ -84,6 +84,57 @@ prefix_ senf::console::GenericNode::cptr senf::console::GenericNode::thisptr() return shared_from_this(); } +prefix_ bool senf::console::GenericNode::operator==(GenericNode & other) + const +{ + return this == & other; +} + +prefix_ bool senf::console::GenericNode::operator!=(GenericNode & other) + const +{ + return this != & other; +} + +prefix_ bool senf::console::GenericNode::isDirectory() + const +{ + return dynamic_cast(this); +} + +prefix_ bool senf::console::GenericNode::isLink() + const +{ + return dynamic_cast(this); +} + +prefix_ bool senf::console::GenericNode::isCommand() + const +{ + return dynamic_cast(this); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::console::LinkNode + +prefix_ senf::console::LinkNode::ptr senf::console::LinkNode::create(GenericNode & node) +{ + GenericNode::ptr p (node.thisptr()); + while ( p->isLink() ) + p = dynamic_cast(*p).follow().thisptr(); + return ptr(new LinkNode(*p)); +} + +prefix_ senf::console::GenericNode & senf::console::LinkNode::follow() + const +{ + return *node_; +} + +prefix_ senf::console::LinkNode::LinkNode(GenericNode & node) + : node_ (node.thisptr()) +{} + /////////////////////////////////////////////////////////////////////////// // senf::console::DirectoryNode @@ -99,6 +150,16 @@ prefix_ bool senf::console::DirectoryNode::hasChild(std::string const & name) return i != children_.end(); } +prefix_ senf::console::GenericNode & +senf::console::DirectoryNode::get(std::string const & name) + const +{ + GenericNode & node (getLink(name)); + return node.isLink() + ? dynamic_cast(node).follow() + : node; +} + prefix_ senf::console::DirectoryNode & senf::console::DirectoryNode::getDirectory(std::string const & name) const @@ -153,6 +214,11 @@ senf::console::DirectoryNode::completions(std::string const & s) children_.lower_bound(s + "\xff")); } +prefix_ void senf::console::DirectoryNode::link(std::string const & name, GenericNode & target) +{ + add(name, LinkNode::create(target)); +} + prefix_ senf::console::DirectoryNode::DirectoryNode() {} @@ -175,6 +241,15 @@ prefix_ senf::console::DirectoryNode::cptr senf::console::DirectoryNode::thisptr } /////////////////////////////////////////////////////////////////////////// +// senf::console::detail::NodeTraverser + +prefix_ senf::console::detail::NodeTraverser::NodeTraverser(DirectoryNode & root, + DirectoryNode & dir, + bool autocomplete) + : root_ (root), dir_ (dir.thisptr()), autocomplete_ (autocomplete), init_ (false) +{} + +/////////////////////////////////////////////////////////////////////////// // senf::console::SyntaxErrorException prefix_ senf::console::SyntaxErrorException::SyntaxErrorException(std::string const & msg)