X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FParsedCommand.cci;h=c2aaf07b498659868f0db22bd55521e14e9ad51e;hb=a29a9ca13ed8105681968759066ed7788c818cb8;hp=5d168ecafeef6510e5f6eaa2ecb567ed0440440d;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/ParsedCommand.cci b/senf/Utils/Console/ParsedCommand.cci index 5d168ec..c2aaf07 100644 --- a/senf/Utils/Console/ParsedCommand.cci +++ b/senf/Utils/Console/ParsedCommand.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 @@ -61,70 +61,66 @@ prefix_ void senf::console::ParsedCommandOverloadBase::doc(std::string const & d // senf::console::ParsedCommandAttributorBase prefix_ senf::console::OverloadedCommandNode & -senf::console::ParsedCommandAttributorBase::node() +senf::console::ParsedCommandAttributorBase::create(DirectoryNode & dir, + std::string const & name) const { - return overload_.node(); + OverloadedCommandNode & node (OverloadedCommandNode::insertOverload(dir, name, overload_)); + if (doc_) node.doc(*doc_); + if (shortdoc_) node.shortdoc(*shortdoc_); + return node; } -prefix_ senf::console::ParsedCommandAttributorBase::operator OverloadedCommandNode &() - const -{ - return node(); -} +prefix_ senf::console::ParsedCommandAttributorBase:: +ParsedCommandAttributorBase(ParsedCommandOverloadBase::ptr overload, unsigned index) + : overload_ (overload), index_ (index) +{} prefix_ senf::console::ParsedCommandAttributorBase:: -ParsedCommandAttributorBase(ParsedCommandOverloadBase & overload, unsigned index) - : overload_ (overload), index_ (index) +ParsedCommandAttributorBase(ParsedCommandAttributorBase const & other, unsigned index) + : overload_ (other.overload_), index_ (index), doc_ (other.doc_), shortdoc_ (other.shortdoc_) {} prefix_ senf::console::ParsedCommandOverloadBase & senf::console::ParsedCommandAttributorBase::overload() const { - return overload_; + return *overload_; } prefix_ void senf::console::ParsedCommandAttributorBase::argName(std::string const & name) - const { overload().arg(index_).name = name; } prefix_ void senf::console::ParsedCommandAttributorBase::argDoc(std::string const & doc) - const { overload().arg(index_).doc = doc; } prefix_ void senf::console::ParsedCommandAttributorBase::typeName(std::string const & doc) - const { overload().arg(index_).type = doc; } prefix_ void senf::console::ParsedCommandAttributorBase::defaultDoc(std::string const & doc) - const { overload().arg(index_).defaultDoc = doc; } prefix_ void senf::console::ParsedCommandAttributorBase::overloadDoc(std::string const & doc) - const { overload().doc(doc); } prefix_ void senf::console::ParsedCommandAttributorBase::nodeDoc(std::string const & doc) - const { - node().doc(doc); + doc_ = doc; } prefix_ void senf::console::ParsedCommandAttributorBase::shortDoc(std::string const & doc) - const { - node().shortdoc(doc); + shortdoc_ = doc; } ///////////////////////////////cci.e///////////////////////////////////////