X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FOverloadedCommand.cci;h=596502107255c1adf080757cf2dda9a56ed48786;hb=6aae6e526573187ece558842e928578e5aa4cc4c;hp=c891fda6dec276d7d7c8928856071dcc3f3b6eaa;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/OverloadedCommand.cci b/senf/Utils/Console/OverloadedCommand.cci index c891fda..5965021 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 @@ -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; } @@ -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_; } @@ -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; +} + +/////////////////////////////cci.e/////////////////////////////////////// #undef prefix_