X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FScopedDirectory.cti;h=a4bc816b40273645223bdfd2b890c7fb24c1f582;hb=4101c2b818ec67e7469ebb44f030eed2185c4ab0;hp=69b70faab34dabf854777a7da2860a7156c4a910;hpb=084d18afd1abb3c6b19de612dbdf4dbc40ffd795;p=senf.git diff --git a/senf/Utils/Console/ScopedDirectory.cti b/senf/Utils/Console/ScopedDirectory.cti index 69b70fa..a4bc816 100644 --- a/senf/Utils/Console/ScopedDirectory.cti +++ b/senf/Utils/Console/ScopedDirectory.cti @@ -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 @@ -26,104 +26,84 @@ //#include "ScopedDirectory.ih" // Custom includes -#include #define prefix_ inline -///////////////////////////////cti.p/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////// -// senf::console::OwnerNodeCreateTraits::Creator - -template -prefix_ typename senf::console::OwnerNodeCreateTraits::result_type -senf::console::OwnerNodeCreateTraits::Creator::create(DirectoryNode & node, - Owner & owner, - std::string const & name, - Object & ob) -{ - return senf_console_add_node(node, owner, name, ob, 0); -} - -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::ScopedDirectory template prefix_ senf::console::ScopedDirectory::ScopedDirectory(Owner * owner) : owner_ (owner) { - SENF_ASSERT(owner_); + SENF_ASSERT(owner_, "ScopedDirectory owner is mandatory"); } template -template -prefix_ typename senf::console::OwnerNodeCreateTraits::result_type -senf::console::ScopedDirectory::add(std::string const & name, Object const & ob) +template +prefix_ NodeType & senf::console::ScopedDirectory::add(std::string const & name, + boost::shared_ptr othernode) { - return OwnerNodeCreateTraits::Creator::create(node(), *owner_, name, ob); + return node().add(name, othernode); } template -template -prefix_ typename senf::console::OwnerNodeCreateTraits::result_type -senf::console::ScopedDirectory::add(std::string const & name, Object & ob) -{ - return OwnerNodeCreateTraits::Creator::create(node(), *owner_, name, ob); -} - -#ifndef DOXYGEN - -template -prefix_ senf::console::SimpleCommandNode & senf::console:: -senf_console_add_node(DirectoryNode & node, Owner & , std::string const & name, - SimpleCommandNode::Function fn, int) +template +prefix_ NodeType & senf::console::ScopedDirectory:: +add(std::string const & name, NodeType & othernode, + typename boost::enable_if< boost::is_convertible >::type *) { - return node.add(name,fn); + return node().add(name,othernode); } template -prefix_ senf::console::SimpleCommandNode & senf::console:: -senf_console_add_node(DirectoryNode & node, Owner & owner, std::string const & name, - void (Owner::*fn)(std::ostream &, ParseCommandInfo const &), int) +template +prefix_ typename Factory::result_type senf::console::ScopedDirectory:: +add(std::string const & name, Factory const & factory, + typename boost::enable_if< boost::is_convertible >::type *) { - return node.add(name, boost::bind(fn,boost::ref(owner),_1,_2)); + return factory.create(*owner_, name, node()); } template -prefix_ senf::console::DirectoryNode & -senf::console::senf_console_add_node(DirectoryNode & node, Owner & owner, - std::string const & name, DirectoryNode & dir, int) +template +prefix_ typename Factory::result_type senf::console::ScopedDirectory:: +add(std::string const & name, Factory const & factory, + typename boost::enable_if< boost::is_convertible >::type *, + typename boost::disable_if< boost::is_convertible >::type *) { - return node.add(name, dir.thisptr()); + return node().add(name, factory); } -template -prefix_ senf::console::DirectoryNode & senf::console:: -senf_console_add_node(DirectoryNode & dir, std::string const & name, Node const & node, int, - typename boost::enable_if< boost::is_convertible >::type *) -{ - return dir.add(name, node.node().thisptr()); -} +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::ScopedDirectory -#endif -/////////////////////////////////////////////////////////////////////////// -// senf::console::ScopedDirectory +template +prefix_ NodeType & senf::console::ScopedDirectory::add(std::string const & name, + boost::shared_ptr othernode) +{ + return node().add(name,othernode); +} -template -prefix_ typename senf::console::NodeCreateTraits::result_type -senf::console::ScopedDirectory::add(std::string const & name, Object const & ob) +template +prefix_ NodeType & senf::console::ScopedDirectory:: +add(std::string const & name, NodeType & othernode, + typename boost::enable_if< boost::is_convertible >::type *) { - return node().add(name, ob); + return node().add(name,othernode); } -template -prefix_ typename senf::console::NodeCreateTraits::result_type -senf::console::ScopedDirectory::add(std::string const & name, Object & ob) +template +prefix_ typename Factory::result_type senf::console::ScopedDirectory:: +add(std::string const & name, Factory const & factory, + typename boost::enable_if< boost::is_convertible >::type *) { - return node().add(name, ob); + return node().add(name,factory); } -///////////////////////////////cti.e/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_