engineAPI.h 179 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) 2012 GarageGames, LLC
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to
  6. // deal in the Software without restriction, including without limitation the
  7. // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  8. // sell copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  20. // IN THE SOFTWARE.
  21. //-----------------------------------------------------------------------------
  22. #ifndef _ENGINEAPI_H_
  23. #define _ENGINEAPI_H_
  24. #ifndef _CONSOLETYPES_H_
  25. #include "console/consoleTypes.h"
  26. #endif
  27. #ifndef _CONSOLE_H_
  28. #include "console/console.h"
  29. #endif
  30. #ifndef _STRINGFUNCTIONS_H_
  31. #include "core/strings/stringFunctions.h"
  32. #endif
  33. #ifndef _SIMOBJECT_H_
  34. #include "console/simObject.h"
  35. #endif
  36. #ifndef _ENGINEFUNCTIONS_H_
  37. #include "console/engineFunctions.h"
  38. #endif
  39. // Whatever types are used in API definitions, their DECLAREs must be visible to the
  40. // macros. We include the basic primitive and struct types here.
  41. #ifndef _ENGINEPRIMITIVES_H_
  42. #include "console/enginePrimitives.h"
  43. #endif
  44. #ifndef _ENGINESTRUCTS_H_
  45. #include "console/engineStructs.h"
  46. #endif
  47. /// @file
  48. /// Definitions for exposing engine functionality to the control layer.
  49. ///
  50. /// This file provides a convenience layer around the underlying engine interop system (which at
  51. /// the moment still includes the legacy TorqueScript interop a.k.a. "console system"). The
  52. /// macros exposed here will automatically take care of all marshalling, value type constraints,
  53. /// reflection info instancing, etc. involved in defining engine API call-ins and call-outs.
  54. ///
  55. /// @note At the moment, this file supplies both the legacy TorqueScript console system as well
  56. /// as the new engine export system with the structures and information they need. In the
  57. /// near future, the console-based parts will get purged. This will not result in visible
  58. /// changes to users of the functionality here except for the string-based marshalling
  59. /// functions currently exposed (which will also disappear).
  60. //TODO: Disable warning for extern "C" functions returning UDTs for now; need to take a closer look at this
  61. #pragma warning( disable : 4190 )
  62. // Disable some VC warnings that are irrelevant to us.
  63. #pragma warning( disable : 4510 ) // default constructor could not be generated; all the Args structures are never constructed by us
  64. #pragma warning( disable : 4610 ) // can never be instantiated; again Args is never constructed by us
  65. namespace engineAPI {
  66. /// Flag for enabling legacy console behavior in the interop system while
  67. /// we still have it around. Will disappear along with console.
  68. extern bool gUseConsoleInterop;
  69. /// Flag to allow engine functions to detect whether the engine had been
  70. /// initialized or shut down.
  71. extern bool gIsInitialized;
  72. }
  73. //FIXME: this allows const char* to be used as a struct field type
  74. // Temp support for allowing const char* to remain in the API functions as long as we
  75. // still have the console system around. When that is purged, these definitions should
  76. // be deleted and all const char* uses be replaced with String.
  77. template<> struct EngineTypeTraits< const char* > : public EngineTypeTraits< String > {};
  78. template<> inline const EngineTypeInfo* TYPE< const char* >() { return TYPE< String >(); }
  79. /// @name Marshalling
  80. ///
  81. /// Functions for converting to/from string-based data representations.
  82. ///
  83. /// @note This functionality is specific to the console interop.
  84. /// @{
  85. /// Marshal a single piece of data from native into client form.
  86. template< typename T >
  87. inline const char* EngineMarshallData( const T& value )
  88. {
  89. return castConsoleTypeToString( value );
  90. }
  91. inline const char* EngineMarshallData( bool value )
  92. {
  93. if( value )
  94. return "1";
  95. else
  96. return "0";
  97. }
  98. inline const char* EngineMarshallData( const char* str )
  99. {
  100. // The API assumes that if you pass a plain "const char*" through it, then you are referring
  101. // to string storage with non-local lifetime that can be safely passed to the control layer.
  102. return str;
  103. }
  104. template< typename T >
  105. inline const char* EngineMarshallData( T* object )
  106. {
  107. return ( object ? object->getIdString() : "0" );
  108. }
  109. template< typename T >
  110. inline const char* EngineMarshallData( const T* object )
  111. {
  112. return ( object ? object->getIdString() : "0" );
  113. }
  114. inline const char* EngineMarshallData( U32 value )
  115. {
  116. return EngineMarshallData( S32( value ) );
  117. }
  118. /// Marshal data from native into client form stored directly in
  119. /// client function invocation vector.
  120. template< typename T >
  121. inline void EngineMarshallData( const T& arg, S32& argc, ConsoleValueRef *argv )
  122. {
  123. argv[ argc ] = Con::getStringArg( castConsoleTypeToString( arg ) );
  124. argc ++;
  125. }
  126. inline void EngineMarshallData( bool arg, S32& argc, ConsoleValueRef *argv )
  127. {
  128. if( arg )
  129. argv[ argc ] = "1";
  130. else
  131. argv[ argc ] = "0";
  132. argc ++;
  133. }
  134. inline void EngineMarshallData( S32 arg, S32& argc, ConsoleValueRef *argv )
  135. {
  136. argv[ argc ] = Con::getIntArg( arg );
  137. argc ++;
  138. }
  139. inline void EngineMarshallData( U32 arg, S32& argc, ConsoleValueRef *argv )
  140. {
  141. EngineMarshallData( S32( arg ), argc, argv );
  142. }
  143. inline void EngineMarshallData( F32 arg, S32& argc, ConsoleValueRef *argv )
  144. {
  145. argv[ argc ] = Con::getFloatArg( arg );
  146. argc ++;
  147. }
  148. inline void EngineMarshallData( const char* arg, S32& argc, ConsoleValueRef *argv )
  149. {
  150. argv[ argc ] = arg;
  151. argc ++;
  152. }
  153. template< typename T >
  154. inline void EngineMarshallData( T* object, S32& argc, ConsoleValueRef *argv )
  155. {
  156. argv[ argc ] = ( object ? object->getIdString() : "0" );
  157. argc ++;
  158. }
  159. template< typename T >
  160. inline void EngineMarshallData( const T* object, S32& argc, ConsoleValueRef *argv )
  161. {
  162. argv[ argc ] = ( object ? object->getIdString() : "0" );
  163. argc ++;
  164. }
  165. /// Unmarshal data from client form to engine form.
  166. ///
  167. /// This is wrapped in an a struct as partial specializations on function
  168. /// templates are not allowed in C++.
  169. template< typename T >
  170. struct EngineUnmarshallData
  171. {
  172. T operator()( const char* str ) const
  173. {
  174. T value;
  175. castConsoleTypeFromString( value, str );
  176. return value;
  177. }
  178. };
  179. template<>
  180. struct EngineUnmarshallData< S32 >
  181. {
  182. S32 operator()( const char* str ) const
  183. {
  184. return dAtoi( str );
  185. }
  186. };
  187. template<>
  188. struct EngineUnmarshallData< U32 >
  189. {
  190. U32 operator()( const char* str ) const
  191. {
  192. return dAtoui( str );
  193. }
  194. };
  195. template<>
  196. struct EngineUnmarshallData< F32 >
  197. {
  198. F32 operator()( const char* str ) const
  199. {
  200. return dAtof( str );
  201. }
  202. };
  203. template<>
  204. struct EngineUnmarshallData< const char* >
  205. {
  206. const char* operator()( const char* str ) const
  207. {
  208. return str;
  209. }
  210. };
  211. template< typename T >
  212. struct EngineUnmarshallData< T* >
  213. {
  214. T* operator()( const char* str ) const
  215. {
  216. return dynamic_cast< T* >( Sim::findObject( str ) );
  217. }
  218. };
  219. template<>
  220. struct EngineUnmarshallData< void >
  221. {
  222. void operator()( const char* ) const {}
  223. };
  224. /// @}
  225. /// @name C to C++ Trampolines
  226. ///
  227. /// The trampolines serve two purposes:
  228. ///
  229. /// For one, they ensure that no matter what argument types are specified by users of the engine API macros, the correct
  230. /// argument value types are enforced on the functions exported by the engine. Let's say, for example, the user writes
  231. /// a function that takes a "Point3F direction" argument, then the template machinery here will automatically expose an
  232. /// API function that takes a "Point3F& direction" argument.
  233. ///
  234. /// Secondly, the templates jump the incoming calls from extern "C" space into C++ space. This is mostly relevant for
  235. /// methods only as they will need an implicit object type argument.
  236. ///
  237. /// @{
  238. // Helper type to factor out commonalities between function and method trampolines.
  239. template< typename T >
  240. struct _EngineTrampoline
  241. {
  242. struct Args {};
  243. };
  244. template< typename R, typename A >
  245. struct _EngineTrampoline< R( A ) >
  246. {
  247. struct Args
  248. {
  249. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ];
  250. typename EngineTypeTraits< A >::ValueType a() const
  251. {
  252. return EngineTypeTraits< A >::ArgumentToValue(
  253. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  254. }
  255. };
  256. };
  257. template< typename R, typename A, typename B >
  258. struct _EngineTrampoline< R( A, B ) >
  259. {
  260. struct Args
  261. {
  262. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  263. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ];
  264. typename EngineTypeTraits< A >::ValueType a() const
  265. {
  266. return EngineTypeTraits< A >::ArgumentToValue(
  267. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  268. }
  269. typename EngineTypeTraits< B >::ValueType b() const
  270. {
  271. return EngineTypeTraits< B >::ArgumentToValue(
  272. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  273. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  274. }
  275. };
  276. };
  277. template< typename R, typename A, typename B, typename C >
  278. struct _EngineTrampoline< R( A, B, C ) >
  279. {
  280. struct Args
  281. {
  282. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  283. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  284. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ];
  285. typename EngineTypeTraits< A >::ValueType a() const
  286. {
  287. return EngineTypeTraits< A >::ArgumentToValue(
  288. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  289. }
  290. typename EngineTypeTraits< B >::ValueType b() const
  291. {
  292. return EngineTypeTraits< B >::ArgumentToValue(
  293. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  294. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  295. }
  296. typename EngineTypeTraits< C >::ValueType c() const
  297. {
  298. return EngineTypeTraits< C >::ArgumentToValue(
  299. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  300. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  301. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  302. }
  303. };
  304. };
  305. template< typename R, typename A, typename B, typename C, typename D >
  306. struct _EngineTrampoline< R( A, B, C, D ) >
  307. {
  308. struct Args
  309. {
  310. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  311. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  312. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  313. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ];
  314. typename EngineTypeTraits< A >::ValueType a() const
  315. {
  316. return EngineTypeTraits< A >::ArgumentToValue(
  317. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  318. }
  319. typename EngineTypeTraits< B >::ValueType b() const
  320. {
  321. return EngineTypeTraits< B >::ArgumentToValue(
  322. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  323. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  324. }
  325. typename EngineTypeTraits< C >::ValueType c() const
  326. {
  327. return EngineTypeTraits< C >::ArgumentToValue(
  328. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  329. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  330. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  331. }
  332. typename EngineTypeTraits< D >::ValueType d() const
  333. {
  334. return EngineTypeTraits< D >::ArgumentToValue(
  335. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  336. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  337. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  338. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  339. }
  340. };
  341. };
  342. template< typename R, typename A, typename B, typename C, typename D, typename E >
  343. struct _EngineTrampoline< R( A, B, C, D, E ) >
  344. {
  345. struct Args
  346. {
  347. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  348. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  349. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  350. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  351. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ];
  352. typename EngineTypeTraits< A >::ValueType a() const
  353. {
  354. return EngineTypeTraits< A >::ArgumentToValue(
  355. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  356. }
  357. typename EngineTypeTraits< B >::ValueType b() const
  358. {
  359. return EngineTypeTraits< B >::ArgumentToValue(
  360. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  361. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  362. }
  363. typename EngineTypeTraits< C >::ValueType c() const
  364. {
  365. return EngineTypeTraits< C >::ArgumentToValue(
  366. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  367. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  368. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  369. }
  370. typename EngineTypeTraits< D >::ValueType d() const
  371. {
  372. return EngineTypeTraits< D >::ArgumentToValue(
  373. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  374. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  375. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  376. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  377. }
  378. typename EngineTypeTraits< E >::ValueType e() const
  379. {
  380. return EngineTypeTraits< E >::ArgumentToValue(
  381. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  382. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  383. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  384. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  385. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  386. }
  387. };
  388. };
  389. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  390. struct _EngineTrampoline< R( A, B, C, D, E, F ) >
  391. {
  392. struct Args
  393. {
  394. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  395. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  396. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  397. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  398. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  399. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ];
  400. typename EngineTypeTraits< A >::ValueType a() const
  401. {
  402. return EngineTypeTraits< A >::ArgumentToValue(
  403. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  404. }
  405. typename EngineTypeTraits< B >::ValueType b() const
  406. {
  407. return EngineTypeTraits< B >::ArgumentToValue(
  408. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  409. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  410. }
  411. typename EngineTypeTraits< C >::ValueType c() const
  412. {
  413. return EngineTypeTraits< C >::ArgumentToValue(
  414. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  415. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  416. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  417. }
  418. typename EngineTypeTraits< D >::ValueType d() const
  419. {
  420. return EngineTypeTraits< D >::ArgumentToValue(
  421. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  422. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  423. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  424. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  425. }
  426. typename EngineTypeTraits< E >::ValueType e() const
  427. {
  428. return EngineTypeTraits< E >::ArgumentToValue(
  429. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  430. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  431. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  432. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  433. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  434. }
  435. typename EngineTypeTraits< F >::ValueType f() const
  436. {
  437. return EngineTypeTraits< F >::ArgumentToValue(
  438. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  439. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  440. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  441. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  442. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  443. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  444. }
  445. };
  446. };
  447. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  448. struct _EngineTrampoline< R( A, B, C, D, E, F, G ) >
  449. {
  450. struct Args
  451. {
  452. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  453. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  454. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  455. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  456. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  457. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  458. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) ];
  459. typename EngineTypeTraits< A >::ValueType a() const
  460. {
  461. return EngineTypeTraits< A >::ArgumentToValue(
  462. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  463. }
  464. typename EngineTypeTraits< B >::ValueType b() const
  465. {
  466. return EngineTypeTraits< B >::ArgumentToValue(
  467. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  468. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  469. }
  470. typename EngineTypeTraits< C >::ValueType c() const
  471. {
  472. return EngineTypeTraits< C >::ArgumentToValue(
  473. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  474. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  475. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  476. }
  477. typename EngineTypeTraits< D >::ValueType d() const
  478. {
  479. return EngineTypeTraits< D >::ArgumentToValue(
  480. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  481. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  482. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  483. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  484. }
  485. typename EngineTypeTraits< E >::ValueType e() const
  486. {
  487. return EngineTypeTraits< E >::ArgumentToValue(
  488. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  489. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  490. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  491. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  492. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  493. }
  494. typename EngineTypeTraits< F >::ValueType f() const
  495. {
  496. return EngineTypeTraits< F >::ArgumentToValue(
  497. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  498. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  499. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  500. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  501. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  502. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  503. }
  504. typename EngineTypeTraits< G >::ValueType g() const
  505. {
  506. return EngineTypeTraits< F >::ArgumentToValue(
  507. *( reinterpret_cast< const typename EngineTypeTraits< G >::ArgumentValueType* >
  508. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  509. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  510. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  511. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  512. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  513. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ] ) ) );
  514. }
  515. };
  516. };
  517. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  518. struct _EngineTrampoline< R( A, B, C, D, E, F, G, H ) >
  519. {
  520. struct Args
  521. {
  522. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  523. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  524. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  525. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  526. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  527. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  528. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  529. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) ];
  530. typename EngineTypeTraits< A >::ValueType a() const
  531. {
  532. return EngineTypeTraits< A >::ArgumentToValue(
  533. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  534. }
  535. typename EngineTypeTraits< B >::ValueType b() const
  536. {
  537. return EngineTypeTraits< B >::ArgumentToValue(
  538. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  539. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  540. }
  541. typename EngineTypeTraits< C >::ValueType c() const
  542. {
  543. return EngineTypeTraits< C >::ArgumentToValue(
  544. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  545. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  546. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  547. }
  548. typename EngineTypeTraits< D >::ValueType d() const
  549. {
  550. return EngineTypeTraits< D >::ArgumentToValue(
  551. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  552. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  553. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  554. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  555. }
  556. typename EngineTypeTraits< E >::ValueType e() const
  557. {
  558. return EngineTypeTraits< E >::ArgumentToValue(
  559. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  560. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  561. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  562. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  563. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  564. }
  565. typename EngineTypeTraits< F >::ValueType f() const
  566. {
  567. return EngineTypeTraits< F >::ArgumentToValue(
  568. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  569. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  570. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  571. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  572. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  573. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  574. }
  575. typename EngineTypeTraits< G >::ValueType g() const
  576. {
  577. return EngineTypeTraits< G >::ArgumentToValue(
  578. *( reinterpret_cast< const typename EngineTypeTraits< G >::ArgumentValueType* >
  579. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  580. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  581. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  582. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  583. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  584. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ] ) ) );
  585. }
  586. typename EngineTypeTraits< H >::ValueType h() const
  587. {
  588. return EngineTypeTraits< H >::ArgumentToValue(
  589. *( reinterpret_cast< const typename EngineTypeTraits< H >::ArgumentValueType* >
  590. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  591. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  592. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  593. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  594. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  595. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  596. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) ] ) ) );
  597. }
  598. };
  599. };
  600. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  601. struct _EngineTrampoline< R( A, B, C, D, E, F, G, H, I ) >
  602. {
  603. struct Args
  604. {
  605. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  606. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  607. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  608. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  609. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  610. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  611. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  612. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  613. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) ];
  614. typename EngineTypeTraits< A >::ValueType a() const
  615. {
  616. return EngineTypeTraits< A >::ArgumentToValue(
  617. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  618. }
  619. typename EngineTypeTraits< B >::ValueType b() const
  620. {
  621. return EngineTypeTraits< B >::ArgumentToValue(
  622. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  623. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  624. }
  625. typename EngineTypeTraits< C >::ValueType c() const
  626. {
  627. return EngineTypeTraits< C >::ArgumentToValue(
  628. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  629. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  630. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  631. }
  632. typename EngineTypeTraits< D >::ValueType d() const
  633. {
  634. return EngineTypeTraits< D >::ArgumentToValue(
  635. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  636. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  637. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  638. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  639. }
  640. typename EngineTypeTraits< E >::ValueType e() const
  641. {
  642. return EngineTypeTraits< E >::ArgumentToValue(
  643. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  644. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  645. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  646. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  647. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  648. }
  649. typename EngineTypeTraits< F >::ValueType f() const
  650. {
  651. return EngineTypeTraits< F >::ArgumentToValue(
  652. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  653. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  654. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  655. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  656. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  657. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  658. }
  659. typename EngineTypeTraits< G >::ValueType g() const
  660. {
  661. return EngineTypeTraits< G >::ArgumentToValue(
  662. *( reinterpret_cast< const typename EngineTypeTraits< G >::ArgumentValueType* >
  663. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  664. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  665. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  666. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  667. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  668. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ] ) ) );
  669. }
  670. typename EngineTypeTraits< H >::ValueType h() const
  671. {
  672. return EngineTypeTraits< H >::ArgumentToValue(
  673. *( reinterpret_cast< const typename EngineTypeTraits< H >::ArgumentValueType* >
  674. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  675. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  676. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  677. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  678. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  679. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  680. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) ] ) ) );
  681. }
  682. typename EngineTypeTraits< I >::ValueType i() const
  683. {
  684. return EngineTypeTraits< I >::ArgumentToValue(
  685. *( reinterpret_cast< const typename EngineTypeTraits< I >::ArgumentValueType* >
  686. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  687. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  688. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  689. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  690. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  691. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  692. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  693. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) ] ) ) );
  694. }
  695. };
  696. };
  697. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  698. struct _EngineTrampoline< R( A, B, C, D, E, F, G, H, I, J ) >
  699. {
  700. struct Args
  701. {
  702. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  703. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  704. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  705. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  706. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  707. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  708. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  709. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  710. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) +
  711. sizeof( typename EngineTypeTraits< J >::ArgumentValueType ) ];
  712. typename EngineTypeTraits< A >::ValueType a() const
  713. {
  714. return EngineTypeTraits< A >::ArgumentToValue(
  715. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  716. }
  717. typename EngineTypeTraits< B >::ValueType b() const
  718. {
  719. return EngineTypeTraits< B >::ArgumentToValue(
  720. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  721. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  722. }
  723. typename EngineTypeTraits< C >::ValueType c() const
  724. {
  725. return EngineTypeTraits< C >::ArgumentToValue(
  726. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  727. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  728. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  729. }
  730. typename EngineTypeTraits< D >::ValueType d() const
  731. {
  732. return EngineTypeTraits< D >::ArgumentToValue(
  733. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  734. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  735. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  736. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  737. }
  738. typename EngineTypeTraits< E >::ValueType e() const
  739. {
  740. return EngineTypeTraits< E >::ArgumentToValue(
  741. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  742. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  743. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  744. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  745. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  746. }
  747. typename EngineTypeTraits< F >::ValueType f() const
  748. {
  749. return EngineTypeTraits< F >::ArgumentToValue(
  750. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  751. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  752. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  753. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  754. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  755. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  756. }
  757. typename EngineTypeTraits< G >::ValueType g() const
  758. {
  759. return EngineTypeTraits< G >::ArgumentToValue(
  760. *( reinterpret_cast< const typename EngineTypeTraits< G >::ArgumentValueType* >
  761. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  762. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  763. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  764. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  765. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  766. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ] ) ) );
  767. }
  768. typename EngineTypeTraits< H >::ValueType h() const
  769. {
  770. return EngineTypeTraits< H >::ArgumentToValue(
  771. *( reinterpret_cast< const typename EngineTypeTraits< H >::ArgumentValueType* >
  772. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  773. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  774. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  775. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  776. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  777. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  778. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) ] ) ) );
  779. }
  780. typename EngineTypeTraits< I >::ValueType i() const
  781. {
  782. return EngineTypeTraits< I >::ArgumentToValue(
  783. *( reinterpret_cast< const typename EngineTypeTraits< I >::ArgumentValueType* >
  784. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  785. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  786. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  787. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  788. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  789. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  790. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  791. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) ] ) ) );
  792. }
  793. typename EngineTypeTraits< J >::ValueType j() const
  794. {
  795. return EngineTypeTraits< J >::ArgumentToValue(
  796. *( reinterpret_cast< const typename EngineTypeTraits< J >::ArgumentValueType* >
  797. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  798. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  799. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  800. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  801. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  802. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  803. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  804. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  805. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) ] ) ) );
  806. }
  807. };
  808. };
  809. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  810. struct _EngineTrampoline< R( A, B, C, D, E, F, G, H, I, J, K ) >
  811. {
  812. struct Args
  813. {
  814. char data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  815. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  816. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  817. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  818. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  819. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  820. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  821. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  822. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) +
  823. sizeof( typename EngineTypeTraits< J >::ArgumentValueType ) +
  824. sizeof( typename EngineTypeTraits< K >::ArgumentValueType ) ];
  825. typename EngineTypeTraits< A >::ValueType a() const
  826. {
  827. return EngineTypeTraits< A >::ArgumentToValue(
  828. *( reinterpret_cast< const typename EngineTypeTraits< A >::ArgumentValueType* >( &data[ 0 ] ) ) );
  829. }
  830. typename EngineTypeTraits< B >::ValueType b() const
  831. {
  832. return EngineTypeTraits< B >::ArgumentToValue(
  833. *( reinterpret_cast< const typename EngineTypeTraits< B >::ArgumentValueType* >
  834. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) ] ) ) );
  835. }
  836. typename EngineTypeTraits< C >::ValueType c() const
  837. {
  838. return EngineTypeTraits< C >::ArgumentToValue(
  839. *( reinterpret_cast< const typename EngineTypeTraits< C >::ArgumentValueType* >
  840. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  841. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) ] ) ) );
  842. }
  843. typename EngineTypeTraits< D >::ValueType d() const
  844. {
  845. return EngineTypeTraits< D >::ArgumentToValue(
  846. *( reinterpret_cast< const typename EngineTypeTraits< D >::ArgumentValueType* >
  847. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  848. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  849. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) ] ) ) );
  850. }
  851. typename EngineTypeTraits< E >::ValueType e() const
  852. {
  853. return EngineTypeTraits< E >::ArgumentToValue(
  854. *( reinterpret_cast< const typename EngineTypeTraits< E >::ArgumentValueType* >
  855. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  856. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  857. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  858. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) ] ) ) );
  859. }
  860. typename EngineTypeTraits< F >::ValueType f() const
  861. {
  862. return EngineTypeTraits< F >::ArgumentToValue(
  863. *( reinterpret_cast< const typename EngineTypeTraits< F >::ArgumentValueType* >
  864. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  865. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  866. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  867. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  868. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) ] ) ) );
  869. }
  870. typename EngineTypeTraits< G >::ValueType g() const
  871. {
  872. return EngineTypeTraits< G >::ArgumentToValue(
  873. *( reinterpret_cast< const typename EngineTypeTraits< G >::ArgumentValueType* >
  874. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  875. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  876. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  877. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  878. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  879. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) ] ) ) );
  880. }
  881. typename EngineTypeTraits< H >::ValueType h() const
  882. {
  883. return EngineTypeTraits< H >::ArgumentToValue(
  884. *( reinterpret_cast< const typename EngineTypeTraits< H >::ArgumentValueType* >
  885. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  886. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  887. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  888. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  889. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  890. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  891. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) ] ) ) );
  892. }
  893. typename EngineTypeTraits< I >::ValueType i() const
  894. {
  895. return EngineTypeTraits< I >::ArgumentToValue(
  896. *( reinterpret_cast< const typename EngineTypeTraits< I >::ArgumentValueType* >
  897. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  898. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  899. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  900. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  901. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  902. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  903. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  904. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) ] ) ) );
  905. }
  906. typename EngineTypeTraits< J >::ValueType j() const
  907. {
  908. return EngineTypeTraits< J >::ArgumentToValue(
  909. *( reinterpret_cast< const typename EngineTypeTraits< J >::ArgumentValueType* >
  910. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  911. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  912. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  913. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  914. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  915. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  916. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  917. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  918. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) ] ) ) );
  919. }
  920. typename EngineTypeTraits< K >::ValueType k() const
  921. {
  922. return EngineTypeTraits< K >::ArgumentToValue(
  923. *( reinterpret_cast< const typename EngineTypeTraits< K >::ArgumentValueType* >
  924. ( &data[ sizeof( typename EngineTypeTraits< A >::ArgumentValueType ) +
  925. sizeof( typename EngineTypeTraits< B >::ArgumentValueType ) +
  926. sizeof( typename EngineTypeTraits< C >::ArgumentValueType ) +
  927. sizeof( typename EngineTypeTraits< D >::ArgumentValueType ) +
  928. sizeof( typename EngineTypeTraits< E >::ArgumentValueType ) +
  929. sizeof( typename EngineTypeTraits< F >::ArgumentValueType ) +
  930. sizeof( typename EngineTypeTraits< G >::ArgumentValueType ) +
  931. sizeof( typename EngineTypeTraits< H >::ArgumentValueType ) +
  932. sizeof( typename EngineTypeTraits< I >::ArgumentValueType ) +
  933. sizeof( typename EngineTypeTraits< J >::ArgumentValueType ) ] ) ) );
  934. }
  935. };
  936. };
  937. template< typename T >
  938. struct _EngineFunctionTrampolineBase : public _EngineTrampoline< T >
  939. {
  940. typedef T FunctionType;
  941. };
  942. // Trampolines for any call-ins that aren't methods.
  943. template< typename T >
  944. struct _EngineFunctionTrampoline {};
  945. template< typename R >
  946. struct _EngineFunctionTrampoline< R() > : public _EngineFunctionTrampolineBase< R() >
  947. {
  948. static R jmp( R ( *fn )(), const typename _EngineFunctionTrampolineBase< R() >::Args& args )
  949. {
  950. return R( fn() );
  951. }
  952. };
  953. template< typename R, typename A >
  954. struct _EngineFunctionTrampoline< R( A ) > : public _EngineFunctionTrampolineBase< R( A ) >
  955. {
  956. static R jmp( R ( *fn )( A ), const typename _EngineFunctionTrampolineBase< R( A ) >::Args& args )
  957. {
  958. return R( fn( args.a() ) );
  959. }
  960. };
  961. template< typename R, typename A, typename B >
  962. struct _EngineFunctionTrampoline< R( A, B ) > : public _EngineFunctionTrampolineBase< R( A, B ) >
  963. {
  964. static R jmp( R ( *fn )( A, B ), const typename _EngineFunctionTrampolineBase< R( A, B ) >::Args& args )
  965. {
  966. return R( fn( args.a(), args.b() ) );
  967. }
  968. };
  969. template< typename R, typename A, typename B, typename C >
  970. struct _EngineFunctionTrampoline< R( A, B, C ) > : public _EngineFunctionTrampolineBase< R( A, B, C ) >
  971. {
  972. static R jmp( R ( *fn )( A, B, C ), const typename _EngineFunctionTrampolineBase< R( A, B, C ) >::Args& args )
  973. {
  974. return R( fn( args.a(), args.b(), args.c() ) );
  975. }
  976. };
  977. template< typename R, typename A, typename B, typename C, typename D >
  978. struct _EngineFunctionTrampoline< R( A, B, C, D ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D ) >
  979. {
  980. static R jmp( R ( *fn )( A, B, C, D ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D ) >::Args& args )
  981. {
  982. return R( fn( args.a(), args.b(), args.c(), args.d() ) );
  983. }
  984. };
  985. template< typename R, typename A, typename B, typename C, typename D, typename E >
  986. struct _EngineFunctionTrampoline< R( A, B, C, D, E ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E ) >
  987. {
  988. static R jmp( R ( *fn )( A, B, C, D, E ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E ) >::Args& args )
  989. {
  990. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e() ) );
  991. }
  992. };
  993. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  994. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F ) >
  995. {
  996. static R jmp( R ( *fn )( A, B, C, D, E, F ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F ) >::Args& args )
  997. {
  998. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e(), args.f() ) );
  999. }
  1000. };
  1001. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  1002. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F, G ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G ) >
  1003. {
  1004. static R jmp( R ( *fn )( A, B, C, D, E, F, G ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G ) >::Args& args )
  1005. {
  1006. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g() ) );
  1007. }
  1008. };
  1009. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  1010. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F, G, H ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H ) >
  1011. {
  1012. static R jmp( R ( *fn )( A, B, C, D, E, F, G, H ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H ) >::Args& args )
  1013. {
  1014. return R( fn( args.a, args.b, args.c, args.d, args.e, args.f, args.g, args.h ) );
  1015. }
  1016. };
  1017. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  1018. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F, G, H, I ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I ) >
  1019. {
  1020. static R jmp( R ( *fn )( A, B, C, D, E, F, G, H, I ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I ) >::Args& args )
  1021. {
  1022. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i() ) );
  1023. }
  1024. };
  1025. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  1026. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F, G, H, I, J ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J ) >
  1027. {
  1028. static R jmp( R ( *fn )( A, B, C, D, E, F, G, H, I, J ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J ) >::Args& args )
  1029. {
  1030. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i(), args.j() ) );
  1031. }
  1032. };
  1033. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  1034. struct _EngineFunctionTrampoline< R( A, B, C, D, E, F, G, H, I, J, K ) > : public _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J, K ) >
  1035. {
  1036. static R jmp( R ( *fn )( A, B, C, D, E, F, G, H, I, J, K ), const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J, K ) >::Args& args )
  1037. {
  1038. return R( fn( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i(), args.j(), args.k() ) );
  1039. }
  1040. };
  1041. template< typename T >
  1042. struct _EngineMethodTrampolineBase : public _EngineTrampoline< T > {};
  1043. template< typename Frame, typename T >
  1044. struct _EngineMethodTrampoline {};
  1045. template< typename Frame, typename R >
  1046. struct _EngineMethodTrampoline< Frame, R() > : public _EngineMethodTrampolineBase< R() >
  1047. {
  1048. typedef R( FunctionType )( typename Frame::ObjectType* );
  1049. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R() >::Args& args )
  1050. {
  1051. Frame f;
  1052. f.object = object;
  1053. return R( f._exec() );
  1054. }
  1055. };
  1056. template< typename Frame, typename R, typename A >
  1057. struct _EngineMethodTrampoline< Frame, R( A ) > : public _EngineMethodTrampolineBase< R( A ) >
  1058. {
  1059. typedef R( FunctionType )( typename Frame::ObjectType*, A );
  1060. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A ) >::Args& args )
  1061. {
  1062. Frame f;
  1063. f.object = object;
  1064. return R( f._exec( args.a() ) );
  1065. }
  1066. };
  1067. template< typename Frame, typename R, typename A, typename B >
  1068. struct _EngineMethodTrampoline< Frame, R( A, B ) > : public _EngineMethodTrampolineBase< R( A, B ) >
  1069. {
  1070. typedef R( FunctionType )( typename Frame::ObjectType*, A, B );
  1071. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B ) >::Args& args )
  1072. {
  1073. Frame f;
  1074. f.object = object;
  1075. return R( f._exec( args.a(), args.b() ) );
  1076. }
  1077. };
  1078. template< typename Frame, typename R, typename A, typename B, typename C >
  1079. struct _EngineMethodTrampoline< Frame, R( A, B, C ) > : public _EngineMethodTrampolineBase< R( A, B, C ) >
  1080. {
  1081. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C );
  1082. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C ) >::Args& args )
  1083. {
  1084. Frame f;
  1085. f.object = object;
  1086. return R( f._exec( args.a(), args.b(), args.c() ) );
  1087. }
  1088. };
  1089. template< typename Frame, typename R, typename A, typename B, typename C, typename D >
  1090. struct _EngineMethodTrampoline< Frame, R( A, B, C, D ) > : public _EngineMethodTrampolineBase< R( A, B, C, D ) >
  1091. {
  1092. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D );
  1093. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D ) >::Args& args )
  1094. {
  1095. Frame f;
  1096. f.object = object;
  1097. return R( f._exec( args.a(), args.b(), args.c(), args.d() ) );
  1098. }
  1099. };
  1100. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E >
  1101. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E ) >
  1102. {
  1103. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E );
  1104. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E ) >::Args& args )
  1105. {
  1106. Frame f;
  1107. f.object = object;
  1108. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e() ) );
  1109. }
  1110. };
  1111. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  1112. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F ) >
  1113. {
  1114. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F );
  1115. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F ) >::Args& args )
  1116. {
  1117. Frame f;
  1118. f.object = object;
  1119. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f() ) );
  1120. }
  1121. };
  1122. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  1123. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F, G ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F, G ) >
  1124. {
  1125. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F, G );
  1126. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G ) >::Args& args )
  1127. {
  1128. Frame f;
  1129. f.object = object;
  1130. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g() ) );
  1131. }
  1132. };
  1133. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  1134. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F, G, H ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F, G, H ) >
  1135. {
  1136. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F, G, H );
  1137. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H ) >::Args& args )
  1138. {
  1139. Frame f;
  1140. f.object = object;
  1141. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h() ) );
  1142. }
  1143. };
  1144. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  1145. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F, G, H, I ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F, G, H, I ) >
  1146. {
  1147. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I );
  1148. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I ) >::Args& args )
  1149. {
  1150. Frame f;
  1151. f.object = object;
  1152. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i() ) );
  1153. }
  1154. };
  1155. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  1156. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F, G, H, I, J ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F, G, H, I, J ) >
  1157. {
  1158. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J );
  1159. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J ) >::Args& args )
  1160. {
  1161. Frame f;
  1162. f.object = object;
  1163. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i(), args.j() ) );
  1164. }
  1165. };
  1166. template< typename Frame, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  1167. struct _EngineMethodTrampoline< Frame, R( A, B, C, D, E, F, G, H, I, J, K ) > : public _EngineMethodTrampolineBase< R( A, B, C, D, E, F, G, H, I, J, K ) >
  1168. {
  1169. typedef R( FunctionType )( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J, K );
  1170. static R jmp( typename Frame::ObjectType* object, const typename _EngineFunctionTrampolineBase< R( A, B, C, D, E, F, G, H, I, J, K ) >::Args& args )
  1171. {
  1172. Frame f;
  1173. f.object = object;
  1174. return R( f._exec( args.a(), args.b(), args.c(), args.d(), args.e(), args.f(), args.g(), args.h(), args.i(), args.j(), args.k() ) );
  1175. }
  1176. };
  1177. /// @}
  1178. /// @name Thunking
  1179. ///
  1180. /// Internal functionality for thunks placed between TorqueScript calls of engine functions and their native
  1181. /// implementations.
  1182. ///
  1183. /// @note The functionality in this group is specific to the console interop system.
  1184. /// @{
  1185. // Helper function to return data from a thunk.
  1186. template< typename T >
  1187. inline const char* _EngineConsoleThunkReturnValue( const T& value )
  1188. {
  1189. return EngineMarshallData( value );
  1190. }
  1191. inline bool _EngineConsoleThunkReturnValue( bool value )
  1192. {
  1193. return value;
  1194. }
  1195. inline S32 _EngineConsoleThunkReturnValue( S32 value )
  1196. {
  1197. return value;
  1198. }
  1199. inline F32 _EngineConsoleThunkReturnValue( F32 value )
  1200. {
  1201. return value;
  1202. }
  1203. inline const char* _EngineConsoleThunkReturnValue( const String& str )
  1204. {
  1205. return Con::getReturnBuffer( str );
  1206. }
  1207. inline const char* _EngineConsoleThunkReturnValue( const char* value )
  1208. {
  1209. return EngineMarshallData( value );
  1210. }
  1211. template< typename T >
  1212. inline const char* _EngineConsoleThunkReturnValue( T* value )
  1213. {
  1214. return ( value ? value->getIdString() : "" );
  1215. }
  1216. template< typename T >
  1217. inline const char* _EngineConsoleThunkReturnValue( const T* value )
  1218. {
  1219. return ( value ? value->getIdString() : "" );
  1220. }
  1221. // Helper class to determine the type of callback registered with the console system.
  1222. template< typename R >
  1223. struct _EngineConsoleThunkType
  1224. {
  1225. typedef const char* ReturnType;
  1226. typedef StringCallback CallbackType;
  1227. };
  1228. template<>
  1229. struct _EngineConsoleThunkType< S32 >
  1230. {
  1231. typedef S32 ReturnType;
  1232. typedef IntCallback CallbackType;
  1233. };
  1234. template<>
  1235. struct _EngineConsoleThunkType< U32 >
  1236. {
  1237. typedef U32 ReturnType;
  1238. typedef IntCallback CallbackType;
  1239. };
  1240. template<>
  1241. struct _EngineConsoleThunkType< F32 >
  1242. {
  1243. typedef F32 ReturnType;
  1244. typedef FloatCallback CallbackType;
  1245. };
  1246. template<>
  1247. struct _EngineConsoleThunkType< bool >
  1248. {
  1249. typedef bool ReturnType;
  1250. typedef BoolCallback CallbackType;
  1251. };
  1252. template<>
  1253. struct _EngineConsoleThunkType< void >
  1254. {
  1255. typedef void ReturnType;
  1256. typedef VoidCallback CallbackType;
  1257. };
  1258. // Helper struct to count the number of parameters in a function list.
  1259. // The setup through operator () allows omitting the the argument list entirely.
  1260. struct _EngineConsoleThunkCountArgs
  1261. {
  1262. template< typename A >
  1263. U32 operator ()( A a )
  1264. {
  1265. return 1;
  1266. }
  1267. template< typename A, typename B >
  1268. U32 operator ()( A a, B b )
  1269. {
  1270. return 2;
  1271. }
  1272. template< typename A, typename B, typename C >
  1273. U32 operator ()( A a, B b, C c )
  1274. {
  1275. return 3;
  1276. }
  1277. template< typename A, typename B, typename C, typename D >
  1278. U32 operator ()( A a, B b, C c, D d )
  1279. {
  1280. return 4;
  1281. }
  1282. template< typename A, typename B, typename C, typename D, typename E >
  1283. U32 operator ()( A a, B b, C c, D d, E e )
  1284. {
  1285. return 5;
  1286. }
  1287. template< typename A, typename B, typename C, typename D, typename E, typename F >
  1288. U32 operator ()( A a, B b, C c, D d, E e, F f )
  1289. {
  1290. return 6;
  1291. }
  1292. template< typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  1293. U32 operator ()( A a, B b, C c, D d, E e, F f, G g )
  1294. {
  1295. return 7;
  1296. }
  1297. template< typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  1298. U32 operator ()( A a, B b, C c, D d, E e, F f, G g, H h )
  1299. {
  1300. return 8;
  1301. }
  1302. template< typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  1303. U32 operator ()( A a, B b, C c, D d, E e, F f, G g, H h, I i )
  1304. {
  1305. return 9;
  1306. }
  1307. template< typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  1308. U32 operator ()( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j )
  1309. {
  1310. return 10;
  1311. }
  1312. template< typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  1313. U32 operator ()( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k )
  1314. {
  1315. return 11;
  1316. }
  1317. operator U32() const
  1318. {
  1319. return 0;
  1320. }
  1321. };
  1322. // Encapsulation of a legacy console function invocation.
  1323. template< int startArgc, typename T >
  1324. struct _EngineConsoleThunk {};
  1325. template< int startArgc, typename R >
  1326. struct _EngineConsoleThunk< startArgc, R() >
  1327. {
  1328. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1329. static const int NUM_ARGS = 0;
  1330. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )(), const _EngineFunctionDefaultArguments< void() >& )
  1331. {
  1332. return _EngineConsoleThunkReturnValue( fn() );
  1333. }
  1334. template< typename Frame >
  1335. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )() const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType* ) >& )
  1336. {
  1337. return _EngineConsoleThunkReturnValue( ( frame->*fn )() );
  1338. }
  1339. };
  1340. template< int startArgc >
  1341. struct _EngineConsoleThunk< startArgc, void() >
  1342. {
  1343. typedef void ReturnType;
  1344. static const int NUM_ARGS = 0;
  1345. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )(), const _EngineFunctionDefaultArguments< void() >& )
  1346. {
  1347. fn();
  1348. }
  1349. template< typename Frame >
  1350. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )() const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType* ) >& )
  1351. {
  1352. return ( frame->*fn )();
  1353. }
  1354. };
  1355. template< int startArgc, typename R, typename A >
  1356. struct _EngineConsoleThunk< startArgc, R( A ) >
  1357. {
  1358. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1359. static const int NUM_ARGS = 1 + startArgc;
  1360. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A ), const _EngineFunctionDefaultArguments< void( A ) >& defaultArgs )
  1361. {
  1362. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1363. return _EngineConsoleThunkReturnValue( fn( a ) );
  1364. }
  1365. template< typename Frame >
  1366. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A ) >& defaultArgs )
  1367. {
  1368. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1369. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a ) );
  1370. }
  1371. };
  1372. template< int startArgc, typename A >
  1373. struct _EngineConsoleThunk< startArgc, void( A ) >
  1374. {
  1375. typedef void ReturnType;
  1376. static const int NUM_ARGS = 1 + startArgc;
  1377. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A ), const _EngineFunctionDefaultArguments< void( A ) >& defaultArgs )
  1378. {
  1379. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1380. fn( a );
  1381. }
  1382. template< typename Frame >
  1383. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A ) >& defaultArgs )
  1384. {
  1385. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1386. ( frame->*fn )( a );
  1387. }
  1388. };
  1389. template< int startArgc, typename R, typename A, typename B >
  1390. struct _EngineConsoleThunk< startArgc, R( A, B ) >
  1391. {
  1392. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1393. static const int NUM_ARGS = 2 + startArgc;
  1394. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B ), const _EngineFunctionDefaultArguments< void( A, B ) >& defaultArgs )
  1395. {
  1396. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1397. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1398. return _EngineConsoleThunkReturnValue( fn( a, b ) );
  1399. }
  1400. template< typename Frame >
  1401. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B ) >& defaultArgs )
  1402. {
  1403. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1404. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1405. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b ) );
  1406. }
  1407. };
  1408. template< int startArgc, typename A, typename B >
  1409. struct _EngineConsoleThunk< startArgc, void( A, B ) >
  1410. {
  1411. typedef void ReturnType;
  1412. static const int NUM_ARGS = 2 + startArgc;
  1413. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B ), const _EngineFunctionDefaultArguments< void( A, B ) >& defaultArgs )
  1414. {
  1415. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1416. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1417. fn( a, b );
  1418. }
  1419. template< typename Frame >
  1420. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B ) >& defaultArgs )
  1421. {
  1422. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1423. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1424. ( frame->*fn )( a, b );
  1425. }
  1426. };
  1427. template< int startArgc, typename R, typename A, typename B, typename C >
  1428. struct _EngineConsoleThunk< startArgc, R( A, B, C ) >
  1429. {
  1430. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1431. static const int NUM_ARGS = 3 + startArgc;
  1432. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C ), const _EngineFunctionDefaultArguments< void( A, B, C ) >& defaultArgs )
  1433. {
  1434. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1435. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1436. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1437. return _EngineConsoleThunkReturnValue( fn( a, b, c ) );
  1438. }
  1439. template< typename Frame >
  1440. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C ) >& defaultArgs )
  1441. {
  1442. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1443. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1444. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1445. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c ) );
  1446. }
  1447. };
  1448. template< int startArgc, typename A, typename B, typename C >
  1449. struct _EngineConsoleThunk< startArgc, void( A, B, C ) >
  1450. {
  1451. typedef void ReturnType;
  1452. static const int NUM_ARGS = 3 + startArgc;
  1453. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C ), const _EngineFunctionDefaultArguments< void( A, B, C ) >& defaultArgs )
  1454. {
  1455. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1456. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1457. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1458. fn( a, b, c );
  1459. }
  1460. template< typename Frame >
  1461. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C ) >& defaultArgs )
  1462. {
  1463. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1464. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1465. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1466. ( frame->*fn )( a, b, c );
  1467. }
  1468. };
  1469. template< int startArgc, typename R, typename A, typename B, typename C, typename D >
  1470. struct _EngineConsoleThunk< startArgc, R( A, B, C, D ) >
  1471. {
  1472. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1473. static const int NUM_ARGS = 4 + startArgc;
  1474. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D ), const _EngineFunctionDefaultArguments< void( A, B, C, D ) >& defaultArgs )
  1475. {
  1476. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1477. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1478. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1479. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1480. return _EngineConsoleThunkReturnValue( fn( a, b, c, d ) );
  1481. }
  1482. template< typename Frame >
  1483. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D ) >& defaultArgs )
  1484. {
  1485. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1486. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1487. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1488. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1489. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d ) );
  1490. }
  1491. };
  1492. template< int startArgc, typename A, typename B, typename C, typename D >
  1493. struct _EngineConsoleThunk< startArgc, void( A, B, C, D ) >
  1494. {
  1495. typedef void ReturnType;
  1496. static const int NUM_ARGS = 4 + startArgc;
  1497. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D ), const _EngineFunctionDefaultArguments< void( A, B, C, D ) >& defaultArgs )
  1498. {
  1499. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1500. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1501. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1502. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1503. fn( a, b, c, d );
  1504. }
  1505. template< typename Frame >
  1506. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D ) >& defaultArgs )
  1507. {
  1508. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1509. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1510. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1511. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1512. ( frame->*fn )( a, b, c, d );
  1513. }
  1514. };
  1515. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E >
  1516. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E ) >
  1517. {
  1518. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1519. static const int NUM_ARGS = 5 + startArgc;
  1520. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E ) >& defaultArgs )
  1521. {
  1522. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1523. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1524. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1525. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1526. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1527. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e ) );
  1528. }
  1529. template< typename Frame >
  1530. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E ) >& defaultArgs )
  1531. {
  1532. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1533. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1534. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1535. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1536. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1537. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e ) );
  1538. }
  1539. };
  1540. template< int startArgc, typename A, typename B, typename C, typename D, typename E >
  1541. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E ) >
  1542. {
  1543. typedef void ReturnType;
  1544. static const int NUM_ARGS = 5 + startArgc;
  1545. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E ) >& defaultArgs )
  1546. {
  1547. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1548. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1549. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1550. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1551. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1552. fn( a, b, c, d, e );
  1553. }
  1554. template< typename Frame >
  1555. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E ) >& defaultArgs )
  1556. {
  1557. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1558. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1559. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1560. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1561. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1562. ( frame->*fn )( a, b, c, d, e );
  1563. }
  1564. };
  1565. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  1566. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F ) >
  1567. {
  1568. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1569. static const int NUM_ARGS = 6 + startArgc;
  1570. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F ) >& defaultArgs )
  1571. {
  1572. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1573. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1574. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1575. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1576. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1577. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1578. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f ) );
  1579. }
  1580. template< typename Frame >
  1581. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F ) >& defaultArgs )
  1582. {
  1583. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1584. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1585. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1586. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1587. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1588. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1589. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f ) );
  1590. }
  1591. };
  1592. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F >
  1593. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F ) >
  1594. {
  1595. typedef void ReturnType;
  1596. static const int NUM_ARGS = 6 + startArgc;
  1597. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F ) >& defaultArgs )
  1598. {
  1599. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1600. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1601. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1602. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1603. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1604. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1605. fn( a, b, c, d, e, f );
  1606. }
  1607. template< typename Frame >
  1608. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F ) >& defaultArgs )
  1609. {
  1610. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1611. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1612. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1613. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1614. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1615. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1616. ( frame->*fn )( a, b, c, d, e, f );
  1617. }
  1618. };
  1619. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  1620. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F, G ) >
  1621. {
  1622. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1623. static const int NUM_ARGS = 7 + startArgc;
  1624. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F, G ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G ) >& defaultArgs )
  1625. {
  1626. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1627. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1628. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1629. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1630. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1631. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1632. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1633. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f, g ) );
  1634. }
  1635. template< typename Frame >
  1636. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F, G ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G ) >& defaultArgs )
  1637. {
  1638. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1639. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1640. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1641. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1642. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1643. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1644. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1645. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f, g ) );
  1646. }
  1647. };
  1648. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  1649. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F, G ) >
  1650. {
  1651. typedef void ReturnType;
  1652. static const int NUM_ARGS = 7 + startArgc;
  1653. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F, G ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G ) >& defaultArgs )
  1654. {
  1655. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1656. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1657. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1658. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1659. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1660. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1661. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1662. fn( a, b, c, d, e, f, g );
  1663. }
  1664. template< typename Frame >
  1665. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F, G ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G ) >& defaultArgs )
  1666. {
  1667. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1668. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1669. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1670. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1671. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1672. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1673. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1674. ( frame->*fn )( a, b, c, d, e, f, g );
  1675. }
  1676. };
  1677. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  1678. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F, G, H ) >
  1679. {
  1680. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1681. static const int NUM_ARGS = 8 + startArgc;
  1682. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F, G, H ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H ) >& defaultArgs )
  1683. {
  1684. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1685. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1686. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1687. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1688. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1689. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1690. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1691. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1692. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f, g, h ) );
  1693. }
  1694. template< typename Frame >
  1695. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F, G, H ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H ) >& defaultArgs )
  1696. {
  1697. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1698. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1699. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1700. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1701. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1702. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1703. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1704. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1705. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f, g, h ) );
  1706. }
  1707. };
  1708. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  1709. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F, G, H ) >
  1710. {
  1711. typedef void ReturnType;
  1712. static const int NUM_ARGS = 8 + startArgc;
  1713. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F, G, H ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H ) >& defaultArgs )
  1714. {
  1715. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1716. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1717. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1718. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1719. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1720. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1721. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1722. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1723. fn( a, b, c, d, e, f, g, h );
  1724. }
  1725. template< typename Frame >
  1726. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F, G, H ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H ) >& defaultArgs )
  1727. {
  1728. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1729. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1730. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1731. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1732. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1733. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1734. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1735. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1736. ( frame->*fn )( a, b, c, d, e, f, g, h );
  1737. }
  1738. };
  1739. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  1740. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F, G, H, I ) >
  1741. {
  1742. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1743. static const int NUM_ARGS = 9 + startArgc;
  1744. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F, G, H, I ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I ) >& defaultArgs )
  1745. {
  1746. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1747. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1748. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1749. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1750. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1751. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1752. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1753. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1754. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1755. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f, g, h, i ) );
  1756. }
  1757. template< typename Frame >
  1758. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F, G, H, I ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I ) >& defaultArgs )
  1759. {
  1760. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1761. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1762. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1763. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1764. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1765. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1766. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1767. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1768. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1769. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f, g, h, i ) );
  1770. }
  1771. };
  1772. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  1773. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F, G, H, I ) >
  1774. {
  1775. typedef void ReturnType;
  1776. static const int NUM_ARGS = 9 + startArgc;
  1777. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F, G, H, I ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I ) >& defaultArgs )
  1778. {
  1779. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1780. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1781. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1782. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1783. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1784. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1785. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1786. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1787. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1788. fn( a, b, c, d, e, f, g, h, i );
  1789. }
  1790. template< typename Frame >
  1791. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F, G, H, I ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I ) >& defaultArgs )
  1792. {
  1793. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1794. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1795. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1796. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1797. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1798. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1799. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1800. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1801. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1802. ( frame->*fn )( a, b, c, d, e, f, g, h, i );
  1803. }
  1804. };
  1805. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  1806. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F, G, H, I, J ) >
  1807. {
  1808. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1809. static const int NUM_ARGS = 10 + startArgc;
  1810. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F, G, H, I, J ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I, J ) >& defaultArgs )
  1811. {
  1812. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1813. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1814. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1815. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1816. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1817. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1818. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1819. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1820. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1821. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.j ) );
  1822. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f, g, h, i, j ) );
  1823. }
  1824. template< typename Frame >
  1825. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F, G, H, I, J ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J ) >& defaultArgs )
  1826. {
  1827. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1828. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1829. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1830. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1831. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1832. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1833. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1834. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1835. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1836. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.k ) );
  1837. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f, g, h, i, j ) );
  1838. }
  1839. };
  1840. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  1841. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F, G, H, I, J ) >
  1842. {
  1843. typedef void ReturnType;
  1844. static const int NUM_ARGS = 10 + startArgc;
  1845. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F, G, H, I, J ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I, J ) >& defaultArgs )
  1846. {
  1847. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1848. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1849. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1850. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1851. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1852. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1853. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1854. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1855. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1856. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.j ) );
  1857. fn( a, b, c, d, e, f, g, h, i, j );
  1858. }
  1859. template< typename Frame >
  1860. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F, G, H, I, J ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J ) >& defaultArgs )
  1861. {
  1862. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1863. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1864. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1865. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1866. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1867. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1868. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1869. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1870. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1871. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.k ) );
  1872. ( frame->*fn )( a, b, c, d, e, f, g, h, i, j );
  1873. }
  1874. };
  1875. template< int startArgc, typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  1876. struct _EngineConsoleThunk< startArgc, R( A, B, C, D, E, F, G, H, I, J, K ) >
  1877. {
  1878. typedef typename _EngineConsoleThunkType< R >::ReturnType ReturnType;
  1879. static const int NUM_ARGS = 11 + startArgc;
  1880. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( *fn )( A, B, C, D, E, F, G, H, I, J, K ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I, J, K ) >& defaultArgs )
  1881. {
  1882. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1883. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1884. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1885. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1886. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1887. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1888. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1889. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1890. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1891. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.j ) );
  1892. K k = ( startArgc + 10 < argc ? EngineUnmarshallData< K >()( argv[ startArgc + 10 ] ) : K( defaultArgs.k ) );
  1893. return _EngineConsoleThunkReturnValue( fn( a, b, c, d, e, f, g, h, i, j, k ) );
  1894. }
  1895. template< typename Frame >
  1896. static ReturnType thunk( S32 argc, ConsoleValueRef *argv, R ( Frame::*fn )( A, B, C, D, E, F, G, H, I, J, K ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J, K ) >& defaultArgs )
  1897. {
  1898. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1899. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1900. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1901. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1902. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1903. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1904. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1905. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1906. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1907. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.k ) );
  1908. K k = ( startArgc + 10 < argc ? EngineUnmarshallData< K >()( argv[ startArgc + 10 ] ) : K( defaultArgs.l ) );
  1909. return _EngineConsoleThunkReturnValue( ( frame->*fn )( a, b, c, d, e, f, g, h, i, j, k ) );
  1910. }
  1911. };
  1912. template< int startArgc, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  1913. struct _EngineConsoleThunk< startArgc, void( A, B, C, D, E, F, G, H, I, J, K ) >
  1914. {
  1915. typedef void ReturnType;
  1916. static const int NUM_ARGS = 11 + startArgc;
  1917. static void thunk( S32 argc, ConsoleValueRef *argv, void ( *fn )( A, B, C, D, E, F, G, H, I, J, K ), const _EngineFunctionDefaultArguments< void( A, B, C, D, E, F, G, H, I, J, K ) >& defaultArgs )
  1918. {
  1919. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.a ) );
  1920. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.b ) );
  1921. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.c ) );
  1922. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.d ) );
  1923. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.e ) );
  1924. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.f ) );
  1925. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.g ) );
  1926. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.h ) );
  1927. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.i ) );
  1928. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.j ) );
  1929. K k = ( startArgc + 10 < argc ? EngineUnmarshallData< K >()( argv[ startArgc + 10 ] ) : K( defaultArgs.k ) );
  1930. fn( a, b, c, d, e, f, g, h, i, j, k );
  1931. }
  1932. template< typename Frame >
  1933. static void thunk( S32 argc, ConsoleValueRef *argv, void ( Frame::*fn )( A, B, C, D, E, F, G, H, I, J, K ) const, Frame* frame, const _EngineFunctionDefaultArguments< void( typename Frame::ObjectType*, A, B, C, D, E, F, G, H, I, J, K ) >& defaultArgs )
  1934. {
  1935. A a = ( startArgc < argc ? EngineUnmarshallData< A >()( argv[ startArgc ] ) : A( defaultArgs.b ) );
  1936. B b = ( startArgc + 1 < argc ? EngineUnmarshallData< B >()( argv[ startArgc + 1 ] ) : B( defaultArgs.c ) );
  1937. C c = ( startArgc + 2 < argc ? EngineUnmarshallData< C >()( argv[ startArgc + 2 ] ) : C( defaultArgs.d ) );
  1938. D d = ( startArgc + 3 < argc ? EngineUnmarshallData< D >()( argv[ startArgc + 3 ] ) : D( defaultArgs.e ) );
  1939. E e = ( startArgc + 4 < argc ? EngineUnmarshallData< E >()( argv[ startArgc + 4 ] ) : E( defaultArgs.f ) );
  1940. F f = ( startArgc + 5 < argc ? EngineUnmarshallData< F >()( argv[ startArgc + 5 ] ) : F( defaultArgs.g ) );
  1941. G g = ( startArgc + 6 < argc ? EngineUnmarshallData< G >()( argv[ startArgc + 6 ] ) : G( defaultArgs.h ) );
  1942. H h = ( startArgc + 7 < argc ? EngineUnmarshallData< H >()( argv[ startArgc + 7 ] ) : H( defaultArgs.i ) );
  1943. I i = ( startArgc + 8 < argc ? EngineUnmarshallData< I >()( argv[ startArgc + 8 ] ) : I( defaultArgs.j ) );
  1944. J j = ( startArgc + 9 < argc ? EngineUnmarshallData< J >()( argv[ startArgc + 9 ] ) : J( defaultArgs.k ) );
  1945. K k = ( startArgc + 10 < argc ? EngineUnmarshallData< K >()( argv[ startArgc + 10 ] ) : K( defaultArgs.l ) );
  1946. ( frame->*fn )( a, b, c, d, e, f, g, h, i, j, k );
  1947. }
  1948. };
  1949. /// @}
  1950. /// @name API Definition Macros
  1951. ///
  1952. /// The macros in this group allow to create engine API functions that work both with the
  1953. /// legacy console system as well as with the new engine export system. As such, they only
  1954. /// support those function features that are available in both systems. This means that for
  1955. /// console-style variadic functions, the ConsoleXXX must be used and that for overloaded
  1956. /// and/or C-style variadic functions as well as for placing functions in export scopes,
  1957. /// DEFINE_CALLIN must be used directly.
  1958. ///
  1959. /// When the console system is removed, the console thunking functionality will be removed
  1960. /// from these macros but otherwise they will remain unchanged and in place.
  1961. ///
  1962. /// @{
  1963. // Helpers to implement initialization checks. Pulled out into separate macros so this can be deactivated easily.
  1964. // Especially important for the initialize() function itself.
  1965. #define _CHECK_ENGINE_INITIALIZED_IMPL( fnName, returnType ) \
  1966. if( !engineAPI::gIsInitialized ) \
  1967. { \
  1968. Con::errorf( "EngineAPI: Engine not initialized when calling " #fnName ); \
  1969. return EngineTypeTraits< returnType >::ReturnValue( EngineTypeTraits< returnType >::ReturnValueType() ); \
  1970. }
  1971. #define _CHECK_ENGINE_INITIALIZED( fnName, returnType ) _CHECK_ENGINE_INITIALIZED_IMPL( fnName, returnType )
  1972. /// Define a call-in point for calling into the engine.
  1973. ///
  1974. /// @param name The name of the function as it should be seen by the control layer.
  1975. /// @param returnType The value type returned to the control layer.
  1976. /// @param args The argument list as it would appear on the function definition
  1977. /// @param defaultArgs The list of default argument values.
  1978. /// @param usage The usage doc string for the engine API reference.
  1979. ///
  1980. /// @code
  1981. /// DefineEngineFunction( myFunction, int, ( float f, const String& s ), ( "value for s" ), "This is my function." )
  1982. /// {
  1983. /// return int( f ) + dAtoi( s );
  1984. /// }
  1985. /// @endcode
  1986. #define DefineEngineFunction( name, returnType, args, defaultArgs, usage ) \
  1987. static inline returnType _fn ## name ## impl args; \
  1988. TORQUE_API EngineTypeTraits< returnType >::ReturnValueType fn ## name \
  1989. ( _EngineFunctionTrampoline< returnType args >::Args a ) \
  1990. { \
  1991. _CHECK_ENGINE_INITIALIZED( name, returnType ); \
  1992. return EngineTypeTraits< returnType >::ReturnValue( \
  1993. _EngineFunctionTrampoline< returnType args >::jmp( _fn ## name ## impl, a ) \
  1994. ); \
  1995. } \
  1996. static _EngineFunctionDefaultArguments< void args > _fn ## name ## DefaultArgs defaultArgs; \
  1997. static EngineFunctionInfo _fn ## name ## FunctionInfo( \
  1998. #name, \
  1999. &_SCOPE<>()(), \
  2000. usage, \
  2001. #returnType " " #name #args, \
  2002. "fn" #name, \
  2003. TYPE< returnType args >(), \
  2004. &_fn ## name ## DefaultArgs, \
  2005. ( void* ) &fn ## name, \
  2006. 0 \
  2007. ); \
  2008. static _EngineConsoleThunkType< returnType >::ReturnType _ ## name ## caster( SimObject*, S32 argc, ConsoleValueRef *argv ) \
  2009. { \
  2010. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 1, returnType args >::thunk( \
  2011. argc, argv, &_fn ## name ## impl, _fn ## name ## DefaultArgs \
  2012. ) ); \
  2013. } \
  2014. static ConsoleFunctionHeader _ ## name ## header \
  2015. ( #returnType, #args, #defaultArgs ); \
  2016. static ConsoleConstructor \
  2017. _ ## name ## obj( NULL, #name, _EngineConsoleThunkType< returnType >::CallbackType( _ ## name ## caster ), usage, \
  2018. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2019. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS, \
  2020. false, &_ ## name ## header \
  2021. ); \
  2022. static inline returnType _fn ## name ## impl args
  2023. // The next thing is a bit tricky. DefineEngineMethod allows to make the 'object' (=this) argument to the function
  2024. // implicit which presents quite an obstacle for the macro internals as the engine export system requires the
  2025. // name of a DLL symbol that represents an extern "C" function with an explicit first object pointer argument.
  2026. //
  2027. // Even if we ignored the fact that we don't have a guarantee how the various C++ compilers implement implicit 'this' arguments,
  2028. // we could still not just use a C++ method for this as then we would have to get past the C++ compiler's mangling to
  2029. // get to the function symbol name (let alone the fact that typing this method correctly would be tricky).
  2030. //
  2031. // So, the trick employed here is to package all but the implicit 'this' argument in a structure and then define an
  2032. // extern "C" function that takes the object pointer as a first argument and the struct type as the second argument.
  2033. // This will result in a function with an identical stack call frame layout to the function we want.
  2034. //
  2035. // Unfortunately, that still requires that function to chain on to the real user-defined function. To do this
  2036. // cleanly and portably, _EngineMethodTrampoline is used to unpack and jump the call from extern "C" into C++ space.
  2037. // In optimized builds, the compiler should be smart enough to pretty much optimize all our trickery here away.
  2038. #define _DefineMethodTrampoline( className, name, returnType, args ) \
  2039. TORQUE_API EngineTypeTraits< returnType >::ReturnValueType \
  2040. fn ## className ## _ ## name ( className* object, _EngineMethodTrampoline< _ ## className ## name ## frame, returnType args >::Args a ) \
  2041. { \
  2042. _CHECK_ENGINE_INITIALIZED( className::name, returnType ); \
  2043. return EngineTypeTraits< returnType >::ReturnValue( \
  2044. _EngineMethodTrampoline< _ ## className ## name ## frame, returnType args >::jmp( object, a ) \
  2045. ); \
  2046. }
  2047. /// Define a call-in point for calling a method on an engine object.
  2048. ///
  2049. /// @param name The name of the C++ class.
  2050. /// @param name The name of the method as it should be seen by the control layer.
  2051. /// @param returnType The value type returned to the control layer.
  2052. /// @param args The argument list as it would appear on the function definition
  2053. /// @param defaultArgs The list of default argument values.
  2054. /// @param usage The usage doc string for the engine API reference.
  2055. ///
  2056. /// @code
  2057. /// DefineEngineMethod( MyClass, myMethod, int, ( float f, const String& s ), ( "value for s" ), "This is my method." )
  2058. /// {
  2059. /// return object->someMethod( f, s );
  2060. /// }
  2061. /// @endcode
  2062. #define DefineEngineMethod( className, name, returnType, args, defaultArgs, usage ) \
  2063. struct _ ## className ## name ## frame \
  2064. { \
  2065. typedef className ObjectType; \
  2066. className* object; \
  2067. inline returnType _exec args const; \
  2068. }; \
  2069. _DefineMethodTrampoline( className, name, returnType, args ); \
  2070. static _EngineFunctionDefaultArguments< _EngineMethodTrampoline< _ ## className ## name ## frame, void args >::FunctionType > \
  2071. _fn ## className ## name ## DefaultArgs defaultArgs; \
  2072. static EngineFunctionInfo _fn ## className ## name ## FunctionInfo( \
  2073. #name, \
  2074. &_SCOPE< className >()(), \
  2075. usage, \
  2076. "virtual " #returnType " " #name #args, \
  2077. "fn" #className "_" #name, \
  2078. TYPE< _EngineMethodTrampoline< _ ## className ## name ## frame, returnType args >::FunctionType >(), \
  2079. &_fn ## className ## name ## DefaultArgs, \
  2080. ( void* ) &fn ## className ## _ ## name, \
  2081. 0 \
  2082. ); \
  2083. static _EngineConsoleThunkType< returnType >::ReturnType _ ## className ## name ## caster( SimObject* object, S32 argc, ConsoleValueRef *argv ) \
  2084. { \
  2085. _ ## className ## name ## frame frame; \
  2086. frame.object = static_cast< className* >( object ); \
  2087. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 2, returnType args >::thunk( \
  2088. argc, argv, &_ ## className ## name ## frame::_exec, &frame, _fn ## className ## name ## DefaultArgs \
  2089. ) ); \
  2090. } \
  2091. static ConsoleFunctionHeader _ ## className ## name ## header \
  2092. ( #returnType, #args, #defaultArgs ); \
  2093. static ConsoleConstructor \
  2094. className ## name ## obj( #className, #name, \
  2095. _EngineConsoleThunkType< returnType >::CallbackType( _ ## className ## name ## caster ), usage, \
  2096. _EngineConsoleThunk< 2, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2097. _EngineConsoleThunk< 2, returnType args >::NUM_ARGS, \
  2098. false, &_ ## className ## name ## header \
  2099. ); \
  2100. returnType _ ## className ## name ## frame::_exec args const
  2101. /// Define a call-in point for calling into the engine. Unlike with DefineEngineFunction, the statically
  2102. /// callable function will be confined to the namespace of the given class.
  2103. ///
  2104. /// @param name The name of the C++ class (or a registered export scope).
  2105. /// @param name The name of the method as it should be seen by the control layer.
  2106. /// @param returnType The value type returned to the control layer.
  2107. /// @param args The argument list as it would appear on the function definition
  2108. /// @param defaultArgs The list of default argument values.
  2109. /// @param usage The usage doc string for the engine API reference.
  2110. ///
  2111. /// @code
  2112. /// DefineEngineStaticMethod( MyClass, myMethod, int, ( float f, string s ), ( "value for s" ), "This is my method." )
  2113. /// {
  2114. /// }
  2115. /// @endcode
  2116. #define DefineEngineStaticMethod( className, name, returnType, args, defaultArgs, usage ) \
  2117. static inline returnType _fn ## className ## name ## impl args; \
  2118. TORQUE_API EngineTypeTraits< returnType >::ReturnValueType fn ## className ## _ ## name \
  2119. ( _EngineFunctionTrampoline< returnType args >::Args a ) \
  2120. { \
  2121. _CHECK_ENGINE_INITIALIZED( className::name, returnType ); \
  2122. return EngineTypeTraits< returnType >::ReturnValue( \
  2123. _EngineFunctionTrampoline< returnType args >::jmp( _fn ## className ## name ## impl, a ) \
  2124. ); \
  2125. } \
  2126. static _EngineFunctionDefaultArguments< void args > _fn ## className ## name ## DefaultArgs defaultArgs; \
  2127. static EngineFunctionInfo _fn ## name ## FunctionInfo( \
  2128. #name, \
  2129. &_SCOPE< className >()(), \
  2130. usage, \
  2131. #returnType " " #name #args, \
  2132. "fn" #className "_" #name, \
  2133. TYPE< returnType args >(), \
  2134. &_fn ## className ## name ## DefaultArgs, \
  2135. ( void* ) &fn ## className ## _ ## name, \
  2136. 0 \
  2137. ); \
  2138. static _EngineConsoleThunkType< returnType >::ReturnType _ ## className ## name ## caster( SimObject*, S32 argc, ConsoleValueRef *argv )\
  2139. { \
  2140. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 1, returnType args >::thunk( \
  2141. argc, argv, &_fn ## className ## name ## impl, _fn ## className ## name ## DefaultArgs \
  2142. ) ); \
  2143. } \
  2144. static ConsoleFunctionHeader _ ## className ## name ## header \
  2145. ( #returnType, #args, #defaultArgs, true ); \
  2146. static ConsoleConstructor \
  2147. _ ## className ## name ## obj( #className, #name, _EngineConsoleThunkType< returnType >::CallbackType( _ ## className ## name ## caster ), usage, \
  2148. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2149. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS, \
  2150. false, &_ ## className ## name ## header \
  2151. ); \
  2152. static inline returnType _fn ## className ## name ## impl args
  2153. // Convenience macros to allow defining functions that use the new marshalling features
  2154. // while being only visible in the console interop. When we drop the console system,
  2155. // these macros can be removed and all definitions that make use of them can be removed
  2156. // as well.
  2157. #define DefineConsoleFunction( name, returnType, args, defaultArgs, usage ) \
  2158. static inline returnType _fn ## name ## impl args; \
  2159. static _EngineFunctionDefaultArguments< void args > _fn ## name ## DefaultArgs defaultArgs; \
  2160. static _EngineConsoleThunkType< returnType >::ReturnType _ ## name ## caster( SimObject*, S32 argc, ConsoleValueRef *argv ) \
  2161. { \
  2162. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 1, returnType args >::thunk( \
  2163. argc, argv, &_fn ## name ## impl, _fn ## name ## DefaultArgs \
  2164. ) ); \
  2165. } \
  2166. static ConsoleFunctionHeader _ ## name ## header \
  2167. ( #returnType, #args, #defaultArgs ); \
  2168. static ConsoleConstructor \
  2169. _ ## name ## obj( NULL, #name, _EngineConsoleThunkType< returnType >::CallbackType( _ ## name ## caster ), usage, \
  2170. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2171. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS, \
  2172. false, &_ ## name ## header \
  2173. ); \
  2174. static inline returnType _fn ## name ## impl args
  2175. #define DefineConsoleMethod( className, name, returnType, args, defaultArgs, usage ) \
  2176. struct _ ## className ## name ## frame \
  2177. { \
  2178. typedef className ObjectType; \
  2179. className* object; \
  2180. inline returnType _exec args const; \
  2181. }; \
  2182. static _EngineFunctionDefaultArguments< _EngineMethodTrampoline< _ ## className ## name ## frame, void args >::FunctionType > \
  2183. _fn ## className ## name ## DefaultArgs defaultArgs; \
  2184. static _EngineConsoleThunkType< returnType >::ReturnType _ ## className ## name ## caster( SimObject* object, S32 argc, ConsoleValueRef *argv ) \
  2185. { \
  2186. _ ## className ## name ## frame frame; \
  2187. frame.object = static_cast< className* >( object ); \
  2188. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 2, returnType args >::thunk( \
  2189. argc, argv, &_ ## className ## name ## frame::_exec, &frame, _fn ## className ## name ## DefaultArgs \
  2190. ) ); \
  2191. } \
  2192. static ConsoleFunctionHeader _ ## className ## name ## header \
  2193. ( #returnType, #args, #defaultArgs ); \
  2194. static ConsoleConstructor \
  2195. className ## name ## obj( #className, #name, \
  2196. _EngineConsoleThunkType< returnType >::CallbackType( _ ## className ## name ## caster ), usage, \
  2197. _EngineConsoleThunk< 2, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2198. _EngineConsoleThunk< 2, returnType args >::NUM_ARGS, \
  2199. false, &_ ## className ## name ## header \
  2200. ); \
  2201. returnType _ ## className ## name ## frame::_exec args const
  2202. #define DefineConsoleStaticMethod( className, name, returnType, args, defaultArgs, usage ) \
  2203. static inline returnType _fn ## className ## name ## impl args; \
  2204. static _EngineFunctionDefaultArguments< void args > _fn ## className ## name ## DefaultArgs defaultArgs; \
  2205. static _EngineConsoleThunkType< returnType >::ReturnType _ ## className ## name ## caster( SimObject*, S32 argc, ConsoleValueRef *argv )\
  2206. { \
  2207. return _EngineConsoleThunkType< returnType >::ReturnType( _EngineConsoleThunk< 1, returnType args >::thunk( \
  2208. argc, argv, &_fn ## className ## name ## impl, _fn ## className ## name ## DefaultArgs \
  2209. ) ); \
  2210. } \
  2211. static ConsoleFunctionHeader _ ## className ## name ## header \
  2212. ( #returnType, #args, #defaultArgs, true ); \
  2213. static ConsoleConstructor \
  2214. _ ## className ## name ## obj( #className, #name, _EngineConsoleThunkType< returnType >::CallbackType( _ ## className ## name ## caster ), usage, \
  2215. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS - _EngineConsoleThunkCountArgs() defaultArgs, \
  2216. _EngineConsoleThunk< 1, returnType args >::NUM_ARGS, \
  2217. false, &_ ## className ## name ## header \
  2218. ); \
  2219. static inline returnType _fn ## className ## name ## impl args
  2220. // The following three macros are only temporary. They allow to define engineAPI functions using the framework
  2221. // here in this file while being visible only in the new API. When the console interop is removed, these macros
  2222. // can be removed and all their uses be replaced with their corresponding versions that now still include support
  2223. // for the console (e.g. DefineNewEngineFunction should become DefineEngineFunction).
  2224. #define DefineNewEngineFunction( name, returnType, args, defaultArgs, usage ) \
  2225. static inline returnType _fn ## name ## impl args; \
  2226. TORQUE_API EngineTypeTraits< returnType >::ReturnValueType fn ## name \
  2227. ( _EngineFunctionTrampoline< returnType args >::Args a ) \
  2228. { \
  2229. _CHECK_ENGINE_INITIALIZED( name, returnType ); \
  2230. return EngineTypeTraits< returnType >::ReturnValue( \
  2231. _EngineFunctionTrampoline< returnType args >::jmp( _fn ## name ## impl, a ) \
  2232. ); \
  2233. } \
  2234. static _EngineFunctionDefaultArguments< void args > _fn ## name ## DefaultArgs defaultArgs; \
  2235. static EngineFunctionInfo _fn ## name ## FunctionInfo( \
  2236. #name, \
  2237. &_SCOPE<>()(), \
  2238. usage, \
  2239. #returnType " " #name #args, \
  2240. "fn" #name, \
  2241. TYPE< returnType args >(), \
  2242. &_fn ## name ## DefaultArgs, \
  2243. ( void* ) &fn ## name, \
  2244. 0 \
  2245. ); \
  2246. static inline returnType _fn ## name ## impl args
  2247. #define DefineNewEngineMethod( className, name, returnType, args, defaultArgs, usage ) \
  2248. struct _ ## className ## name ## frame \
  2249. { \
  2250. typedef className ObjectType; \
  2251. className* object; \
  2252. inline returnType _exec args const; \
  2253. }; \
  2254. _DefineMethodTrampoline( className, name, returnType, args ); \
  2255. static _EngineFunctionDefaultArguments< _EngineMethodTrampoline< _ ## className ## name ## frame, void args >::FunctionType > \
  2256. _fn ## className ## name ## DefaultArgs defaultArgs; \
  2257. static EngineFunctionInfo _fn ## className ## name ## FunctionInfo( \
  2258. #name, \
  2259. &_SCOPE< className >()(), \
  2260. usage, \
  2261. "virtual " #returnType " " #name #args, \
  2262. "fn" #className "_" #name, \
  2263. TYPE< _EngineMethodTrampoline< _ ## className ## name ## frame, returnType args >::FunctionType >(), \
  2264. &_fn ## className ## name ## DefaultArgs, \
  2265. ( void* ) &fn ## className ## _ ## name, \
  2266. 0 \
  2267. ); \
  2268. returnType _ ## className ## name ## frame::_exec args const
  2269. #define DefineNewEngineStaticMethod( className, name, returnType, args, defaultArgs, usage ) \
  2270. static inline returnType _fn ## className ## name ## impl args; \
  2271. TORQUE_API EngineTypeTraits< returnType >::ReturnValueType fn ## className ## _ ## name \
  2272. ( _EngineFunctionTrampoline< returnType args >::Args a ) \
  2273. { \
  2274. _CHECK_ENGINE_INITIALIZED( className::name, returnType ); \
  2275. return EngineTypeTraits< returnType >::ReturnValue( \
  2276. _EngineFunctionTrampoline< returnType args >::jmp( _fn ## className ## name ## impl, a ) \
  2277. ); \
  2278. } \
  2279. static _EngineFunctionDefaultArguments< void args > _fn ## className ## name ## DefaultArgs defaultArgs; \
  2280. static EngineFunctionInfo _fn ## name ## FunctionInfo( \
  2281. #name, \
  2282. &_SCOPE< className >()(), \
  2283. usage, \
  2284. #returnType " " #name #args, \
  2285. "fn" #className "_" #name, \
  2286. TYPE< returnType args >(), \
  2287. &_fn ## className ## name ## DefaultArgs, \
  2288. ( void* ) &fn ## className ## _ ## name, \
  2289. 0 \
  2290. ); \
  2291. static inline returnType _fn ## className ## name ## impl args
  2292. /// @}
  2293. //=============================================================================
  2294. // Callbacks.
  2295. //=============================================================================
  2296. /// Matching implement for DECLARE_CALLBACK.
  2297. ///
  2298. ///
  2299. /// @warn With the new interop system, method-style callbacks <em>must not</em> be triggered on object
  2300. /// that are being created! This is because the control layer will likely not yet have a fully valid wrapper
  2301. /// object in place for the EngineObject under construction.
  2302. #define IMPLEMENT_CALLBACK( class, name, returnType, args, argNames, usageString ) \
  2303. struct _ ## class ## name ## frame { typedef class ObjectType; }; \
  2304. TORQUE_API _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType* cb ## class ## _ ## name; \
  2305. TORQUE_API void set_cb ## class ## _ ## name( \
  2306. _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType fn ) \
  2307. { cb ## class ## _ ## name = fn; } \
  2308. _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType* cb ## class ## _ ## name; \
  2309. namespace { \
  2310. ::EngineFunctionInfo _cb ## class ## name( \
  2311. #name, \
  2312. &::_SCOPE< class >()(), \
  2313. usageString, \
  2314. "virtual " #returnType " " #name #args, \
  2315. "cb" #class "_" #name, \
  2316. ::TYPE< _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType >(), \
  2317. NULL, \
  2318. ( void* ) &cb ## class ## _ ## name, \
  2319. EngineFunctionCallout \
  2320. ); \
  2321. } \
  2322. returnType class::name ## _callback args \
  2323. { \
  2324. if( cb ## class ## _ ## name ) { \
  2325. _EngineCallbackHelper cbh( this, reinterpret_cast< const void* >( cb ## class ## _ ## name ) ); \
  2326. return returnType( cbh.call< returnType > argNames ); \
  2327. } \
  2328. if( engineAPI::gUseConsoleInterop ) \
  2329. { \
  2330. static StringTableEntry sName = StringTable->insert( #name ); \
  2331. _EngineConsoleCallbackHelper cbh( sName, this ); \
  2332. return returnType( cbh.call< returnType > argNames ); \
  2333. } \
  2334. return returnType(); \
  2335. } \
  2336. namespace { \
  2337. ConsoleFunctionHeader _ ## class ## name ## header( \
  2338. #returnType, #args, "" ); \
  2339. ConsoleConstructor _ ## class ## name ## obj( #class, #name, usageString, &_ ## class ## name ## header ); \
  2340. }
  2341. /// Used to define global callbacks not associated with
  2342. /// any particular class or namespace.
  2343. #define IMPLEMENT_GLOBAL_CALLBACK( name, returnType, args, argNames, usageString ) \
  2344. DEFINE_CALLOUT( cb ## name, name,, returnType, args, 0, usageString ); \
  2345. returnType name ## _callback args \
  2346. { \
  2347. if( cb ## name ) \
  2348. return returnType( cb ## name argNames ); \
  2349. if( engineAPI::gUseConsoleInterop ) \
  2350. { \
  2351. static StringTableEntry sName = StringTable->insert( #name ); \
  2352. _EngineConsoleCallbackHelper cbh( sName, NULL ); \
  2353. return returnType( cbh.call< returnType > argNames ); \
  2354. } \
  2355. return returnType(); \
  2356. } \
  2357. namespace { \
  2358. ConsoleFunctionHeader _ ## name ## header( \
  2359. #returnType, #args, "" ); \
  2360. ConsoleConstructor _ ## name ## obj( NULL, #name, usageString, &_ ## name ## header ); \
  2361. }
  2362. // Again, temporary macros to allow splicing the API while we still have the console interop around.
  2363. #define IMPLEMENT_CONSOLE_CALLBACK( class, name, returnType, args, argNames, usageString ) \
  2364. returnType class::name ## _callback args \
  2365. { \
  2366. if( engineAPI::gUseConsoleInterop ) \
  2367. { \
  2368. static StringTableEntry sName = StringTable->insert( #name ); \
  2369. _EngineConsoleCallbackHelper cbh( sName, this ); \
  2370. return returnType( cbh.call< returnType > argNames ); \
  2371. } \
  2372. return returnType(); \
  2373. } \
  2374. namespace { \
  2375. ConsoleFunctionHeader _ ## class ## name ## header( \
  2376. #returnType, #args, "" ); \
  2377. ConsoleConstructor _ ## class ## name ## obj( #class, #name, usageString, &_ ## class ## name ## header ); \
  2378. }
  2379. #define IMPLEMENT_NEW_CALLBACK( class, name, returnType, args, argNames, usageString ) \
  2380. struct _ ## class ## name ## frame { typedef class ObjectType; }; \
  2381. TORQUE_API _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType* cb ## class ## _ ## name; \
  2382. TORQUE_API void set_cb ## class ## _ ## name( \
  2383. _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType fn ) \
  2384. { cb ## class ## _ ## name = fn; } \
  2385. _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType* cb ## class ## _ ## name; \
  2386. namespace { \
  2387. ::EngineFunctionInfo _cb ## class ## name( \
  2388. #name, \
  2389. &::_SCOPE< class >()(), \
  2390. usageString, \
  2391. "virtual " #returnType " " #name #args, \
  2392. "cb" #class "_" #name, \
  2393. ::TYPE< _EngineMethodTrampoline< _ ## class ## name ## frame, returnType args >::FunctionType >(), \
  2394. NULL, \
  2395. &cb ## class ## _ ## name, \
  2396. EngineFunctionCallout \
  2397. ); \
  2398. } \
  2399. returnType class::name ## _callback args \
  2400. { \
  2401. if( cb ## class ## _ ## name ) { \
  2402. _EngineCallbackHelper cbh( this, reinterpret_cast< const void* >( cb ## class ## _ ## name ) ); \
  2403. return returnType( cbh.call< returnType > argNames ); \
  2404. } \
  2405. return returnType(); \
  2406. }
  2407. // Internal helper class for doing call-outs in the new interop.
  2408. struct _EngineCallbackHelper
  2409. {
  2410. protected:
  2411. EngineObject* mThis;
  2412. const void* mFn;
  2413. public:
  2414. _EngineCallbackHelper( EngineObject* pThis, const void* fn )
  2415. : mThis( pThis ),
  2416. mFn( fn ) {}
  2417. template< typename R >
  2418. R call() const
  2419. {
  2420. typedef R( FunctionType )( EngineObject* );
  2421. return R( reinterpret_cast< FunctionType* >( mFn )( mThis ) );
  2422. }
  2423. template< typename R, typename A >
  2424. R call( A a ) const
  2425. {
  2426. typedef R( FunctionType )( EngineObject*, A );
  2427. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a ) );
  2428. }
  2429. template< typename R, typename A, typename B >
  2430. R call( A a, B b ) const
  2431. {
  2432. typedef R( FunctionType )( EngineObject*, A, B );
  2433. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b ) );
  2434. }
  2435. template< typename R, typename A, typename B, typename C >
  2436. R call( A a, B b, C c ) const
  2437. {
  2438. typedef R( FunctionType )( EngineObject*, A, B, C );
  2439. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c ) );
  2440. }
  2441. template< typename R, typename A, typename B, typename C, typename D >
  2442. R call( A a, B b, C c, D d ) const
  2443. {
  2444. typedef R( FunctionType )( EngineObject*, A, B, C, D );
  2445. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d ) );
  2446. }
  2447. template< typename R, typename A, typename B, typename C, typename D, typename E >
  2448. R call( A a, B b, C c, D d, E e ) const
  2449. {
  2450. typedef R( FunctionType )( EngineObject*, A, B, C, D, E );
  2451. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e ) );
  2452. }
  2453. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  2454. R call( A a, B b, C c, D d, E e, F f ) const
  2455. {
  2456. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F );
  2457. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f ) );
  2458. }
  2459. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  2460. R call( A a, B b, C c, D d, E e, F f, G g ) const
  2461. {
  2462. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G );
  2463. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g ) );
  2464. }
  2465. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  2466. R call( A a, B b, C c, D d, E e, F f, G g, H h ) const
  2467. {
  2468. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G, H );
  2469. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g, h ) );
  2470. }
  2471. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  2472. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i ) const
  2473. {
  2474. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G, H, I );
  2475. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g, h, i ) );
  2476. }
  2477. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  2478. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j ) const
  2479. {
  2480. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G, H, I, J );
  2481. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g, h, i, j ) );
  2482. }
  2483. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  2484. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k ) const
  2485. {
  2486. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G, H, I, J, K );
  2487. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g, h, i, j, k ) );
  2488. }
  2489. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L >
  2490. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l ) const
  2491. {
  2492. typedef R( FunctionType )( EngineObject*, A, B, C, D, E, F, G, H, I, J, K, L l );
  2493. return R( reinterpret_cast< FunctionType* >( mFn )( mThis, a, b, c, d, e, f, g, h, i, j, k, l ) );
  2494. }
  2495. };
  2496. // Internal helper for callback support in legacy console system.
  2497. struct _EngineConsoleCallbackHelper
  2498. {
  2499. protected:
  2500. /// Matches up to storeArgs.
  2501. static const U32 MAX_ARGUMENTS = 11;
  2502. SimObject* mThis;
  2503. S32 mArgc;
  2504. ConsoleValueRef mArgv[ MAX_ARGUMENTS + 2 ];
  2505. const char* _exec()
  2506. {
  2507. if( mThis )
  2508. {
  2509. // Cannot invoke callback until object has been registered
  2510. if (mThis->isProperlyAdded()) {
  2511. return Con::execute( mThis, mArgc, mArgv );
  2512. } else {
  2513. Con::resetStackFrame(); // jamesu - we might have pushed some vars here
  2514. return "";
  2515. }
  2516. }
  2517. else
  2518. return Con::execute( mArgc, mArgv );
  2519. }
  2520. public:
  2521. _EngineConsoleCallbackHelper( StringTableEntry callbackName, SimObject* pThis )
  2522. : mThis( pThis ),
  2523. mArgc( pThis ? 2 : 1 )
  2524. {
  2525. mArgv[ 0 ] = callbackName;
  2526. }
  2527. template< typename R >
  2528. R call()
  2529. {
  2530. return R( EngineUnmarshallData< R >()( _exec() ) );
  2531. }
  2532. template< typename R, typename A >
  2533. R call( A a )
  2534. {
  2535. EngineMarshallData( a, mArgc, mArgv );
  2536. return R( EngineUnmarshallData< R >()( _exec() ) );
  2537. }
  2538. template< typename R, typename A, typename B >
  2539. R call( A a, B b )
  2540. {
  2541. EngineMarshallData( a, mArgc, mArgv );
  2542. EngineMarshallData( b, mArgc, mArgv );
  2543. return R( EngineUnmarshallData< R >()( _exec() ) );
  2544. }
  2545. template< typename R, typename A, typename B, typename C >
  2546. R call( A a, B b, C c )
  2547. {
  2548. EngineMarshallData( a, mArgc, mArgv );
  2549. EngineMarshallData( b, mArgc, mArgv );
  2550. EngineMarshallData( c, mArgc, mArgv );
  2551. return R( EngineUnmarshallData< R >()( _exec() ) );
  2552. }
  2553. template< typename R, typename A, typename B, typename C, typename D >
  2554. R call( A a, B b, C c, D d )
  2555. {
  2556. EngineMarshallData( a, mArgc, mArgv );
  2557. EngineMarshallData( b, mArgc, mArgv );
  2558. EngineMarshallData( c, mArgc, mArgv );
  2559. EngineMarshallData( d, mArgc, mArgv );
  2560. return R( EngineUnmarshallData< R >()( _exec() ) );
  2561. }
  2562. template< typename R, typename A, typename B, typename C, typename D, typename E >
  2563. R call( A a, B b, C c, D d, E e )
  2564. {
  2565. EngineMarshallData( a, mArgc, mArgv );
  2566. EngineMarshallData( b, mArgc, mArgv );
  2567. EngineMarshallData( c, mArgc, mArgv );
  2568. EngineMarshallData( d, mArgc, mArgv );
  2569. EngineMarshallData( e, mArgc, mArgv );
  2570. return R( EngineUnmarshallData< R >()( _exec() ) );
  2571. }
  2572. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F >
  2573. R call( A a, B b, C c, D d, E e, F f )
  2574. {
  2575. EngineMarshallData( a, mArgc, mArgv );
  2576. EngineMarshallData( b, mArgc, mArgv );
  2577. EngineMarshallData( c, mArgc, mArgv );
  2578. EngineMarshallData( d, mArgc, mArgv );
  2579. EngineMarshallData( e, mArgc, mArgv );
  2580. EngineMarshallData( f, mArgc, mArgv );
  2581. return R( EngineUnmarshallData< R >()( _exec() ) );
  2582. }
  2583. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G >
  2584. R call( A a, B b, C c, D d, E e, F f, G g )
  2585. {
  2586. EngineMarshallData( a, mArgc, mArgv );
  2587. EngineMarshallData( b, mArgc, mArgv );
  2588. EngineMarshallData( c, mArgc, mArgv );
  2589. EngineMarshallData( d, mArgc, mArgv );
  2590. EngineMarshallData( e, mArgc, mArgv );
  2591. EngineMarshallData( f, mArgc, mArgv );
  2592. EngineMarshallData( g, mArgc, mArgv );
  2593. return R( EngineUnmarshallData< R >()( _exec() ) );
  2594. }
  2595. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H >
  2596. R call( A a, B b, C c, D d, E e, F f, G g, H h )
  2597. {
  2598. EngineMarshallData( a, mArgc, mArgv );
  2599. EngineMarshallData( b, mArgc, mArgv );
  2600. EngineMarshallData( c, mArgc, mArgv );
  2601. EngineMarshallData( d, mArgc, mArgv );
  2602. EngineMarshallData( e, mArgc, mArgv );
  2603. EngineMarshallData( f, mArgc, mArgv );
  2604. EngineMarshallData( g, mArgc, mArgv );
  2605. EngineMarshallData( h, mArgc, mArgv );
  2606. return R( EngineUnmarshallData< R >()( _exec() ) );
  2607. }
  2608. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I >
  2609. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i )
  2610. {
  2611. EngineMarshallData( a, mArgc, mArgv );
  2612. EngineMarshallData( b, mArgc, mArgv );
  2613. EngineMarshallData( c, mArgc, mArgv );
  2614. EngineMarshallData( d, mArgc, mArgv );
  2615. EngineMarshallData( e, mArgc, mArgv );
  2616. EngineMarshallData( f, mArgc, mArgv );
  2617. EngineMarshallData( g, mArgc, mArgv );
  2618. EngineMarshallData( h, mArgc, mArgv );
  2619. EngineMarshallData( i, mArgc, mArgv );
  2620. return R( EngineUnmarshallData< R >()( _exec() ) );
  2621. }
  2622. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J >
  2623. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j )
  2624. {
  2625. EngineMarshallData( a, mArgc, mArgv );
  2626. EngineMarshallData( b, mArgc, mArgv );
  2627. EngineMarshallData( c, mArgc, mArgv );
  2628. EngineMarshallData( d, mArgc, mArgv );
  2629. EngineMarshallData( e, mArgc, mArgv );
  2630. EngineMarshallData( f, mArgc, mArgv );
  2631. EngineMarshallData( g, mArgc, mArgv );
  2632. EngineMarshallData( h, mArgc, mArgv );
  2633. EngineMarshallData( i, mArgc, mArgv );
  2634. EngineMarshallData( j, mArgc, mArgv );
  2635. return R( EngineUnmarshallData< R >()( _exec() ) );
  2636. }
  2637. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K >
  2638. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k )
  2639. {
  2640. EngineMarshallData( a, mArgc, mArgv );
  2641. EngineMarshallData( b, mArgc, mArgv );
  2642. EngineMarshallData( c, mArgc, mArgv );
  2643. EngineMarshallData( d, mArgc, mArgv );
  2644. EngineMarshallData( e, mArgc, mArgv );
  2645. EngineMarshallData( f, mArgc, mArgv );
  2646. EngineMarshallData( g, mArgc, mArgv );
  2647. EngineMarshallData( h, mArgc, mArgv );
  2648. EngineMarshallData( i, mArgc, mArgv );
  2649. EngineMarshallData( j, mArgc, mArgv );
  2650. EngineMarshallData( k, mArgc, mArgv );
  2651. return R( EngineUnmarshallData< R >()( _exec() ) );
  2652. }
  2653. template< typename R, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L >
  2654. R call( A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l )
  2655. {
  2656. EngineMarshallData( a, mArgc, mArgv );
  2657. EngineMarshallData( b, mArgc, mArgv );
  2658. EngineMarshallData( c, mArgc, mArgv );
  2659. EngineMarshallData( d, mArgc, mArgv );
  2660. EngineMarshallData( e, mArgc, mArgv );
  2661. EngineMarshallData( f, mArgc, mArgv );
  2662. EngineMarshallData( g, mArgc, mArgv );
  2663. EngineMarshallData( h, mArgc, mArgv );
  2664. EngineMarshallData( i, mArgc, mArgv );
  2665. EngineMarshallData( j, mArgc, mArgv );
  2666. EngineMarshallData( k, mArgc, mArgv );
  2667. EngineMarshallData( l, mArgc, mArgv );
  2668. return R( EngineUnmarshallData< R >()( _exec() ) );
  2669. }
  2670. };
  2671. // Re-enable some VC warnings we disabled for this file.
  2672. #pragma warning( default : 4510 )
  2673. #pragma warning( default : 4610 )
  2674. #endif // !_ENGINEAPI_H_