X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FNode.cci;h=5bb7c09748736d9792878a0ad686f3c7426abd7a;hb=4101c2b818ec67e7469ebb44f030eed2185c4ab0;hp=61c36460071aae5180a1df7546c391e36858e5d7;hpb=f13780e9e4da7df981d6f6542fbdc714beb34765;p=senf.git diff --git a/senf/Utils/Console/Node.cci b/senf/Utils/Console/Node.cci index 61c3646..5bb7c09 100644 --- a/senf/Utils/Console/Node.cci +++ b/senf/Utils/Console/Node.cci @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2008 +// Copyright (C) 2008 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund @@ -26,12 +26,11 @@ #include "Node.ih" // Custom includes -#include #define prefix_ inline -///////////////////////////////cci.p/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::GenericNode prefix_ senf::console::GenericNode::ptr senf::console::GenericNode::thisptr() @@ -135,7 +134,7 @@ prefix_ senf::console::GenericNode & senf::console::GenericNode::followLink() : *this; } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::LinkNode prefix_ senf::console::GenericNode & senf::console::LinkNode::follow() @@ -156,7 +155,7 @@ prefix_ senf::console::LinkNode::LinkNode(GenericNode & node) : node_ (node.thisptr()) {} -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::DirectoryNode prefix_ senf::console::DirectoryNode::ptr senf::console::DirectoryNode::create() @@ -212,18 +211,6 @@ senf::console::DirectoryNode::operator()(std::string const & name) return getCommand(name); } -prefix_ senf::console::DirectoryNode & -senf::console::DirectoryNode::mkdir(std::string const & name) -{ - return add(name, create()); -} - -prefix_ senf::console::DirectoryNode & -senf::console::DirectoryNode::provideDirectory(std::string const & name) -{ - return hasChild(name) ? getDirectory(name) : mkdir(name); -} - prefix_ senf::console::DirectoryNode::ChildrenRange senf::console::DirectoryNode::children() const { @@ -238,11 +225,6 @@ 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() {} @@ -271,7 +253,7 @@ prefix_ senf::console::DirectoryNode::cptr senf::console::DirectoryNode::thisptr return boost::static_pointer_cast(shared_from_this()); } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::detail::NodeTraverser #ifndef DOXYGEN @@ -283,7 +265,7 @@ prefix_ senf::console::detail::NodeTraverser::NodeTraverser(DirectoryNode & root #endif -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::CommandNode prefix_ senf::console::CommandNode::ptr senf::console::CommandNode::thisptr() @@ -330,7 +312,7 @@ prefix_ void senf::console::CommandNode::operator()(boost::any & rv, std::ostrea execute(rv, output, command); } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::SimpleCommandNode prefix_ senf::console::SimpleCommandNode::SimpleCommandNode(Function const & fn) @@ -368,7 +350,16 @@ prefix_ senf::console::SimpleCommandNode::cptr senf::console::SimpleCommandNode: return boost::static_pointer_cast(shared_from_this()); } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// + +prefix_ senf::console::DirectoryNode & senf::console::provideDirectory(DirectoryNode & dir, + std::string const & name) +{ + return dir.hasChild(name) ? dir.getDirectory(name) : dir.add(name, factory::Directory()); +} + + +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::factory::SimpleCommand prefix_ senf::console::factory::SimpleCommand::SimpleCommand(SimpleCommandNode::Function fn) @@ -398,7 +389,51 @@ senf::console::factory::SimpleCommand::shortdoc(std::string const & doc) return *this; } -///////////////////////////////cci.e/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::factory::Directory + +prefix_ senf::console::factory::Directory::Directory() + : node_ (DirectoryNode::create()) +{} + +prefix_ senf::console::DirectoryNode & +senf::console::factory::Directory::create(DirectoryNode & dir, std::string const & name) + const +{ + return dir.add(name, node_); +} + +prefix_ senf::console::factory::Directory const & +senf::console::factory::Directory::doc(std::string const & doc) + const +{ + node_->doc(doc); + return *this; +} + +prefix_ senf::console::factory::Directory const & +senf::console::factory::Directory::shortdoc(std::string const & doc) + const +{ + node_->shortdoc(doc); + return *this; +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::factory::Link + +prefix_ senf::console::factory::Link::Link(GenericNode & target) + : node_ (LinkNode::create(target)) +{} + +prefix_ senf::console::LinkNode & senf::console::factory::Link::create(DirectoryNode & dir, + std::string const & name) + const +{ + return dir.add(name, node_); +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_