// $Id$ // // Copyright (C) 2008 // Fraunhofer Institute for Open Communication Systems (FOKUS) // // The contents of this file are subject to the Fraunhofer FOKUS Public License // Version 1.0 (the "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // http://senf.berlios.de/license.html // // The Fraunhofer FOKUS Public License Version 1.0 is based on, // but modifies the Mozilla Public License Version 1.1. // See the full license text for the amendments. // // Software distributed under the License is distributed on an "AS IS" basis, // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License // for the specific language governing rights and limitations under the License. // // The Original Code is Fraunhofer FOKUS code. // // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. // (registered association), Hansastraße 27 c, 80686 Munich, Germany. // All Rights Reserved. // // Contributor(s): // Stefan Bund /** \file \brief ParsedCommand internal header */ #ifndef IH_SENF_Scheduler_Console_ParsedCommand_ #define IH_SENF_Scheduler_Console_ParsedCommand_ 1 // Custom includes #include #include #include #include "Parse.hh" //-///////////////////////////////////////////////////////////////////////////////////////////////// namespace senf { namespace console { template < class FunctionTraits, class ReturnType=typename FunctionTraits::result_type, unsigned arity=FunctionTraits::arity > class ParsedCommandOverload; template < class Overload, unsigned index=0, bool flag=(index < unsigned(Overload::traits::arity)) > class ParsedArgumentAttributor; namespace detail { /** \brief Internal: Argument information structure This class is used to hold argument information for automatically parsed commands. \see ParsedCommandOverloadBase */ struct ArgumentInfoBase : public intrusive_refcount { typedef boost::intrusive_ptr ptr; std::string type; std::string name; std::string defaultDoc; bool hasDefault; std::string doc; bool singleToken; explicit ArgumentInfoBase(std::string const & type, bool singleToken=false); virtual ~ArgumentInfoBase(); virtual std::string defaultValueStr() const = 0; }; /** \brief Internal: Argument information structure This class is used to hold argument information for automatically parsed commands. \see ParsedCommandOverloadBase */ template struct ArgumentInfo : public ArgumentInfoBase { typedef boost::intrusive_ptr ptr; typedef boost::function Parser; static ptr create(); ArgumentInfo(); ParameterType defaultValue; Parser parser; virtual std::string defaultValueStr() const; }; #ifndef DOXYGEN // FirstArgType returns void, if the function has no arguments, otherwise it returns arg1_type template 0)> struct FirstArgType { typedef void type; }; template struct FirstArgType { typedef typename Traits::arg1_type type; }; template ::value> struct ParsedCommandTraits_i { static const bool is_callable = false; static const bool is_member = false; static const bool is_simple = false; }; template struct ParsedCommandTraits_i { typedef FunctionP base_type; typedef typename senf::remove_any_pointer::type function_type; typedef boost::function_traits base_traits; typedef typename FirstArgType::type first_arg_type; static const bool has_ostream_arg = boost::is_same::value; typedef typename boost::mpl::if_c< has_ostream_arg, typename function_traits_remove_arg::type, base_traits> ::type traits; typedef typename senf::remove_cvref::type result_type; static const bool is_callable = true; static const bool is_member = boost::is_member_pointer::value; static const bool is_simple = false; typedef typename senf::member_class::type class_type; typedef ParsedCommandOverload Overload; typedef ParsedArgumentAttributor Attributor; }; // Disable auto-parsing for ParseCommandInfo arg -> register manually parsed command template struct ParsedCommandTraits_i { static const bool is_simple = true; }; template struct ParsedCommandTraits : public ParsedCommandTraits_i< FunctionP, typename senf::remove_any_pointer::type > {}; struct ParsedCommandAddNodeAccess; // What is THIS about ?? // Ok, here's the dope: parsed commands may optionally have an std::ostream & first argument. If // this argument is given, then the function will be called with the console output stream as // it's first argument. // // This is implemented in the following way: ParsedCommandOverload (the class responsible for // calling the callback) will ALWAYS pass the stream as first argument. If the user callback // expects os as it's first argument, 'ignoreOneArg' will be false and the user supplied // function will be directly passed to ParsedCommandOverload. // // If however, it does NOT take an std::ostream first argument, 'ignoreOneArg' will be true and // the create member will use boost::bind to DROP the first argument. template struct CreateParsedCommandOverload {}; template struct CreateParsedCommandOverload { typedef typename Traits::traits traits; template static typename senf::console::ParsedCommandOverload::ptr create(Function fn) { return senf::console::ParsedCommandOverload::create(fn); }; }; # define BOOST_PP_ITERATION_PARAMS_1 (4, (0, SENF_CONSOLE_MAX_COMMAND_ARITY, \ SENF_ABSOLUTE_INCLUDE_PATH(Utils/Console/ParsedCommand.mpp), \ 4)) # include BOOST_PP_ITERATE() #endif }}} //-///////////////////////////////////////////////////////////////////////////////////////////////// #endif // Local Variables: // mode: c++ // fill-column: 100 // comment-column: 40 // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" // End: