X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Console%2FNode.cci;h=11d212e3d2edbb11b3e73a2484ec87b486225448;hb=748363b235c4651b3992cc291a95dc2e18e45724;hp=43954f3b761abfbe353b8f2cc1fa648c436139bd;hpb=c70f7413515b513656f850f51a3cc2ea9d776a37;p=senf.git diff --git a/Console/Node.cci b/Console/Node.cci index 43954f3..11d212e 100644 --- a/Console/Node.cci +++ b/Console/Node.cci @@ -92,18 +92,45 @@ prefix_ senf::console::DirectoryNode::ptr senf::console::DirectoryNode::create() return ptr(new DirectoryNode()); } +prefix_ bool senf::console::DirectoryNode::hasChild(std::string const & name) + const +{ + ChildMap::const_iterator i (children_.find(name)); + return i != children_.end(); +} + +prefix_ senf::console::DirectoryNode & +senf::console::DirectoryNode::getDirectory(std::string const & name) + const +{ + try { + return dynamic_cast(get(name)); + } + SENF_WRAP_EXC(std::bad_cast) +} + prefix_ senf::console::DirectoryNode & senf::console::DirectoryNode::operator[](std::string const & name) const { - return dynamic_cast(get(name)); + return getDirectory(name); +} + +prefix_ senf::console::CommandNode & +senf::console::DirectoryNode::getCommand(std::string const & name) + const +{ + try { + return dynamic_cast(get(name)); + } + SENF_WRAP_EXC(std::bad_cast) } prefix_ senf::console::CommandNode & senf::console::DirectoryNode::operator()(std::string const & name) const { - return dynamic_cast(get(name)); + return getCommand(name); } prefix_ senf::console::DirectoryNode & @@ -140,6 +167,13 @@ prefix_ senf::console::DirectoryNode::cptr senf::console::DirectoryNode::thisptr } /////////////////////////////////////////////////////////////////////////// +// senf::console::SyntaxErrorException + +prefix_ senf::console::SyntaxErrorException::SyntaxErrorException(std::string const & msg) + : Exception(msg) +{} + +/////////////////////////////////////////////////////////////////////////// // senf::console::CommandNode prefix_ senf::console::CommandNode::ptr senf::console::CommandNode::thisptr() @@ -156,15 +190,23 @@ prefix_ senf::console::CommandNode::cptr senf::console::CommandNode::thisptr() prefix_ senf::console::CommandNode::CommandNode() {} -/////////////////////////////////////////////////////////////////////////// -// senf::console::SimpleCommandNode +prefix_ void senf::console::CommandNode::execute(std::ostream & output, + ParseCommandInfo const & command) + const +{ + v_execute(output, command); +} -prefix_ void senf::console::SimpleCommandNode::operator()(std::ostream & output, - Arguments const & arguments) +prefix_ void senf::console::CommandNode::operator()(std::ostream & output, + ParseCommandInfo const & command) + const { - fn_(output, arguments); + execute(output, command); } +/////////////////////////////////////////////////////////////////////////// +// senf::console::SimpleCommandNode + prefix_ senf::console::SimpleCommandNode::SimpleCommandNode(Function const & fn) : fn_ (fn) {} @@ -182,6 +224,17 @@ senf::console::SimpleCommandNode::doc(std::string const & doc) return *this; } +prefix_ senf::console::SimpleCommandNode::ptr senf::console::SimpleCommandNode::thisptr() +{ + return boost::static_pointer_cast(shared_from_this()); +} + +prefix_ senf::console::SimpleCommandNode::cptr senf::console::SimpleCommandNode::thisptr() + const +{ + return boost::static_pointer_cast(shared_from_this()); +} + ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_