|
|
@ -67,10 +67,15 @@ namespace df {
|
|
|
|
CT *self = (CT*)DFHack::LuaWrapper::get_object_addr(state, base++, UPVAL_METHOD_NAME, "invoke");
|
|
|
|
CT *self = (CT*)DFHack::LuaWrapper::get_object_addr(state, base++, UPVAL_METHOD_NAME, "invoke");
|
|
|
|
#define LOAD_ARG(type) \
|
|
|
|
#define LOAD_ARG(type) \
|
|
|
|
type v##type; df::identity_traits<type>::get()->lua_write(state, UPVAL_METHOD_NAME, &v##type, base++);
|
|
|
|
type v##type; df::identity_traits<type>::get()->lua_write(state, UPVAL_METHOD_NAME, &v##type, base++);
|
|
|
|
|
|
|
|
#define OSTREAM_ARG DFHack::color_ostream&
|
|
|
|
|
|
|
|
#define LOAD_OSTREAM(name) \
|
|
|
|
|
|
|
|
DFHack::color_ostream_proxy name(DFHack::Core::getInstance().getConsole());
|
|
|
|
|
|
|
|
|
|
|
|
#define INSTANTIATE_WRAPPERS(Count, FArgs, Args, Loads) \
|
|
|
|
#define INSTANTIATE_RETURN_TYPE(FArgs) \
|
|
|
|
template<FW_TARGSC class RT> struct return_type<RT (*) FArgs> { typedef RT type; }; \
|
|
|
|
template<FW_TARGSC class RT> struct return_type<RT (*) FArgs> { typedef RT type; }; \
|
|
|
|
template<FW_TARGSC class RT, class CT> struct return_type<RT (CT::*) FArgs> { typedef RT type; }; \
|
|
|
|
template<FW_TARGSC class RT, class CT> struct return_type<RT (CT::*) FArgs> { typedef RT type; };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define INSTANTIATE_WRAPPERS(Count, FArgs, Args, Loads) \
|
|
|
|
template<FW_TARGS> struct function_wrapper<void (*) FArgs, true> { \
|
|
|
|
template<FW_TARGS> struct function_wrapper<void (*) FArgs, true> { \
|
|
|
|
static const bool is_method = false; \
|
|
|
|
static const bool is_method = false; \
|
|
|
|
static const int num_args = Count; \
|
|
|
|
static const int num_args = Count; \
|
|
|
@ -96,24 +101,35 @@ namespace df {
|
|
|
|
|
|
|
|
|
|
|
|
#define FW_TARGSC
|
|
|
|
#define FW_TARGSC
|
|
|
|
#define FW_TARGS
|
|
|
|
#define FW_TARGS
|
|
|
|
|
|
|
|
INSTANTIATE_RETURN_TYPE(())
|
|
|
|
INSTANTIATE_WRAPPERS(0, (), (), ;)
|
|
|
|
INSTANTIATE_WRAPPERS(0, (), (), ;)
|
|
|
|
|
|
|
|
INSTANTIATE_WRAPPERS(0, (OSTREAM_ARG), (out), LOAD_OSTREAM(out);)
|
|
|
|
#undef FW_TARGS
|
|
|
|
#undef FW_TARGS
|
|
|
|
|
|
|
|
|
|
|
|
#undef FW_TARGSC
|
|
|
|
#undef FW_TARGSC
|
|
|
|
#define FW_TARGSC FW_TARGS,
|
|
|
|
#define FW_TARGSC FW_TARGS,
|
|
|
|
#define FW_TARGS class A1
|
|
|
|
#define FW_TARGS class A1
|
|
|
|
|
|
|
|
INSTANTIATE_RETURN_TYPE((A1))
|
|
|
|
INSTANTIATE_WRAPPERS(1, (A1), (vA1), LOAD_ARG(A1);)
|
|
|
|
INSTANTIATE_WRAPPERS(1, (A1), (vA1), LOAD_ARG(A1);)
|
|
|
|
|
|
|
|
INSTANTIATE_WRAPPERS(1, (OSTREAM_ARG,A1), (out,vA1), LOAD_OSTREAM(out); LOAD_ARG(A1);)
|
|
|
|
#undef FW_TARGS
|
|
|
|
#undef FW_TARGS
|
|
|
|
|
|
|
|
|
|
|
|
#define FW_TARGS class A1, class A2
|
|
|
|
#define FW_TARGS class A1, class A2
|
|
|
|
|
|
|
|
INSTANTIATE_RETURN_TYPE((A1,A2))
|
|
|
|
INSTANTIATE_WRAPPERS(2, (A1,A2), (vA1,vA2), LOAD_ARG(A1); LOAD_ARG(A2);)
|
|
|
|
INSTANTIATE_WRAPPERS(2, (A1,A2), (vA1,vA2), LOAD_ARG(A1); LOAD_ARG(A2);)
|
|
|
|
|
|
|
|
INSTANTIATE_WRAPPERS(2, (OSTREAM_ARG,A1,A2), (out,vA1,vA2),
|
|
|
|
|
|
|
|
LOAD_OSTREAM(out); LOAD_ARG(A1); LOAD_ARG(A2);)
|
|
|
|
#undef FW_TARGS
|
|
|
|
#undef FW_TARGS
|
|
|
|
|
|
|
|
|
|
|
|
#define FW_TARGS class A1, class A2, class A3
|
|
|
|
#define FW_TARGS class A1, class A2, class A3
|
|
|
|
|
|
|
|
INSTANTIATE_RETURN_TYPE((A1,A2,A3))
|
|
|
|
INSTANTIATE_WRAPPERS(3, (A1,A2,A3), (vA1,vA2,vA3), LOAD_ARG(A1); LOAD_ARG(A2); LOAD_ARG(A3);)
|
|
|
|
INSTANTIATE_WRAPPERS(3, (A1,A2,A3), (vA1,vA2,vA3), LOAD_ARG(A1); LOAD_ARG(A2); LOAD_ARG(A3);)
|
|
|
|
|
|
|
|
INSTANTIATE_WRAPPERS(3, (OSTREAM_ARG,A1,A2,A3), (out,vA1,vA2,vA3),
|
|
|
|
|
|
|
|
LOAD_OSTREAM(out); LOAD_ARG(A1); LOAD_ARG(A2); LOAD_ARG(A3);)
|
|
|
|
#undef FW_TARGS
|
|
|
|
#undef FW_TARGS
|
|
|
|
|
|
|
|
|
|
|
|
#define FW_TARGS class A1, class A2, class A3, class A4
|
|
|
|
#define FW_TARGS class A1, class A2, class A3, class A4
|
|
|
|
|
|
|
|
INSTANTIATE_RETURN_TYPE((A1,A2,A3,A4))
|
|
|
|
INSTANTIATE_WRAPPERS(4, (A1,A2,A3,A4), (vA1,vA2,vA3,vA4),
|
|
|
|
INSTANTIATE_WRAPPERS(4, (A1,A2,A3,A4), (vA1,vA2,vA3,vA4),
|
|
|
|
LOAD_ARG(A1); LOAD_ARG(A2); LOAD_ARG(A3); LOAD_ARG(A4);)
|
|
|
|
LOAD_ARG(A1); LOAD_ARG(A2); LOAD_ARG(A3); LOAD_ARG(A4);)
|
|
|
|
#undef FW_TARGS
|
|
|
|
#undef FW_TARGS
|
|
|
@ -124,6 +140,8 @@ INSTANTIATE_WRAPPERS(4, (A1,A2,A3,A4), (vA1,vA2,vA3,vA4),
|
|
|
|
#undef INVOKE_RV
|
|
|
|
#undef INVOKE_RV
|
|
|
|
#undef LOAD_CLASS
|
|
|
|
#undef LOAD_CLASS
|
|
|
|
#undef LOAD_ARG
|
|
|
|
#undef LOAD_ARG
|
|
|
|
|
|
|
|
#undef OSTREAM_ARG
|
|
|
|
|
|
|
|
#undef LOAD_OSTREAM
|
|
|
|
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
template<class T>
|
|
|
|
class function_identity : public function_identity_base {
|
|
|
|
class function_identity : public function_identity_base {
|
|
|
|