diff options
author | Peter Powell <petpow@saberuk.com> | 2017-11-25 13:01:53 +0000 |
---|---|---|
committer | Peter Powell <petpow@saberuk.com> | 2017-11-25 13:38:02 +0000 |
commit | fa95bb4b0d5aed9204d469a36946a9839a7ffaa2 (patch) | |
tree | 95ff9727251b1081c5348342b6fde619d346b8aa /include | |
parent | 6abc789577a86ffcdce8fae81b37f825d9ca4226 (diff) |
Convert the remaining things away from the caller/handler API.
Diffstat (limited to 'include')
-rw-r--r-- | include/caller.h | 355 | ||||
-rw-r--r-- | include/compat.h | 18 | ||||
-rw-r--r-- | include/cull_list.h | 12 | ||||
-rw-r--r-- | include/inspircd.h | 1 |
4 files changed, 10 insertions, 376 deletions
diff --git a/include/caller.h b/include/caller.h deleted file mode 100644 index dfa6ccebb..000000000 --- a/include/caller.h +++ /dev/null @@ -1,355 +0,0 @@ -/* - * InspIRCd -- Internet Relay Chat Daemon - * - * Copyright (C) 2009 Daniel De Graaf <danieldg@inspircd.org> - * Copyright (C) 2007 Craig Edwards <craigedwards@brainbox.cc> - * Copyright (C) 2012 Adam <Adam@anope.org> - * - * This file is part of InspIRCd. InspIRCd is free software: you can - * redistribute it and/or modify it under the terms of the GNU General Public - * License as published by the Free Software Foundation, version 2. - * - * This program is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS - * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more - * details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see <http://www.gnu.org/licenses/>. - */ - - -#pragma once - -#if defined HAS_CXX11_VARIADIC_TEMPLATES - -template<typename ReturnType, typename... Args> class CoreExport Handler : public classbase -{ - public: - virtual ~Handler() { } - virtual ReturnType Call(Args...) = 0; -}; - -template<typename ReturnType, typename... Args> class CoreExport Caller -{ - public: - Handler<ReturnType, Args...>* target; - - Caller(Handler<ReturnType, Args...>* initial) : target(initial) { } - virtual ~Caller() { } - - virtual ReturnType operator()(const Args&... params) - { - return this->target->Call(params...); - } -}; - -/* Below here is compat with the old API */ -#define HandlerBase0 Handler -#define HandlerBase1 Handler -#define HandlerBase2 Handler -#define HandlerBase3 Handler -#define HandlerBase4 Handler -#define HandlerBase5 Handler -#define HandlerBase6 Handler -#define HandlerBase7 Handler -#define HandlerBase8 Handler - -#define caller1 Caller -#define caller2 Caller -#define caller3 Caller -#define caller4 Caller -#define caller5 Caller -#define caller6 Caller -#define caller7 Caller -#define caller8 Caller - -#define DEFINE_HANDLER0(NAME, RETURN) \ - class CoreExport NAME : public Handler<RETURN> { public: RETURN Call() CXX11_OVERRIDE; } - -#define DEFINE_HANDLER1(NAME, RETURN, V1) \ - class CoreExport NAME : public Handler<RETURN, V1> { public: RETURN Call(V1) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER2(NAME, RETURN, V1, V2) \ - class CoreExport NAME : public Handler<RETURN, V1, V2> { public: RETURN Call(V1, V2) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER3(NAME, RETURN, V1, V2, V3) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3> { public: RETURN Call(V1, V2, V3) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER4(NAME, RETURN, V1, V2, V3, V4) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3, V4> { public: RETURN Call(V1, V2, V3, V4) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER5(NAME, RETURN, V1, V2, V3, V4, V5) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3, V4, V5> { public: RETURN Call(V1, V2, V3, V4, V5) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER6(NAME, RETURN, V1, V2, V3, V4, V5, V6) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3, V4, V5, V6> { public: RETURN Call(V1, V2, V3, V4, V5, V6) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER7(NAME, RETURN, V1, V2, V3, V4, V5, V6, V7) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3, V4, V5, V6, V7> { public: RETURN Call(V1, V2, V3, V4, V5, V6, V7) CXX11_OVERRIDE; } - -#define DEFINE_HANDLER8(NAME, RETURN, V1, V2, V3, V4, V5, V6, V7, V8) \ - class CoreExport NAME : public Handler<RETURN, V1, V2, V3, V4, V5, V6, V7, V8> { public: RETURN Call(V1, V2, V3, V4, V5, V6, V7, V8) CXX11_OVERRIDE; } - -#else - -/** The templates below can be auto generated by tools/create_templates.pl. - * They are used to represent a functor with a given number of parameters and - * a specific return type. To prevent passing the wrong number of parameters - * and have the compiler detect this error at build-time, each class is numbered - * according to the number of parameters it takes, e.g. caller0, caller1, caller2. - * These have been generated from zero parameters to eight. - * - * If you want to declare a functor which takes two parameters, a User and a Channel, - * and returns bool, simply create it like this: - * - * caller2<bool, User*, Channel*> MyFunction; - * - * and initialize it correctly, when placed into a class you will be able to call it: - * - * bool n = someclass->MyFunction(someuser, somechan); - * - * These functor templates work this way so that you can simply and easily allow - * for these class methods to be overridden from within a module, e.g. have a module - * which completely replaces the code for IsNick, etc. For example, with the example - * above: - * - * MyNewFunction replaceme(ServerInstance); - * - * someclass->MyFunction = \&replaceme; - * - * After this point, calls to someclass->MyFunction will call the new code in your - * replacement functor. - * - * This is a very powerful feature which should be considered 'advanced' and not for - * beginners. If you do not understand these templates, STAY AWAY from playing with - * this until you do, as if you get this wrong, this can generate some pretty long - * winded and confusing error messages at compile time. - */ -template <typename ReturnType> class CoreExport HandlerBase0 : public classbase -{ - public: - virtual ReturnType Call() = 0; - virtual ~HandlerBase0() { } -}; - -template <typename ReturnType, typename Param1> class CoreExport HandlerBase1 : public classbase -{ - public: - virtual ReturnType Call(Param1) = 0; - virtual ~HandlerBase1() { } -}; - -template <typename ReturnType, typename Param1, typename Param2> class CoreExport HandlerBase2 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2) = 0; - virtual ~HandlerBase2() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3> class CoreExport HandlerBase3 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3) = 0; - virtual ~HandlerBase3() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4> class CoreExport HandlerBase4 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3, Param4) = 0; - virtual ~HandlerBase4() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5> class CoreExport HandlerBase5 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3, Param4, Param5) = 0; - virtual ~HandlerBase5() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6> class CoreExport HandlerBase6 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3, Param4, Param5, Param6) = 0; - virtual ~HandlerBase6() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6, typename Param7> class CoreExport HandlerBase7 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3, Param4, Param5, Param6, Param7) = 0; - virtual ~HandlerBase7() { } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6, typename Param7, typename Param8> class CoreExport HandlerBase8 : public classbase -{ - public: - virtual ReturnType Call(Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8) = 0; - virtual ~HandlerBase8() { } -}; - -template <typename HandlerType> class caller -{ - public: - HandlerType* target; - - caller(HandlerType* initial) - : target(initial) - { } - - virtual ~caller() { } -}; - -template <typename ReturnType> class caller0 : public caller< HandlerBase0<ReturnType> > -{ - public: - caller0(HandlerBase0<ReturnType>* initial) - : caller< HandlerBase0<ReturnType> >::caller(initial) - { } - - ReturnType operator() () - { - return this->target->Call(); - } -}; - -template <typename ReturnType, typename Param1> class caller1 : public caller< HandlerBase1<ReturnType, Param1> > -{ - public: - caller1(HandlerBase1<ReturnType, Param1>* initial) - : caller< HandlerBase1<ReturnType, Param1> >(initial) - { } - - ReturnType operator() (Param1 param1) - { - return this->target->Call(param1); - } -}; - -template <typename ReturnType, typename Param1, typename Param2> class caller2 : public caller< HandlerBase2<ReturnType, Param1, Param2> > -{ - public: - caller2(HandlerBase2<ReturnType, Param1, Param2>* initial) - : caller< HandlerBase2<ReturnType, Param1, Param2> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2) - { - return this->target->Call(param1, param2); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3> class caller3 : public caller< HandlerBase3<ReturnType, Param1, Param2, Param3> > -{ - public: - caller3(HandlerBase3<ReturnType, Param1, Param2, Param3>* initial) - : caller< HandlerBase3<ReturnType, Param1, Param2, Param3> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3) - { - return this->target->Call(param1, param2, param3); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4> class caller4 : public caller< HandlerBase4<ReturnType, Param1, Param2, Param3, Param4> > -{ - public: - caller4(HandlerBase4<ReturnType, Param1, Param2, Param3, Param4>* initial) - : caller< HandlerBase4<ReturnType, Param1, Param2, Param3, Param4> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4) - { - return this->target->Call(param1, param2, param3, param4); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5> class caller5 : public caller< HandlerBase5<ReturnType, Param1, Param2, Param3, Param4, Param5> > -{ - public: - caller5(HandlerBase5<ReturnType, Param1, Param2, Param3, Param4, Param5>* initial) - : caller< HandlerBase5<ReturnType, Param1, Param2, Param3, Param4, Param5> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5) - { - return this->target->Call(param1, param2, param3, param4, param5); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6> class caller6 : public caller< HandlerBase6<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6> > -{ - public: - caller6(HandlerBase6<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6>* initial) - : caller< HandlerBase6<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6) - { - return this->target->Call(param1, param2, param3, param4, param5, param6); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6, typename Param7> class caller7 : public caller< HandlerBase7<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7> > -{ - public: - caller7(HandlerBase7<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7>* initial) - : caller< HandlerBase7<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6, Param7 param7) - { - return this->target->Call(param1, param2, param3, param4, param5, param6, param7); - } -}; - -template <typename ReturnType, typename Param1, typename Param2, typename Param3, typename Param4, typename Param5, typename Param6, typename Param7, typename Param8> class caller8 : public caller< HandlerBase8<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8> > -{ - public: - caller8(HandlerBase8<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8>* initial) - : caller< HandlerBase8<ReturnType, Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8> >(initial) - { } - - ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6, Param7 param7, Param8 param8) - { - return this->target->Call(param1, param2, param3, param4, param5, param6, param7, param8); - } -}; - -/** These shorthand macros are used to define a functor class which only implements Call(). Most functors are like this. - * If you want something more complex, define them by hand. - * - * The first parameter to each macro is the class name to define, the second parameter is the return value of Call(). - * The following parameters are the parameter types for Call(), and again, the macro is numbered to match the number of - * parameters, to prevent mistakes. - */ -#define DEFINE_HANDLER0(NAME, RETURN) \ - class CoreExport NAME : public HandlerBase0<RETURN> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(); } - -#define DEFINE_HANDLER1(NAME, RETURN, V1) \ - class CoreExport NAME : public HandlerBase1<RETURN, V1> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1); } - -#define DEFINE_HANDLER2(NAME, RETURN, V1, V2) \ - class CoreExport NAME : public HandlerBase2<RETURN, V1, V2> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2); } - -#define DEFINE_HANDLER3(NAME, RETURN, V1, V2, V3) \ - class CoreExport NAME : public HandlerBase3<RETURN, V1, V2, V3> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3); } - -#define DEFINE_HANDLER4(NAME, RETURN, V1, V2, V3, V4) \ - class CoreExport NAME : public HandlerBase4<RETURN, V1, V2, V3, V4> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3, V4); } - -#define DEFINE_HANDLER5(NAME, RETURN, V1, V2, V3, V4, V5) \ - class CoreExport NAME : public HandlerBase5<RETURN, V1, V2, V3, V4, V5> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3, V4, V5); } - -#define DEFINE_HANDLER6(NAME, RETURN, V1, V2, V3, V4, V5, V6) \ - class CoreExport NAME : public HandlerBase6<RETURN, V1, V2, V3, V4, V5, V6> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3, V4, V5, V6); } - -#define DEFINE_HANDLER7(NAME, RETURN, V1, V2, V3, V4, V5, V6, V7) \ - class CoreExport NAME : public HandlerBase7<RETURN, V1, V2, V3, V4, V5, V6, V7> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3, V4, V5, V6, V7); } - -#define DEFINE_HANDLER8(NAME, RETURN, V1, V2, V3, V4, V5, V6, V7, V8) \ - class CoreExport NAME : public HandlerBase8<RETURN, V1, V2, V3, V4, V5, V6, V7, V8> { public: NAME() { } virtual ~NAME() { } virtual RETURN Call(V1, V2, V3, V4, V5, V6, V7, V8); } - -#endif diff --git a/include/compat.h b/include/compat.h index 4678de12a..7a95e9050 100644 --- a/include/compat.h +++ b/include/compat.h @@ -77,24 +77,6 @@ #endif /** - * These macros enable the detection of the C++11 variadic templates in - * compilers which support them. - */ -#if __cplusplus >= 201103L -# define HAS_CXX11_VARIADIC_TEMPLATES -#elif defined __clang__ -# if __has_feature(cxx_variadic_templates) -# define HAS_CXX11_VARIADIC_TEMPLATES -# endif -#elif (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4) -# if defined __GXX_EXPERIMENTAL_CXX0X__ -# define HAS_CXX11_VARIADIC_TEMPLATES -# endif -#elif _MSC_FULL_VER >= 170051025 -# define HAS_CXX11_VARIADIC_TEMPLATES -#endif - -/** * This macro allows methods to be marked as deprecated. To use this, wrap the * method declaration in the header file with the macro. */ diff --git a/include/cull_list.h b/include/cull_list.h index ac64dced2..f5087f512 100644 --- a/include/cull_list.h +++ b/include/cull_list.h @@ -43,14 +43,22 @@ class CoreExport CullList void Apply(); }; +/** Represents an action which is executable by an action list */ +class CoreExport ActionBase : public classbase +{ + public: + /** Executes this action. */ + virtual void Call() = 0; +}; + class CoreExport ActionList { - std::vector<HandlerBase0<void>*> list; + std::vector<ActionBase*> list; public: /** Adds an item to the list */ - void AddAction(HandlerBase0<void>* item) { list.push_back(item); } + void AddAction(ActionBase* item) { list.push_back(item); } /** Runs the items */ diff --git a/include/inspircd.h b/include/inspircd.h index 00a705dd0..7e9007a1d 100644 --- a/include/inspircd.h +++ b/include/inspircd.h @@ -68,7 +68,6 @@ struct fakederef #include "convto.h" #include "dynref.h" #include "consolecolors.h" -#include "caller.h" #include "cull_list.h" #include "extensible.h" #include "fileutils.h" |