X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Console%2FParsedCommand.ih;h=90231c20dfeb69d4673b84a90e6b12945bf2c6a2;hb=fa5eaa97c8593e3587c87f25adb14f7f91f31f37;hp=d8a72d28ab5715739957ddca477e4aa97c8d3138;hpb=63c40810b93b4d8f3d6dad5f987adc5f2bf5b5ed;p=senf.git diff --git a/Console/ParsedCommand.ih b/Console/ParsedCommand.ih index d8a72d2..90231c2 100644 --- a/Console/ParsedCommand.ih +++ b/Console/ParsedCommand.ih @@ -27,15 +27,33 @@ #define IH_ParsedCommand_ 1 // Custom includes +#include +#include +#include "Parse.hh" ///////////////////////////////ih.p//////////////////////////////////////// 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 { -#ifndef DOXYGEN + /** \brief Internal: Argument information structure + + This class is used to hold argument information for automatically parsed commands. + \see ParsedCommandOverloadBase + */ struct ArgumentInfoBase : public intrusive_refcount { @@ -43,6 +61,7 @@ namespace detail { std::string type; std::string name; + std::string defaultDoc; bool hasDefault; std::string doc; @@ -51,23 +70,30 @@ namespace detail { 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; }; - template ::value> - struct ParsedCommandTraits - {}; +#ifndef DOXYGEN // FirstArgType returns void, if the function has no arguments, otherwise it returns arg1_type @@ -83,10 +109,14 @@ namespace detail { typedef typename Traits::arg1_type type; }; - template - struct ParsedCommandTraits + template ::value> + struct ParsedCommandTraits_i + {}; + + template + struct ParsedCommandTraits_i { - typedef Function base_type; + 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; @@ -99,24 +129,28 @@ namespace detail { base_traits> ::type traits; + typedef typename senf::remove_cvref::type result_type; + static const bool is_member = boost::is_member_pointer::value; typedef typename senf::member_class::type class_type; - }; - template - struct CheckVoidReturn - { - template - static void call(Fn fn, std::ostream & os); + typedef ParsedCommandOverload Overload; + typedef ParsedArgumentAttributor Attributor; }; - template <> - struct CheckVoidReturn - { - template - static void call(Fn fn, std::ostream & os); - }; + // Disable auto-parsing for ParseCommandInfo arg -> register manually parsed command + template + struct ParsedCommandTraits_i + {}; + + template + struct ParsedCommandTraits + : public ParsedCommandTraits_i< FunctionP, + typename senf::remove_any_pointer::type > + {}; + + struct ParsedCommandAddNodeAccess; #endif