X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=include%2Fcaller.h;h=b5dd38ef0e63015c57af58f4508c220c0a973b6d;hb=5ee7322040d501fe55853453caa230f4550313c3;hp=4b4651b33dc11e4c01b8152de4980853787ed745;hpb=c39ccd1fdaef9ac6fd62888badc0240e8a88c55a;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/include/caller.h b/include/caller.h index 4b4651b33..b5dd38ef0 100644 --- a/include/caller.h +++ b/include/caller.h @@ -32,11 +32,20 @@ * * 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. 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. + * which completely replaces the code f r 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 class CoreExport HandlerBase0 @@ -137,7 +146,7 @@ template class CoreExport caller1 : publi { public: caller1(HandlerBase1* initial) - : caller< HandlerBase1 >::caller(initial) + : caller< HandlerBase1 >(initial) { } virtual ReturnType operator() (Param1 param1) @@ -150,7 +159,7 @@ template class CoreExpor { public: caller2(HandlerBase2* initial) - : caller< HandlerBase2 >::caller(initial) + : caller< HandlerBase2 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2) @@ -163,7 +172,7 @@ template * initial) - : caller< HandlerBase3 >::caller(initial) + : caller< HandlerBase3 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3) @@ -176,7 +185,7 @@ template * initial) - : caller< HandlerBase4 >::caller(initial) + : caller< HandlerBase4 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4) @@ -189,7 +198,7 @@ template * initial) - : caller< HandlerBase5 >::caller(initial) + : caller< HandlerBase5 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5) @@ -202,7 +211,7 @@ template * initial) - : caller< HandlerBase6 >::caller(initial) + : caller< HandlerBase6 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6) @@ -215,7 +224,7 @@ template * initial) - : caller< HandlerBase7 >::caller(initial) + : caller< HandlerBase7 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6, Param7 param7) @@ -228,7 +237,7 @@ template * initial) - : caller< HandlerBase8 >::caller(initial) + : caller< HandlerBase8 >(initial) { } virtual ReturnType operator() (Param1 param1, Param2 param2, Param3 param3, Param4 param4, Param5 param5, Param6 param6, Param7 param7, Param8 param8)