X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FOverloadedCommand.cci;h=352e162855a613ff32b9b6cd30def4b35dff7d89;hb=5b2e9a63a43027c71ac470ac9bdecb72e8974951;hp=c891fda6dec276d7d7c8928856071dcc3f3b6eaa;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/OverloadedCommand.cci b/senf/Utils/Console/OverloadedCommand.cci index c891fda..352e162 100644 --- a/senf/Utils/Console/OverloadedCommand.cci +++ b/senf/Utils/Console/OverloadedCommand.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 @@ -28,9 +28,9 @@ // Custom includes #define prefix_ inline -///////////////////////////////cci.p/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::OverloadedCommandNode prefix_ senf::console::OverloadedCommandNode::ptr senf::console::OverloadedCommandNode::create() @@ -66,7 +66,7 @@ senf::console::OverloadedCommandNode::shortdoc(std::string const & doc) prefix_ unsigned senf::console::OverloadedCommandNode::overloadIndex(CommandOverload const & overload) { - return find(overloads_.begin(), overloads_.end(), CommandOverload::cptr(&overload)) + return find(overloads_.begin(), overloads_.end(), CommandOverload::cptr(&overload)) - overloads_.begin() + 1; } @@ -80,7 +80,7 @@ senf::console::OverloadedCommandNode::overloads() prefix_ senf::console::OverloadedCommandNode::OverloadedCommandNode() {} -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::CommandOverload prefix_ senf::console::CommandOverload::~CommandOverload() @@ -119,7 +119,7 @@ prefix_ std::string senf::console::CommandOverload::doc() prefix_ senf::console::OverloadedCommandNode & senf::console::CommandOverload::node() const { - SENF_ASSERT( node_ ); + SENF_ASSERT( node_, "Overload not added to any node yet" ); return *node_; } @@ -133,7 +133,7 @@ prefix_ senf::console::CommandOverload::CommandOverload() : node_(0) {} -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::SimpleCommandOverload prefix_ senf::console::SimpleCommandOverload::ptr @@ -153,7 +153,49 @@ prefix_ senf::console::SimpleCommandOverload::SimpleCommandOverload(Function fn) : fn_ (fn) {} -///////////////////////////////cci.e/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::SimpleOverloadAttributor + +prefix_ senf::console::SimpleOverloadAttributor:: +SimpleOverloadAttributor(SimpleCommandOverload::Function fn) + : overload_ (SimpleCommandOverload::create(fn)) +{} + +prefix_ senf::console::SimpleOverloadAttributor const & +senf::console::SimpleOverloadAttributor::doc(std::string const & doc) + const +{ + doc_ = doc; + return *this; +} + +prefix_ senf::console::SimpleOverloadAttributor const & +senf::console::SimpleOverloadAttributor::shortdoc(std::string const & doc) + const +{ + shortdoc_ = doc; + return *this; +} + +prefix_ senf::console::SimpleOverloadAttributor const & +senf::console::SimpleOverloadAttributor::overloadDoc(std::string const & doc) + const +{ + overload_->doc(doc); + return *this; +} + +prefix_ senf::console::OverloadedCommandNode & +senf::console::SimpleOverloadAttributor::create(DirectoryNode & dir, std::string const & name) + const +{ + OverloadedCommandNode & node (OverloadedCommandNode::insertOverload(dir, name, overload_)); + if (doc_) node.doc(*doc_); + if (shortdoc_) node.shortdoc(*shortdoc_); + return node; +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_