return name_;
}
-prefix_ senf::console::GenericNode::GenericNode(std::string const & name)
- : name_ (name), parent_ (0)
+prefix_ senf::console::GenericNode::GenericNode()
+ : parent_ (0)
{}
prefix_ void senf::console::GenericNode::name(std::string const & name)
name_ = name;
}
-prefix_ void senf::console::GenericNode::name(GenericNode & node, std::string const & name)
-{
- node.name_ = name;
-}
-
prefix_ boost::shared_ptr<senf::console::DirectoryNode> senf::console::GenericNode::parent()
const
{
parent_ ? parent_->shared_from_this() : ptr() );
}
+prefix_ senf::console::GenericNode::ptr senf::console::GenericNode::unlink()
+{
+ if (parent_)
+ return parent()->remove(name());
+ else
+ return thisptr();
+}
+
+prefix_ void senf::console::GenericNode::help(std::ostream & output)
+ const
+{
+ v_help(output);
+}
+
+prefix_ senf::console::GenericNode::ptr senf::console::GenericNode::thisptr()
+{
+ return shared_from_this();
+}
+
+prefix_ senf::console::GenericNode::cptr senf::console::GenericNode::thisptr()
+ const
+{
+ return shared_from_this();
+}
+
///////////////////////////////////////////////////////////////////////////
// senf::console::DirectoryNode
-prefix_ senf::console::GenericNode &
-senf::console::DirectoryNode::add(std::auto_ptr<GenericNode> node, bool uniquify)
+prefix_ senf::console::DirectoryNode::ptr senf::console::DirectoryNode::create()
{
- GenericNode::ptr p (node.release());
- add(p, uniquify);
- return *p;
+ return ptr(new DirectoryNode());
}
prefix_ senf::console::DirectoryNode &
senf::console::DirectoryNode::operator[](std::string const & name)
const
{
- return dynamic_cast<DirectoryNode&>(lookup(name));
+ return dynamic_cast<DirectoryNode&>(get(name));
}
prefix_ senf::console::CommandNode &
senf::console::DirectoryNode::operator()(std::string const & name)
const
{
- return dynamic_cast<CommandNode&>(lookup(name));
+ return dynamic_cast<CommandNode&>(get(name));
}
prefix_ senf::console::DirectoryNode &
senf::console::DirectoryNode::mkdir(std::string const & name)
{
- return static_cast<DirectoryNode &>(
- add(std::auto_ptr<GenericNode>(new DirectoryNode(name))));
+ return add(name, create());
}
prefix_ senf::console::DirectoryNode::ChildrenRange senf::console::DirectoryNode::children()
return boost::make_iterator_range(children_.begin(), children_.end());
}
-prefix_ senf::console::DirectoryNode::DirectoryNode(std::string const & name)
- : GenericNode(name)
+prefix_ senf::console::DirectoryNode::DirectoryNode()
+{}
+
+prefix_ senf::console::DirectoryNode &
+senf::console::DirectoryNode::doc(std::string const & doc)
+{
+ doc_ = doc;
+ return *this;
+}
+
+prefix_ senf::console::DirectoryNode::ptr senf::console::DirectoryNode::thisptr()
+{
+ return boost::static_pointer_cast<DirectoryNode>(shared_from_this());
+}
+
+prefix_ senf::console::DirectoryNode::cptr senf::console::DirectoryNode::thisptr()
+ const
+{
+ return boost::static_pointer_cast<DirectoryNode const>(shared_from_this());
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::console::SyntaxErrorException
+
+prefix_ senf::console::SyntaxErrorException::SyntaxErrorException(std::string const & msg)
+ : Exception(msg)
{}
///////////////////////////////////////////////////////////////////////////
// senf::console::CommandNode
-prefix_ senf::console::CommandNode::CommandNode(std::string const & name)
- : GenericNode(name)
+prefix_ senf::console::CommandNode::ptr senf::console::CommandNode::thisptr()
+{
+ return boost::static_pointer_cast<CommandNode>(shared_from_this());
+}
+
+prefix_ senf::console::CommandNode::cptr senf::console::CommandNode::thisptr()
+ const
+{
+ return boost::static_pointer_cast<CommandNode const>(shared_from_this());
+}
+
+prefix_ senf::console::CommandNode::CommandNode()
+{}
+
+prefix_ void senf::console::CommandNode::operator()(std::ostream & output,
+ Arguments const & arguments)
+ const
+{
+ v_execute(output, arguments);
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::console::SimpleCommandNode
+
+prefix_ senf::console::SimpleCommandNode::SimpleCommandNode(Function const & fn)
+ : fn_ (fn)
{}
+prefix_ senf::console::SimpleCommandNode::ptr
+senf::console::SimpleCommandNode::create(Function const & fn)
+{
+ return ptr(new SimpleCommandNode(fn));
+}
+
+prefix_ senf::console::SimpleCommandNode &
+senf::console::SimpleCommandNode::doc(std::string const & doc)
+{
+ doc_ = doc;
+ return *this;
+}
+
+prefix_ senf::console::SimpleCommandNode::ptr senf::console::SimpleCommandNode::thisptr()
+{
+ return boost::static_pointer_cast<SimpleCommandNode>(shared_from_this());
+}
+
+prefix_ senf::console::SimpleCommandNode::cptr senf::console::SimpleCommandNode::thisptr()
+ const
+{
+ return boost::static_pointer_cast<SimpleCommandNode const>(shared_from_this());
+}
+
///////////////////////////////cci.e///////////////////////////////////////
#undef prefix_