X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fscripting%2Fwrapper.cpp;h=7b74d7ade8133d511cc64f652bc87d19549bfcae;hb=6492679a300bff2c17505c5d9bc9d333eeba384d;hp=1f8060b1a4c5e707ba632f6424856c3583b825ee;hpb=02afe1b64f521ccc6f81701c288dfd56d459215b;p=supertux.git diff --git a/src/scripting/wrapper.cpp b/src/scripting/wrapper.cpp index 1f8060b1a..7b74d7ade 100644 --- a/src/scripting/wrapper.cpp +++ b/src/scripting/wrapper.cpp @@ -3,73 +3,43 @@ * 'src/scripting/wrapper.interface.hpp' * DO NOT CHANGE */ -#include -#include -#include -#include #include -#include -#include "squirrel_error.hpp" -#include "wrapper.interface.hpp" -namespace Scripting -{ -namespace Wrapper -{ +#include "scripting/squirrel_error.hpp" +#include "scripting/wrapper.interface.hpp" -static SQInteger DisplayEffect_release_hook(SQUserPointer ptr, SQInteger ) +namespace scripting { +namespace wrapper { + +static SQInteger AmbientSound_release_hook(SQUserPointer ptr, SQInteger ) { - Scripting::DisplayEffect* _this = reinterpret_cast (ptr); + scripting::AmbientSound* _this = reinterpret_cast (ptr); delete _this; return 0; } -static SQInteger DisplayEffect_fade_out_wrapper(HSQUIRRELVM vm) +static SQInteger AmbientSound_set_pos_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'fade_out' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_pos' called without instance")); return SQ_ERROR; } - Scripting::DisplayEffect* _this = reinterpret_cast (data); + scripting::AmbientSound* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - - try { - _this->fade_out(static_cast (arg0)); - - return 0; - - } catch(std::exception& e) { - sq_throwerror(vm, e.what()); - return SQ_ERROR; - } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_out'")); - return SQ_ERROR; - } - -} - -static SQInteger DisplayEffect_fade_in_wrapper(HSQUIRRELVM vm) -{ - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'fade_in' called without instance")); - return SQ_ERROR; - } - Scripting::DisplayEffect* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); return SQ_ERROR; } try { - _this->fade_in(static_cast (arg0)); + _this->set_pos(static_cast (arg0), static_cast (arg1)); return 0; @@ -77,111 +47,80 @@ static SQInteger DisplayEffect_fade_in_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_in'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); return SQ_ERROR; } } -static SQInteger DisplayEffect_set_black_wrapper(HSQUIRRELVM vm) +static SQInteger AmbientSound_get_pos_x_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_black' called without instance")); - return SQ_ERROR; - } - Scripting::DisplayEffect* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_x' called without instance")); return SQ_ERROR; } + scripting::AmbientSound* _this = reinterpret_cast (data); try { - _this->set_black(arg0 == SQTrue); + float return_value = _this->get_pos_x(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_black'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); return SQ_ERROR; } } -static SQInteger DisplayEffect_is_black_wrapper(HSQUIRRELVM vm) +static SQInteger AmbientSound_get_pos_y_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'is_black' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_y' called without instance")); return SQ_ERROR; } - Scripting::DisplayEffect* _this = reinterpret_cast (data); + scripting::AmbientSound* _this = reinterpret_cast (data); try { - bool return_value = _this->is_black(); + float return_value = _this->get_pos_y(); - sq_pushbool(vm, return_value); + sq_pushfloat(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_black'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); return SQ_ERROR; } } -static SQInteger DisplayEffect_sixteen_to_nine_wrapper(HSQUIRRELVM vm) +static SQInteger Camera_release_hook(SQUserPointer ptr, SQInteger ) { - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'sixteen_to_nine' called without instance")); - return SQ_ERROR; - } - Scripting::DisplayEffect* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); - return SQ_ERROR; - } - - try { - _this->sixteen_to_nine(static_cast (arg0)); - - return 0; - - } catch(std::exception& e) { - sq_throwerror(vm, e.what()); - return SQ_ERROR; - } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'sixteen_to_nine'")); - return SQ_ERROR; - } - + scripting::Camera* _this = reinterpret_cast (ptr); + delete _this; + return 0; } -static SQInteger DisplayEffect_four_to_three_wrapper(HSQUIRRELVM vm) +static SQInteger Camera_reload_config_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'four_to_three' called without instance")); - return SQ_ERROR; - } - Scripting::DisplayEffect* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'reload_config' called without instance")); return SQ_ERROR; } + scripting::Camera* _this = reinterpret_cast (data); try { - _this->four_to_three(static_cast (arg0)); + _this->reload_config(); return 0; @@ -189,27 +128,20 @@ static SQInteger DisplayEffect_four_to_three_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'four_to_three'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'reload_config'")); return SQ_ERROR; } } -static SQInteger Camera_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Camera* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - static SQInteger Camera_shake_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'shake' called without instance")); return SQ_ERROR; } - Scripting::Camera* _this = reinterpret_cast (data); + scripting::Camera* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -244,11 +176,11 @@ static SQInteger Camera_shake_wrapper(HSQUIRRELVM vm) static SQInteger Camera_set_pos_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'set_pos' called without instance")); return SQ_ERROR; } - Scripting::Camera* _this = reinterpret_cast (data); + scripting::Camera* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -278,11 +210,11 @@ static SQInteger Camera_set_pos_wrapper(HSQUIRRELVM vm) static SQInteger Camera_set_mode_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'set_mode' called without instance")); return SQ_ERROR; } - Scripting::Camera* _this = reinterpret_cast (data); + scripting::Camera* _this = reinterpret_cast (data); const SQChar* arg0; if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a string")); @@ -307,11 +239,11 @@ static SQInteger Camera_set_mode_wrapper(HSQUIRRELVM vm) static SQInteger Camera_scroll_to_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'scroll_to' called without instance")); return SQ_ERROR; } - Scripting::Camera* _this = reinterpret_cast (data); + scripting::Camera* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -343,63 +275,54 @@ static SQInteger Camera_scroll_to_wrapper(HSQUIRRELVM vm) } -static SQInteger Level_release_hook(SQUserPointer ptr, SQInteger ) +static SQInteger Candle_release_hook(SQUserPointer ptr, SQInteger ) { - Scripting::Level* _this = reinterpret_cast (ptr); + scripting::Candle* _this = reinterpret_cast (ptr); delete _this; return 0; } -static SQInteger Level_finish_wrapper(HSQUIRRELVM vm) +static SQInteger Candle_get_burning_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'finish' called without instance")); - return SQ_ERROR; - } - Scripting::Level* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_burning' called without instance")); return SQ_ERROR; } + scripting::Candle* _this = reinterpret_cast (data); try { - _this->finish(arg0 == SQTrue); + bool return_value = _this->get_burning(); - return 0; + sq_pushbool(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'finish'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_burning'")); return SQ_ERROR; } } -static SQInteger Level_spawn_wrapper(HSQUIRRELVM vm) +static SQInteger Candle_set_burning_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'spawn' called without instance")); - return SQ_ERROR; - } - Scripting::Level* _this = reinterpret_cast (data); - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_burning' called without instance")); return SQ_ERROR; } - const SQChar* arg1; - if(SQ_FAILED(sq_getstring(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a string")); + scripting::Candle* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } try { - _this->spawn(arg0, arg1); + _this->set_burning(arg0 == SQTrue); return 0; @@ -407,23 +330,35 @@ static SQInteger Level_spawn_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'spawn'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_burning'")); return SQ_ERROR; } } -static SQInteger Level_flip_vertically_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_release_hook(SQUserPointer ptr, SQInteger ) +{ + scripting::DisplayEffect* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger DisplayEffect_fade_out_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'flip_vertically' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'fade_out' called without instance")); + return SQ_ERROR; + } + scripting::DisplayEffect* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - Scripting::Level* _this = reinterpret_cast (data); try { - _this->flip_vertically(); + _this->fade_out(static_cast (arg0)); return 0; @@ -431,23 +366,28 @@ static SQInteger Level_flip_vertically_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'flip_vertically'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_out'")); return SQ_ERROR; } } -static SQInteger Level_toggle_pause_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_fade_in_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'toggle_pause' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'fade_in' called without instance")); + return SQ_ERROR; + } + scripting::DisplayEffect* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - Scripting::Level* _this = reinterpret_cast (data); try { - _this->toggle_pause(); + _this->fade_in(static_cast (arg0)); return 0; @@ -455,35 +395,28 @@ static SQInteger Level_toggle_pause_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'toggle_pause'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_in'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::ScriptedObject* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger ScriptedObject_set_action_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_set_black_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_action' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_black' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + scripting::DisplayEffect* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } try { - _this->set_action(arg0); + _this->set_black(arg0 == SQTrue); return 0; @@ -491,58 +424,53 @@ static SQInteger ScriptedObject_set_action_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_action'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_black'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_get_action_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_is_black_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_action' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'is_black' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::DisplayEffect* _this = reinterpret_cast (data); try { - std::string return_value = _this->get_action(); + bool return_value = _this->is_black(); - sq_pushstring(vm, return_value.c_str(), return_value.size()); + sq_pushbool(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_action'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_black'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_move_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_sixteen_to_nine_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'move' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'sixteen_to_nine' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::DisplayEffect* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a float")); - return SQ_ERROR; - } try { - _this->move(static_cast (arg0), static_cast (arg1)); + _this->sixteen_to_nine(static_cast (arg0)); return 0; @@ -550,33 +478,28 @@ static SQInteger ScriptedObject_move_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'move'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'sixteen_to_nine'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_set_pos_wrapper(HSQUIRRELVM vm) +static SQInteger DisplayEffect_four_to_three_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_pos' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'four_to_three' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::DisplayEffect* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a float")); - return SQ_ERROR; - } try { - _this->set_pos(static_cast (arg0), static_cast (arg1)); + _this->four_to_three(static_cast (arg0)); return 0; @@ -584,70 +507,109 @@ static SQInteger ScriptedObject_set_pos_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'four_to_three'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_get_pos_x_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_release_hook(SQUserPointer ptr, SQInteger ) { - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_x' called without instance")); + scripting::FloatingImage* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger FloatingImage_constructor_wrapper(HSQUIRRELVM vm) +{ + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); try { - float return_value = _this->get_pos_x(); + scripting::FloatingImage* _this = new scripting::FloatingImage(arg0); + if(SQ_FAILED(sq_setinstanceup(vm, 1, _this))) { + sq_throwerror(vm, _SC("Couldn't setup instance of 'FloatingImage' class")); + return SQ_ERROR; + } + sq_setreleasehook(vm, 1, FloatingImage_release_hook); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'constructor'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_get_pos_y_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_set_layer_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_y' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_layer' called without instance")); + return SQ_ERROR; + } + scripting::FloatingImage* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); try { - float return_value = _this->get_pos_y(); + _this->set_layer(static_cast (arg0)); - sq_pushfloat(vm, return_value); + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_layer'")); + return SQ_ERROR; + } + +} + +static SQInteger FloatingImage_get_layer_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_layer' called without instance")); + return SQ_ERROR; + } + scripting::FloatingImage* _this = reinterpret_cast (data); + + try { + int return_value = _this->get_layer(); + + sq_pushinteger(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_layer'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_set_velocity_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_set_pos_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_velocity' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_pos' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -660,7 +622,7 @@ static SQInteger ScriptedObject_set_velocity_wrapper(HSQUIRRELVM vm) } try { - _this->set_velocity(static_cast (arg0), static_cast (arg1)); + _this->set_pos(static_cast (arg0), static_cast (arg1)); return 0; @@ -668,23 +630,23 @@ static SQInteger ScriptedObject_set_velocity_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_velocity'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_get_velocity_x_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_get_pos_x_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_velocity_x' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_x' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); try { - float return_value = _this->get_velocity_x(); + float return_value = _this->get_pos_x(); sq_pushfloat(vm, return_value); return 1; @@ -693,23 +655,23 @@ static SQInteger ScriptedObject_get_velocity_x_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_velocity_x'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_get_velocity_y_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_get_pos_y_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_velocity_y' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_y' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); try { - float return_value = _this->get_velocity_y(); + float return_value = _this->get_pos_y(); sq_pushfloat(vm, return_value); return 1; @@ -718,28 +680,28 @@ static SQInteger ScriptedObject_get_velocity_y_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_velocity_y'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_set_visible_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_set_anchor_point_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_visible' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_anchor_point' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + scripting::FloatingImage* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); return SQ_ERROR; } try { - _this->set_visible(arg0 == SQTrue); + _this->set_anchor_point(static_cast (arg0)); return 0; @@ -747,45 +709,45 @@ static SQInteger ScriptedObject_set_visible_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_anchor_point'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_is_visible_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_get_anchor_point_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'is_visible' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_anchor_point' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); try { - bool return_value = _this->is_visible(); + int return_value = _this->get_anchor_point(); - sq_pushbool(vm, return_value); + sq_pushinteger(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_visible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_anchor_point'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_set_solid_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_set_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_solid' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_visible' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); SQBool arg0; if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a bool")); @@ -793,7 +755,7 @@ static SQInteger ScriptedObject_set_solid_wrapper(HSQUIRRELVM vm) } try { - _this->set_solid(arg0 == SQTrue); + _this->set_visible(arg0 == SQTrue); return 0; @@ -801,23 +763,23 @@ static SQInteger ScriptedObject_set_solid_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_solid'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); return SQ_ERROR; } } -static SQInteger ScriptedObject_is_solid_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_get_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'is_solid' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_visible' called without instance")); return SQ_ERROR; } - Scripting::ScriptedObject* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); try { - bool return_value = _this->is_solid(); + bool return_value = _this->get_visible(); sq_pushbool(vm, return_value); return 1; @@ -826,52 +788,20 @@ static SQInteger ScriptedObject_is_solid_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_solid'")); - return SQ_ERROR; - } - -} - -static SQInteger ScriptedObject_get_name_wrapper(HSQUIRRELVM vm) -{ - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_name' called without instance")); - return SQ_ERROR; - } - Scripting::ScriptedObject* _this = reinterpret_cast (data); - - try { - std::string return_value = _this->get_name(); - - sq_pushstring(vm, return_value.c_str(), return_value.size()); - return 1; - - } catch(std::exception& e) { - sq_throwerror(vm, e.what()); - return SQ_ERROR; - } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_name'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_visible'")); return SQ_ERROR; } } -static SQInteger Text_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Text* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger Text_set_text_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_set_action_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_text' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_action' called without instance")); return SQ_ERROR; } - Scripting::Text* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); const SQChar* arg0; if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a string")); @@ -879,7 +809,7 @@ static SQInteger Text_set_text_wrapper(HSQUIRRELVM vm) } try { - _this->set_text(arg0); + _this->set_action(arg0); return 0; @@ -887,49 +817,45 @@ static SQInteger Text_set_text_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_text'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_action'")); return SQ_ERROR; } } -static SQInteger Text_set_font_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_get_action_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_font' called without instance")); - return SQ_ERROR; - } - Scripting::Text* _this = reinterpret_cast (data); - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_action' called without instance")); return SQ_ERROR; } + scripting::FloatingImage* _this = reinterpret_cast (data); try { - _this->set_font(arg0); + std::string return_value = _this->get_action(); - return 0; + sq_pushstring(vm, return_value.c_str(), return_value.size()); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_font'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_action'")); return SQ_ERROR; } } -static SQInteger Text_fade_in_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_fade_in_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'fade_in' called without instance")); return SQ_ERROR; } - Scripting::Text* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -951,14 +877,14 @@ static SQInteger Text_fade_in_wrapper(HSQUIRRELVM vm) } -static SQInteger Text_fade_out_wrapper(HSQUIRRELVM vm) +static SQInteger FloatingImage_fade_out_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'fade_out' called without instance")); return SQ_ERROR; } - Scripting::Text* _this = reinterpret_cast (data); + scripting::FloatingImage* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -980,22 +906,24 @@ static SQInteger Text_fade_out_wrapper(HSQUIRRELVM vm) } -static SQInteger Text_set_visible_wrapper(HSQUIRRELVM vm) +static SQInteger LevelTime_release_hook(SQUserPointer ptr, SQInteger ) +{ + scripting::LevelTime* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger LevelTime_start_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_visible' called without instance")); - return SQ_ERROR; - } - Scripting::Text* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start' called without instance")); return SQ_ERROR; } + scripting::LevelTime* _this = reinterpret_cast (data); try { - _this->set_visible(arg0 == SQTrue); + _this->start(); return 0; @@ -1003,28 +931,23 @@ static SQInteger Text_set_visible_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); return SQ_ERROR; } } -static SQInteger Text_set_centered_wrapper(HSQUIRRELVM vm) +static SQInteger LevelTime_stop_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_centered' called without instance")); - return SQ_ERROR; - } - Scripting::Text* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop' called without instance")); return SQ_ERROR; } + scripting::LevelTime* _this = reinterpret_cast (data); try { - _this->set_centered(arg0 == SQTrue); + _this->stop(); return 0; @@ -1032,65 +955,53 @@ static SQInteger Text_set_centered_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_centered'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); return SQ_ERROR; } } -static SQInteger Player_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Player* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger Player_add_bonus_wrapper(HSQUIRRELVM vm) +static SQInteger LevelTime_get_time_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'add_bonus' called without instance")); - return SQ_ERROR; - } - Scripting::Player* _this = reinterpret_cast (data); - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_time' called without instance")); return SQ_ERROR; } + scripting::LevelTime* _this = reinterpret_cast (data); try { - bool return_value = _this->add_bonus(arg0); + float return_value = _this->get_time(); - sq_pushbool(vm, return_value); + sq_pushfloat(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'add_bonus'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_time'")); return SQ_ERROR; } } -static SQInteger Player_add_coins_wrapper(HSQUIRRELVM vm) +static SQInteger LevelTime_set_time_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'add_coins' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_time' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); - SQInteger arg0; - if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not an integer")); + scripting::LevelTime* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } try { - _this->add_coins(static_cast (arg0)); + _this->set_time(static_cast (arg0)); return 0; @@ -1098,23 +1009,35 @@ static SQInteger Player_add_coins_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'add_coins'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_time'")); return SQ_ERROR; } } -static SQInteger Player_make_invincible_wrapper(HSQUIRRELVM vm) +static SQInteger Platform_release_hook(SQUserPointer ptr, SQInteger ) +{ + scripting::Platform* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger Platform_goto_node_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'make_invincible' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'goto_node' called without instance")); + return SQ_ERROR; + } + scripting::Platform* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); try { - _this->make_invincible(); + _this->goto_node(static_cast (arg0)); return 0; @@ -1122,23 +1045,23 @@ static SQInteger Player_make_invincible_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'make_invincible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'goto_node'")); return SQ_ERROR; } } -static SQInteger Player_deactivate_wrapper(HSQUIRRELVM vm) +static SQInteger Platform_start_moving_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'deactivate' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start_moving' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Platform* _this = reinterpret_cast (data); try { - _this->deactivate(); + _this->start_moving(); return 0; @@ -1146,23 +1069,23 @@ static SQInteger Player_deactivate_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'deactivate'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start_moving'")); return SQ_ERROR; } } -static SQInteger Player_activate_wrapper(HSQUIRRELVM vm) +static SQInteger Platform_stop_moving_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'activate' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop_moving' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Platform* _this = reinterpret_cast (data); try { - _this->activate(); + _this->stop_moving(); return 0; @@ -1170,21 +1093,159 @@ static SQInteger Player_activate_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'activate'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop_moving'")); return SQ_ERROR; } } -static SQInteger Player_walk_wrapper(HSQUIRRELVM vm) +static SQInteger Player_release_hook(SQUserPointer ptr, SQInteger ) { - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'walk' called without instance")); - return SQ_ERROR; - } - Scripting::Player* _this = reinterpret_cast (data); - SQFloat arg0; + scripting::Player* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger Player_add_bonus_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'add_bonus' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } + + try { + bool return_value = _this->add_bonus(arg0); + + sq_pushbool(vm, return_value); + return 1; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'add_bonus'")); + return SQ_ERROR; + } + +} + +static SQInteger Player_add_coins_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'add_coins' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); + return SQ_ERROR; + } + + try { + _this->add_coins(static_cast (arg0)); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'add_coins'")); + return SQ_ERROR; + } + +} + +static SQInteger Player_make_invincible_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'make_invincible' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + + try { + _this->make_invincible(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'make_invincible'")); + return SQ_ERROR; + } + +} + +static SQInteger Player_deactivate_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'deactivate' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + + try { + _this->deactivate(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'deactivate'")); + return SQ_ERROR; + } + +} + +static SQInteger Player_activate_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'activate' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + + try { + _this->activate(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'activate'")); + return SQ_ERROR; + } + +} + +static SQInteger Player_walk_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'walk' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; @@ -1205,14 +1266,43 @@ static SQInteger Player_walk_wrapper(HSQUIRRELVM vm) } +static SQInteger Player_set_dir_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_dir' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } + + try { + _this->set_dir(arg0 == SQTrue); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_dir'")); + return SQ_ERROR; + } + +} + static SQInteger Player_set_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'set_visible' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); SQBool arg0; if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a bool")); @@ -1237,11 +1327,11 @@ static SQInteger Player_set_visible_wrapper(HSQUIRRELVM vm) static SQInteger Player_get_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'get_visible' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { bool return_value = _this->get_visible(); @@ -1262,11 +1352,11 @@ static SQInteger Player_get_visible_wrapper(HSQUIRRELVM vm) static SQInteger Player_kill_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'kill' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); SQBool arg0; if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a bool")); @@ -1291,11 +1381,11 @@ static SQInteger Player_kill_wrapper(HSQUIRRELVM vm) static SQInteger Player_set_ghost_mode_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'set_ghost_mode' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); SQBool arg0; if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a bool")); @@ -1320,11 +1410,11 @@ static SQInteger Player_set_ghost_mode_wrapper(HSQUIRRELVM vm) static SQInteger Player_get_ghost_mode_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'get_ghost_mode' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { bool return_value = _this->get_ghost_mode(); @@ -1342,14 +1432,38 @@ static SQInteger Player_get_ghost_mode_wrapper(HSQUIRRELVM vm) } +static SQInteger Player_kick_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'kick' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + + try { + _this->kick(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'kick'")); + return SQ_ERROR; + } + +} + static SQInteger Player_do_cheer_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'do_cheer' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { _this->do_cheer(); @@ -1369,11 +1483,11 @@ static SQInteger Player_do_cheer_wrapper(HSQUIRRELVM vm) static SQInteger Player_do_duck_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'do_duck' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { _this->do_duck(); @@ -1393,11 +1507,11 @@ static SQInteger Player_do_duck_wrapper(HSQUIRRELVM vm) static SQInteger Player_do_standup_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'do_standup' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { _this->do_standup(); @@ -1417,11 +1531,11 @@ static SQInteger Player_do_standup_wrapper(HSQUIRRELVM vm) static SQInteger Player_do_backflip_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'do_backflip' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); try { _this->do_backflip(); @@ -1441,11 +1555,11 @@ static SQInteger Player_do_backflip_wrapper(HSQUIRRELVM vm) static SQInteger Player_do_jump_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'do_jump' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -1470,11 +1584,11 @@ static SQInteger Player_do_jump_wrapper(HSQUIRRELVM vm) static SQInteger Player_trigger_sequence_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { sq_throwerror(vm, _SC("'trigger_sequence' called without instance")); return SQ_ERROR; } - Scripting::Player* _this = reinterpret_cast (data); + scripting::Player* _this = reinterpret_cast (data); const SQChar* arg0; if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a string")); @@ -1496,28 +1610,56 @@ static SQInteger Player_trigger_sequence_wrapper(HSQUIRRELVM vm) } -static SQInteger FloatingImage_release_hook(SQUserPointer ptr, SQInteger ) +static SQInteger Player_use_scripting_controller_wrapper(HSQUIRRELVM vm) { - Scripting::FloatingImage* _this = reinterpret_cast (ptr); - delete _this; - return 0; + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'use_scripting_controller' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } + + try { + _this->use_scripting_controller(arg0 == SQTrue); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'use_scripting_controller'")); + return SQ_ERROR; + } + } -static SQInteger FloatingImage_constructor_wrapper(HSQUIRRELVM vm) +static SQInteger Player_do_scripting_controller_wrapper(HSQUIRRELVM vm) { + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'do_scripting_controller' called without instance")); + return SQ_ERROR; + } + scripting::Player* _this = reinterpret_cast (data); const SQChar* arg0; if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } - - try { - Scripting::FloatingImage* _this = new Scripting::FloatingImage(arg0); - if(SQ_FAILED(sq_setinstanceup(vm, 1, _this))) { - sq_throwerror(vm, _SC("Couldn't setup instance of 'FloatingImage' class")); + SQBool arg1; + if(SQ_FAILED(sq_getbool(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a bool")); return SQ_ERROR; } - sq_setreleasehook(vm, 1, FloatingImage_release_hook); + + try { + _this->do_scripting_controller(arg0, arg1 == SQTrue); return 0; @@ -1525,28 +1667,35 @@ static SQInteger FloatingImage_constructor_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'constructor'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'do_scripting_controller'")); return SQ_ERROR; } } -static SQInteger FloatingImage_set_layer_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_release_hook(SQUserPointer ptr, SQInteger ) +{ + scripting::ScriptedObject* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger ScriptedObject_set_action_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_layer' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_action' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); - SQInteger arg0; - if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not an integer")); + scripting::ScriptedObject* _this = reinterpret_cast (data); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } try { - _this->set_layer(static_cast (arg0)); + _this->set_action(arg0); return 0; @@ -1554,45 +1703,45 @@ static SQInteger FloatingImage_set_layer_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_layer'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_action'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_layer_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_action_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_layer' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_action' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - int return_value = _this->get_layer(); + std::string return_value = _this->get_action(); - sq_pushinteger(vm, return_value); + sq_pushstring(vm, return_value.c_str(), return_value.size()); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_layer'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_action'")); return SQ_ERROR; } } -static SQInteger FloatingImage_set_pos_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_move_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_pos' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'move' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); @@ -1605,7 +1754,7 @@ static SQInteger FloatingImage_set_pos_wrapper(HSQUIRRELVM vm) } try { - _this->set_pos(static_cast (arg0), static_cast (arg1)); + _this->move(static_cast (arg0), static_cast (arg1)); return 0; @@ -1613,48 +1762,57 @@ static SQInteger FloatingImage_set_pos_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'move'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_pos_x_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_set_pos_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_x' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_pos' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); - - try { - float return_value = _this->get_pos_x(); - - sq_pushfloat(vm, return_value); - return 1; + scripting::ScriptedObject* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); + return SQ_ERROR; + } + + try { + _this->set_pos(static_cast (arg0), static_cast (arg1)); + + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_pos_y_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_pos_x_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_y' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_x' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - float return_value = _this->get_pos_y(); + float return_value = _this->get_pos_x(); sq_pushfloat(vm, return_value); return 1; @@ -1663,136 +1821,137 @@ static SQInteger FloatingImage_get_pos_y_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); return SQ_ERROR; } } -static SQInteger FloatingImage_set_anchor_point_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_pos_y_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_anchor_point' called without instance")); - return SQ_ERROR; - } - Scripting::FloatingImage* _this = reinterpret_cast (data); - SQInteger arg0; - if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not an integer")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_y' called without instance")); return SQ_ERROR; } + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - _this->set_anchor_point(static_cast (arg0)); + float return_value = _this->get_pos_y(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_anchor_point'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_anchor_point_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_set_velocity_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_anchor_point' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_velocity' called without instance")); + return SQ_ERROR; + } + scripting::ScriptedObject* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); try { - int return_value = _this->get_anchor_point(); + _this->set_velocity(static_cast (arg0), static_cast (arg1)); - sq_pushinteger(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_anchor_point'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_velocity'")); return SQ_ERROR; } } -static SQInteger FloatingImage_set_visible_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_velocity_x_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_visible' called without instance")); - return SQ_ERROR; - } - Scripting::FloatingImage* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_velocity_x' called without instance")); return SQ_ERROR; } + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - _this->set_visible(arg0 == SQTrue); + float return_value = _this->get_velocity_x(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_velocity_x'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_visible_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_velocity_y_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_visible' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_velocity_y' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - bool return_value = _this->get_visible(); + float return_value = _this->get_velocity_y(); - sq_pushbool(vm, return_value); + sq_pushfloat(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_visible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_velocity_y'")); return SQ_ERROR; } } -static SQInteger FloatingImage_set_action_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_enable_gravity_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_action' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'enable_gravity' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + scripting::ScriptedObject* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } try { - _this->set_action(arg0); + _this->enable_gravity(arg0 == SQTrue); return 0; @@ -1800,53 +1959,53 @@ static SQInteger FloatingImage_set_action_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_action'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'enable_gravity'")); return SQ_ERROR; } } -static SQInteger FloatingImage_get_action_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_gravity_enabled_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_action' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'gravity_enabled' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - std::string return_value = _this->get_action(); + bool return_value = _this->gravity_enabled(); - sq_pushstring(vm, return_value.c_str(), return_value.size()); + sq_pushbool(vm, return_value); return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_action'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'gravity_enabled'")); return SQ_ERROR; } } -static SQInteger FloatingImage_fade_in_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_set_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'fade_in' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_visible' called without instance")); return SQ_ERROR; } - Scripting::FloatingImage* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + scripting::ScriptedObject* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } try { - _this->fade_in(static_cast (arg0)); + _this->set_visible(arg0 == SQTrue); return 0; @@ -1854,64 +2013,53 @@ static SQInteger FloatingImage_fade_in_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_in'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); return SQ_ERROR; } } -static SQInteger FloatingImage_fade_out_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_is_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'fade_out' called without instance")); - return SQ_ERROR; - } - Scripting::FloatingImage* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'is_visible' called without instance")); return SQ_ERROR; } + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - _this->fade_out(static_cast (arg0)); + bool return_value = _this->is_visible(); - return 0; + sq_pushbool(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_out'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_visible'")); return SQ_ERROR; } } -static SQInteger Platform_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Platform* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger Platform_goto_node_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_set_solid_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'goto_node' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_solid' called without instance")); return SQ_ERROR; } - Scripting::Platform* _this = reinterpret_cast (data); - SQInteger arg0; - if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not an integer")); + scripting::ScriptedObject* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } try { - _this->goto_node(static_cast (arg0)); + _this->set_solid(arg0 == SQTrue); return 0; @@ -1919,204 +2067,199 @@ static SQInteger Platform_goto_node_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'goto_node'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_solid'")); return SQ_ERROR; } } -static SQInteger Platform_start_moving_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_is_solid_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'start_moving' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'is_solid' called without instance")); return SQ_ERROR; } - Scripting::Platform* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - _this->start_moving(); + bool return_value = _this->is_solid(); - return 0; + sq_pushbool(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'start_moving'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'is_solid'")); return SQ_ERROR; } } -static SQInteger Platform_stop_moving_wrapper(HSQUIRRELVM vm) +static SQInteger ScriptedObject_get_name_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'stop_moving' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_name' called without instance")); return SQ_ERROR; } - Scripting::Platform* _this = reinterpret_cast (data); + scripting::ScriptedObject* _this = reinterpret_cast (data); try { - _this->stop_moving(); + std::string return_value = _this->get_name(); - return 0; + sq_pushstring(vm, return_value.c_str(), return_value.size()); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop_moving'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_name'")); return SQ_ERROR; } } -static SQInteger Candle_release_hook(SQUserPointer ptr, SQInteger ) +static SQInteger SSector_release_hook(SQUserPointer ptr, SQInteger ) { - Scripting::Candle* _this = reinterpret_cast (ptr); + scripting::SSector* _this = reinterpret_cast (ptr); delete _this; return 0; } -static SQInteger Candle_get_burning_wrapper(HSQUIRRELVM vm) +static SQInteger SSector_set_ambient_light_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_burning' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_ambient_light' called without instance")); + return SQ_ERROR; + } + scripting::SSector* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); + return SQ_ERROR; + } + SQFloat arg2; + if(SQ_FAILED(sq_getfloat(vm, 4, &arg2))) { + sq_throwerror(vm, _SC("Argument 3 not a float")); return SQ_ERROR; } - Scripting::Candle* _this = reinterpret_cast (data); try { - bool return_value = _this->get_burning(); + _this->set_ambient_light(static_cast (arg0), static_cast (arg1), static_cast (arg2)); - sq_pushbool(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_burning'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_ambient_light'")); return SQ_ERROR; } } -static SQInteger Candle_set_burning_wrapper(HSQUIRRELVM vm) +static SQInteger SSector_get_ambient_red_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_burning' called without instance")); - return SQ_ERROR; - } - Scripting::Candle* _this = reinterpret_cast (data); - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_ambient_red' called without instance")); return SQ_ERROR; } + scripting::SSector* _this = reinterpret_cast (data); try { - _this->set_burning(arg0 == SQTrue); + float return_value = _this->get_ambient_red(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_burning'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_red'")); return SQ_ERROR; } } -static SQInteger Wind_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Wind* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger Wind_start_wrapper(HSQUIRRELVM vm) +static SQInteger SSector_get_ambient_green_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'start' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_ambient_green' called without instance")); return SQ_ERROR; } - Scripting::Wind* _this = reinterpret_cast (data); + scripting::SSector* _this = reinterpret_cast (data); try { - _this->start(); + float return_value = _this->get_ambient_green(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_green'")); return SQ_ERROR; } } -static SQInteger Wind_stop_wrapper(HSQUIRRELVM vm) +static SQInteger SSector_get_ambient_blue_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'stop' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_ambient_blue' called without instance")); return SQ_ERROR; } - Scripting::Wind* _this = reinterpret_cast (data); + scripting::SSector* _this = reinterpret_cast (data); try { - _this->stop(); + float return_value = _this->get_ambient_blue(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_blue'")); return SQ_ERROR; } } -static SQInteger AmbientSound_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::AmbientSound* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger AmbientSound_set_pos_wrapper(HSQUIRRELVM vm) +static SQInteger SSector_set_gravity_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_pos' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_gravity' called without instance")); return SQ_ERROR; } - Scripting::AmbientSound* _this = reinterpret_cast (data); + scripting::SSector* _this = reinterpret_cast (data); SQFloat arg0; if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a float")); - return SQ_ERROR; - } try { - _this->set_pos(static_cast (arg0), static_cast (arg1)); + _this->set_gravity(static_cast (arg0)); return 0; @@ -2124,80 +2267,93 @@ static SQInteger AmbientSound_set_pos_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_gravity'")); return SQ_ERROR; } } -static SQInteger AmbientSound_get_pos_x_wrapper(HSQUIRRELVM vm) +static SQInteger Text_release_hook(SQUserPointer ptr, SQInteger ) +{ + scripting::Text* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger Text_set_text_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_x' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_text' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } - Scripting::AmbientSound* _this = reinterpret_cast (data); try { - float return_value = _this->get_pos_x(); + _this->set_text(arg0); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_text'")); return SQ_ERROR; } } -static SQInteger AmbientSound_get_pos_y_wrapper(HSQUIRRELVM vm) +static SQInteger Text_set_font_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_pos_y' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_font' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } - Scripting::AmbientSound* _this = reinterpret_cast (data); try { - float return_value = _this->get_pos_y(); + _this->set_font(arg0); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_font'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::Thunderstorm* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger Thunderstorm_start_wrapper(HSQUIRRELVM vm) +static SQInteger Text_fade_in_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'start' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'fade_in' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->start(); + _this->fade_in(static_cast (arg0)); return 0; @@ -2205,23 +2361,28 @@ static SQInteger Thunderstorm_start_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_in'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_stop_wrapper(HSQUIRRELVM vm) +static SQInteger Text_fade_out_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'stop' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'fade_out' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->stop(); + _this->fade_out(static_cast (arg0)); return 0; @@ -2229,23 +2390,28 @@ static SQInteger Thunderstorm_stop_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade_out'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_thunder_wrapper(HSQUIRRELVM vm) +static SQInteger Text_set_visible_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'thunder' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_visible' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->thunder(); + _this->set_visible(arg0 == SQTrue); return 0; @@ -2253,23 +2419,28 @@ static SQInteger Thunderstorm_thunder_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'thunder'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_visible'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_lightning_wrapper(HSQUIRRELVM vm) +static SQInteger Text_set_centered_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'lightning' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_centered' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->lightning(); + _this->set_centered(arg0 == SQTrue); return 0; @@ -2277,23 +2448,33 @@ static SQInteger Thunderstorm_lightning_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'lightning'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_centered'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_flash_wrapper(HSQUIRRELVM vm) +static SQInteger Text_set_pos_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'flash' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_pos' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->flash(); + _this->set_pos(static_cast (arg0), static_cast (arg1)); return 0; @@ -2301,83 +2482,78 @@ static SQInteger Thunderstorm_flash_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'flash'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_pos'")); return SQ_ERROR; } } -static SQInteger Thunderstorm_electrify_wrapper(HSQUIRRELVM vm) +static SQInteger Text_get_pos_x_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'electrify' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_x' called without instance")); return SQ_ERROR; } - Scripting::Thunderstorm* _this = reinterpret_cast (data); + scripting::Text* _this = reinterpret_cast (data); try { - _this->electrify(); + float return_value = _this->get_pos_x(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'electrify'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_x'")); return SQ_ERROR; } } -static SQInteger TileMap_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::TileMap* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger TileMap_goto_node_wrapper(HSQUIRRELVM vm) +static SQInteger Text_get_pos_y_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'goto_node' called without instance")); - return SQ_ERROR; - } - Scripting::TileMap* _this = reinterpret_cast (data); - SQInteger arg0; - if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not an integer")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_pos_y' called without instance")); return SQ_ERROR; } + scripting::Text* _this = reinterpret_cast (data); try { - _this->goto_node(static_cast (arg0)); + float return_value = _this->get_pos_y(); - return 0; + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'goto_node'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_pos_y'")); return SQ_ERROR; } } -static SQInteger TileMap_start_moving_wrapper(HSQUIRRELVM vm) +static SQInteger Text_set_anchor_point_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'start_moving' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_anchor_point' called without instance")); + return SQ_ERROR; + } + scripting::Text* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); return SQ_ERROR; } - Scripting::TileMap* _this = reinterpret_cast (data); try { - _this->start_moving(); + _this->set_anchor_point(static_cast (arg0)); return 0; @@ -2385,69 +2561,55 @@ static SQInteger TileMap_start_moving_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'start_moving'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_anchor_point'")); return SQ_ERROR; } } -static SQInteger TileMap_stop_moving_wrapper(HSQUIRRELVM vm) +static SQInteger Text_get_anchor_point_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'stop_moving' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_anchor_point' called without instance")); return SQ_ERROR; } - Scripting::TileMap* _this = reinterpret_cast (data); + scripting::Text* _this = reinterpret_cast (data); try { - _this->stop_moving(); + int return_value = _this->get_anchor_point(); - return 0; + sq_pushinteger(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop_moving'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_anchor_point'")); return SQ_ERROR; } } -static SQInteger SSector_release_hook(SQUserPointer ptr, SQInteger ) +static SQInteger Thunderstorm_release_hook(SQUserPointer ptr, SQInteger ) { - Scripting::SSector* _this = reinterpret_cast (ptr); + scripting::Thunderstorm* _this = reinterpret_cast (ptr); delete _this; return 0; } -static SQInteger SSector_set_ambient_light_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_start_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_ambient_light' called without instance")); - return SQ_ERROR; - } - Scripting::SSector* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); - return SQ_ERROR; - } - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a float")); - return SQ_ERROR; - } - SQFloat arg2; - if(SQ_FAILED(sq_getfloat(vm, 4, &arg2))) { - sq_throwerror(vm, _SC("Argument 3 not a float")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start' called without instance")); return SQ_ERROR; } + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->set_ambient_light(static_cast (arg0), static_cast (arg1), static_cast (arg2)); + _this->start(); return 0; @@ -2455,105 +2617,95 @@ static SQInteger SSector_set_ambient_light_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_ambient_light'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); return SQ_ERROR; } } -static SQInteger SSector_get_ambient_red_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_stop_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_ambient_red' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop' called without instance")); return SQ_ERROR; } - Scripting::SSector* _this = reinterpret_cast (data); + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - float return_value = _this->get_ambient_red(); + _this->stop(); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_red'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); return SQ_ERROR; } } -static SQInteger SSector_get_ambient_green_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_thunder_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_ambient_green' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'thunder' called without instance")); return SQ_ERROR; } - Scripting::SSector* _this = reinterpret_cast (data); + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - float return_value = _this->get_ambient_green(); + _this->thunder(); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_green'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'thunder'")); return SQ_ERROR; } } -static SQInteger SSector_get_ambient_blue_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_lightning_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_ambient_blue' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'lightning' called without instance")); return SQ_ERROR; } - Scripting::SSector* _this = reinterpret_cast (data); + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - float return_value = _this->get_ambient_blue(); + _this->lightning(); - sq_pushfloat(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_ambient_blue'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'lightning'")); return SQ_ERROR; } } -static SQInteger LevelTime_release_hook(SQUserPointer ptr, SQInteger ) -{ - Scripting::LevelTime* _this = reinterpret_cast (ptr); - delete _this; - return 0; -} - -static SQInteger LevelTime_start_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_flash_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'start' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'flash' called without instance")); return SQ_ERROR; } - Scripting::LevelTime* _this = reinterpret_cast (data); + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->start(); + _this->flash(); return 0; @@ -2561,23 +2713,23 @@ static SQInteger LevelTime_start_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'flash'")); return SQ_ERROR; } } -static SQInteger LevelTime_stop_wrapper(HSQUIRRELVM vm) +static SQInteger Thunderstorm_electrify_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'stop' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'electrify' called without instance")); return SQ_ERROR; } - Scripting::LevelTime* _this = reinterpret_cast (data); + scripting::Thunderstorm* _this = reinterpret_cast (data); try { - _this->stop(); + _this->electrify(); return 0; @@ -2585,53 +2737,35 @@ static SQInteger LevelTime_stop_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'electrify'")); return SQ_ERROR; } } -static SQInteger LevelTime_get_time_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_release_hook(SQUserPointer ptr, SQInteger ) { - SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'get_time' called without instance")); - return SQ_ERROR; - } - Scripting::LevelTime* _this = reinterpret_cast (data); - - try { - float return_value = _this->get_time(); - - sq_pushfloat(vm, return_value); - return 1; - - } catch(std::exception& e) { - sq_throwerror(vm, e.what()); - return SQ_ERROR; - } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_time'")); - return SQ_ERROR; - } - + scripting::TileMap* _this = reinterpret_cast (ptr); + delete _this; + return 0; } -static SQInteger LevelTime_set_time_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_goto_node_wrapper(HSQUIRRELVM vm) { SQUserPointer data; - if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0))) { - sq_throwerror(vm, _SC("'set_time' called without instance")); + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'goto_node' called without instance")); return SQ_ERROR; } - Scripting::LevelTime* _this = reinterpret_cast (data); - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + scripting::TileMap* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); return SQ_ERROR; } try { - _this->set_time(static_cast (arg0)); + _this->goto_node(static_cast (arg0)); return 0; @@ -2639,23 +2773,23 @@ static SQInteger LevelTime_set_time_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_time'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'goto_node'")); return SQ_ERROR; } } -static SQInteger display_wrapper(HSQUIRRELVM vm) -{ - return Scripting::display(vm); -} - -static SQInteger print_stacktrace_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_start_moving_wrapper(HSQUIRRELVM vm) { - HSQUIRRELVM arg0 = vm; + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start_moving' called without instance")); + return SQ_ERROR; + } + scripting::TileMap* _this = reinterpret_cast (data); try { - Scripting::print_stacktrace(arg0); + _this->start_moving(); return 0; @@ -2663,27 +2797,23 @@ static SQInteger print_stacktrace_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'print_stacktrace'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start_moving'")); return SQ_ERROR; } } -static SQInteger get_current_thread_wrapper(HSQUIRRELVM vm) -{ - return Scripting::get_current_thread(vm); -} - -static SQInteger display_text_file_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_stop_moving_wrapper(HSQUIRRELVM vm) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop_moving' called without instance")); return SQ_ERROR; } + scripting::TileMap* _this = reinterpret_cast (data); try { - Scripting::display_text_file(arg0); + _this->stop_moving(); return 0; @@ -2691,22 +2821,33 @@ static SQInteger display_text_file_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'display_text_file'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop_moving'")); return SQ_ERROR; } } -static SQInteger load_worldmap_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_fade_wrapper(HSQUIRRELVM vm) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'fade' called without instance")); + return SQ_ERROR; + } + scripting::TileMap* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); return SQ_ERROR; } try { - Scripting::load_worldmap(arg0); + _this->fade(static_cast (arg0), static_cast (arg1)); return 0; @@ -2714,22 +2855,28 @@ static SQInteger load_worldmap_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'load_worldmap'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fade'")); return SQ_ERROR; } } -static SQInteger load_level_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_set_alpha_wrapper(HSQUIRRELVM vm) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_alpha' called without instance")); + return SQ_ERROR; + } + scripting::TileMap* _this = reinterpret_cast (data); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } try { - Scripting::load_level(arg0); + _this->set_alpha(static_cast (arg0)); return 0; @@ -2737,61 +2884,89 @@ static SQInteger load_level_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'load_level'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_alpha'")); return SQ_ERROR; } } -static SQInteger wait_wrapper(HSQUIRRELVM vm) +static SQInteger TileMap_get_alpha_wrapper(HSQUIRRELVM vm) { - HSQUIRRELVM arg0 = vm; - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg1))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'get_alpha' called without instance")); return SQ_ERROR; } + scripting::TileMap* _this = reinterpret_cast (data); try { - Scripting::wait(arg0, static_cast (arg1)); + float return_value = _this->get_alpha(); - return sq_suspendvm(vm); + sq_pushfloat(vm, return_value); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'wait'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'get_alpha'")); return SQ_ERROR; } } -static SQInteger wait_for_screenswitch_wrapper(HSQUIRRELVM vm) +static SQInteger WillOWisp_release_hook(SQUserPointer ptr, SQInteger ) { - HSQUIRRELVM arg0 = vm; + scripting::WillOWisp* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger WillOWisp_goto_node_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'goto_node' called without instance")); + return SQ_ERROR; + } + scripting::WillOWisp* _this = reinterpret_cast (data); + SQInteger arg0; + if(SQ_FAILED(sq_getinteger(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not an integer")); + return SQ_ERROR; + } try { - Scripting::wait_for_screenswitch(arg0); + _this->goto_node(static_cast (arg0)); - return sq_suspendvm(vm); + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'wait_for_screenswitch'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'goto_node'")); return SQ_ERROR; } } -static SQInteger exit_screen_wrapper(HSQUIRRELVM vm) +static SQInteger WillOWisp_set_state_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'set_state' called without instance")); + return SQ_ERROR; + } + scripting::WillOWisp* _this = reinterpret_cast (data); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } try { - Scripting::exit_screen(); + _this->set_state(arg0); return 0; @@ -2799,22 +2974,23 @@ static SQInteger exit_screen_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'exit_screen'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_state'")); return SQ_ERROR; } } -static SQInteger fadeout_screen_wrapper(HSQUIRRELVM vm) +static SQInteger WillOWisp_start_moving_wrapper(HSQUIRRELVM vm) { - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start_moving' called without instance")); return SQ_ERROR; } + scripting::WillOWisp* _this = reinterpret_cast (data); try { - Scripting::fadeout_screen(static_cast (arg0)); + _this->start_moving(); return 0; @@ -2822,32 +2998,23 @@ static SQInteger fadeout_screen_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'fadeout_screen'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start_moving'")); return SQ_ERROR; } } -static SQInteger shrink_screen_wrapper(HSQUIRRELVM vm) +static SQInteger WillOWisp_stop_moving_wrapper(HSQUIRRELVM vm) { - SQFloat arg0; - if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a float")); - return SQ_ERROR; - } - SQFloat arg1; - if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { - sq_throwerror(vm, _SC("Argument 2 not a float")); - return SQ_ERROR; - } - SQFloat arg2; - if(SQ_FAILED(sq_getfloat(vm, 4, &arg2))) { - sq_throwerror(vm, _SC("Argument 3 not a float")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop_moving' called without instance")); return SQ_ERROR; } + scripting::WillOWisp* _this = reinterpret_cast (data); try { - Scripting::shrink_screen(static_cast (arg0), static_cast (arg1), static_cast (arg2)); + _this->stop_moving(); return 0; @@ -2855,47 +3022,54 @@ static SQInteger shrink_screen_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'shrink_screen'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop_moving'")); return SQ_ERROR; } } -static SQInteger translate_wrapper(HSQUIRRELVM vm) +static SQInteger Wind_release_hook(SQUserPointer ptr, SQInteger ) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + scripting::Wind* _this = reinterpret_cast (ptr); + delete _this; + return 0; +} + +static SQInteger Wind_start_wrapper(HSQUIRRELVM vm) +{ + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'start' called without instance")); return SQ_ERROR; } + scripting::Wind* _this = reinterpret_cast (data); try { - std::string return_value = Scripting::translate(arg0); + _this->start(); - sq_pushstring(vm, return_value.c_str(), return_value.size()); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'translate'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'start'")); return SQ_ERROR; } } -static SQInteger import_wrapper(HSQUIRRELVM vm) +static SQInteger Wind_stop_wrapper(HSQUIRRELVM vm) { - HSQUIRRELVM arg0 = vm; - const SQChar* arg1; - if(SQ_FAILED(sq_getstring(vm, 2, &arg1))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); + SQUserPointer data; + if(SQ_FAILED(sq_getinstanceup(vm, 1, &data, 0)) || !data) { + sq_throwerror(vm, _SC("'stop' called without instance")); return SQ_ERROR; } + scripting::Wind* _this = reinterpret_cast (data); try { - Scripting::import(arg0, arg1); + _this->stop(); return 0; @@ -2903,18 +3077,23 @@ static SQInteger import_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'import'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'stop'")); return SQ_ERROR; } } -static SQInteger save_state_wrapper(HSQUIRRELVM vm) +static SQInteger display_wrapper(HSQUIRRELVM vm) { - (void) vm; + return scripting::display(vm); +} + +static SQInteger print_stacktrace_wrapper(HSQUIRRELVM vm) +{ + HSQUIRRELVM arg0 = vm; try { - Scripting::save_state(); + scripting::print_stacktrace(arg0); return 0; @@ -2922,18 +3101,27 @@ static SQInteger save_state_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'save_state'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'print_stacktrace'")); return SQ_ERROR; } } -static SQInteger update_worldmap_wrapper(HSQUIRRELVM vm) +static SQInteger get_current_thread_wrapper(HSQUIRRELVM vm) +{ + return scripting::get_current_thread(vm); +} + +static SQInteger display_text_file_wrapper(HSQUIRRELVM vm) { - (void) vm; + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } try { - Scripting::update_worldmap(); + scripting::display_text_file(arg0); return 0; @@ -2941,22 +3129,22 @@ static SQInteger update_worldmap_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'update_worldmap'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'display_text_file'")); return SQ_ERROR; } } -static SQInteger debug_collrects_wrapper(HSQUIRRELVM vm) +static SQInteger load_worldmap_wrapper(HSQUIRRELVM vm) { - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } try { - Scripting::debug_collrects(arg0 == SQTrue); + scripting::load_worldmap(arg0); return 0; @@ -2964,22 +3152,22 @@ static SQInteger debug_collrects_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_collrects'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'load_worldmap'")); return SQ_ERROR; } } -static SQInteger debug_show_fps_wrapper(HSQUIRRELVM vm) +static SQInteger load_level_wrapper(HSQUIRRELVM vm) { - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); return SQ_ERROR; } try { - Scripting::debug_show_fps(arg0 == SQTrue); + scripting::load_level(arg0); return 0; @@ -2987,68 +3175,61 @@ static SQInteger debug_show_fps_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_show_fps'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'load_level'")); return SQ_ERROR; } } -static SQInteger debug_draw_solids_only_wrapper(HSQUIRRELVM vm) +static SQInteger wait_wrapper(HSQUIRRELVM vm) { - SQBool arg0; - if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a bool")); + HSQUIRRELVM arg0 = vm; + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg1))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); return SQ_ERROR; } try { - Scripting::debug_draw_solids_only(arg0 == SQTrue); + scripting::wait(arg0, static_cast (arg1)); - return 0; + return sq_suspendvm(vm); } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_draw_solids_only'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'wait'")); return SQ_ERROR; } } -static SQInteger play_music_wrapper(HSQUIRRELVM vm) +static SQInteger wait_for_screenswitch_wrapper(HSQUIRRELVM vm) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); - return SQ_ERROR; - } + HSQUIRRELVM arg0 = vm; try { - Scripting::play_music(arg0); + scripting::wait_for_screenswitch(arg0); - return 0; + return sq_suspendvm(vm); } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'play_music'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'wait_for_screenswitch'")); return SQ_ERROR; } } -static SQInteger play_sound_wrapper(HSQUIRRELVM vm) +static SQInteger exit_screen_wrapper(HSQUIRRELVM vm) { - const SQChar* arg0; - if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { - sq_throwerror(vm, _SC("Argument 1 not a string")); - return SQ_ERROR; - } + (void) vm; try { - Scripting::play_sound(arg0); + scripting::exit_screen(); return 0; @@ -3056,18 +3237,22 @@ static SQInteger play_sound_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'play_sound'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'exit_screen'")); return SQ_ERROR; } } -static SQInteger grease_wrapper(HSQUIRRELVM vm) +static SQInteger fadeout_screen_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } try { - Scripting::grease(); + scripting::fadeout_screen(static_cast (arg0)); return 0; @@ -3075,18 +3260,32 @@ static SQInteger grease_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'grease'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'fadeout_screen'")); return SQ_ERROR; } } -static SQInteger invincible_wrapper(HSQUIRRELVM vm) +static SQInteger shrink_screen_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + SQFloat arg1; + if(SQ_FAILED(sq_getfloat(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a float")); + return SQ_ERROR; + } + SQFloat arg2; + if(SQ_FAILED(sq_getfloat(vm, 4, &arg2))) { + sq_throwerror(vm, _SC("Argument 3 not a float")); + return SQ_ERROR; + } try { - Scripting::invincible(); + scripting::shrink_screen(static_cast (arg0), static_cast (arg1), static_cast (arg2)); return 0; @@ -3094,18 +3293,18 @@ static SQInteger invincible_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'invincible'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'shrink_screen'")); return SQ_ERROR; } } -static SQInteger ghost_wrapper(HSQUIRRELVM vm) +static SQInteger abort_screenfade_wrapper(HSQUIRRELVM vm) { (void) vm; try { - Scripting::ghost(); + scripting::abort_screenfade(); return 0; @@ -3113,37 +3312,47 @@ static SQInteger ghost_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'ghost'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'abort_screenfade'")); return SQ_ERROR; } } -static SQInteger mortal_wrapper(HSQUIRRELVM vm) +static SQInteger translate_wrapper(HSQUIRRELVM vm) { - (void) vm; + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } try { - Scripting::mortal(); + std::string return_value = scripting::translate(arg0); - return 0; + sq_pushstring(vm, return_value.c_str(), return_value.size()); + return 1; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'mortal'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'translate'")); return SQ_ERROR; } } -static SQInteger restart_wrapper(HSQUIRRELVM vm) +static SQInteger import_wrapper(HSQUIRRELVM vm) { - (void) vm; + HSQUIRRELVM arg0 = vm; + const SQChar* arg1; + if(SQ_FAILED(sq_getstring(vm, 2, &arg1))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } try { - Scripting::restart(); + scripting::import(arg0, arg1); return 0; @@ -3151,18 +3360,18 @@ static SQInteger restart_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'restart'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'import'")); return SQ_ERROR; } } -static SQInteger whereami_wrapper(HSQUIRRELVM vm) +static SQInteger save_state_wrapper(HSQUIRRELVM vm) { (void) vm; try { - Scripting::whereami(); + scripting::save_state(); return 0; @@ -3170,18 +3379,22 @@ static SQInteger whereami_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'whereami'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'save_state'")); return SQ_ERROR; } } -static SQInteger gotoend_wrapper(HSQUIRRELVM vm) +static SQInteger debug_collrects_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } try { - Scripting::gotoend(); + scripting::debug_collrects(arg0 == SQTrue); return 0; @@ -3189,18 +3402,22 @@ static SQInteger gotoend_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'gotoend'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_collrects'")); return SQ_ERROR; } } -static SQInteger camera_wrapper(HSQUIRRELVM vm) +static SQInteger debug_show_fps_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } try { - Scripting::camera(); + scripting::debug_show_fps(arg0 == SQTrue); return 0; @@ -3208,18 +3425,22 @@ static SQInteger camera_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'camera'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_show_fps'")); return SQ_ERROR; } } -static SQInteger quit_wrapper(HSQUIRRELVM vm) +static SQInteger debug_draw_solids_only_wrapper(HSQUIRRELVM vm) { - (void) vm; + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } try { - Scripting::quit(); + scripting::debug_draw_solids_only(arg0 == SQTrue); return 0; @@ -3227,191 +3448,606 @@ static SQInteger quit_wrapper(HSQUIRRELVM vm) sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'quit'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_draw_solids_only'")); return SQ_ERROR; } } -static SQInteger rand_wrapper(HSQUIRRELVM vm) +static SQInteger debug_draw_editor_images_wrapper(HSQUIRRELVM vm) { + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } try { - int return_value = Scripting::rand(); + scripting::debug_draw_editor_images(arg0 == SQTrue); - sq_pushinteger(vm, return_value); - return 1; + return 0; } catch(std::exception& e) { sq_throwerror(vm, e.what()); return SQ_ERROR; } catch(...) { - sq_throwerror(vm, _SC("Unexpected exception while executing function 'rand'")); + sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_draw_editor_images'")); return SQ_ERROR; } } -} // end of namespace Wrapper -void create_squirrel_instance(HSQUIRRELVM v, Scripting::DisplayEffect* object, bool setup_releasehook) +static SQInteger debug_worldmap_ghost_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; - - sq_pushroottable(v); - sq_pushstring(v, "DisplayEffect", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'DisplayEffect'"; - throw SquirrelError(v, msg.str()); + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; } - if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { - std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'DisplayEffect'"; - throw SquirrelError(v, msg.str()); - } - sq_remove(v, -2); // remove object name + try { + scripting::debug_worldmap_ghost(arg0 == SQTrue); - if(setup_releasehook) { - sq_setreleasehook(v, -1, DisplayEffect_release_hook); + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'debug_worldmap_ghost'")); + return SQ_ERROR; } - sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Camera* object, bool setup_releasehook) +static SQInteger play_music_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; - - sq_pushroottable(v); - sq_pushstring(v, "Camera", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Camera'"; - throw SquirrelError(v, msg.str()); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; } - if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { - std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Camera'"; - throw SquirrelError(v, msg.str()); - } - sq_remove(v, -2); // remove object name + try { + scripting::play_music(arg0); - if(setup_releasehook) { - sq_setreleasehook(v, -1, Camera_release_hook); + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'play_music'")); + return SQ_ERROR; } - sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Level* object, bool setup_releasehook) +static SQInteger play_sound_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; - - sq_pushroottable(v); - sq_pushstring(v, "Level", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Level'"; - throw SquirrelError(v, msg.str()); + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; } - if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { - std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Level'"; - throw SquirrelError(v, msg.str()); - } - sq_remove(v, -2); // remove object name + try { + scripting::play_sound(arg0); - if(setup_releasehook) { - sq_setreleasehook(v, -1, Level_release_hook); + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'play_sound'")); + return SQ_ERROR; } - sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::ScriptedObject* object, bool setup_releasehook) +static SQInteger set_game_speed_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; - - sq_pushroottable(v); - sq_pushstring(v, "ScriptedObject", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'ScriptedObject'"; - throw SquirrelError(v, msg.str()); + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; } - if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { - std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'ScriptedObject'"; - throw SquirrelError(v, msg.str()); - } - sq_remove(v, -2); // remove object name + try { + scripting::set_game_speed(static_cast (arg0)); - if(setup_releasehook) { - sq_setreleasehook(v, -1, ScriptedObject_release_hook); + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_game_speed'")); + return SQ_ERROR; } - sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Text* object, bool setup_releasehook) +static SQInteger grease_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; + (void) vm; - sq_pushroottable(v); - sq_pushstring(v, "Text", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Text'"; - throw SquirrelError(v, msg.str()); - } + try { + scripting::grease(); - if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { - std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Text'"; - throw SquirrelError(v, msg.str()); - } - sq_remove(v, -2); // remove object name + return 0; - if(setup_releasehook) { - sq_setreleasehook(v, -1, Text_release_hook); + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'grease'")); + return SQ_ERROR; } - sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Player* object, bool setup_releasehook) +static SQInteger invincible_wrapper(HSQUIRRELVM vm) { - using namespace Wrapper; + (void) vm; - sq_pushroottable(v); - sq_pushstring(v, "Player", -1); - if(SQ_FAILED(sq_get(v, -2))) { - std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Player'"; - throw SquirrelError(v, msg.str()); + try { + scripting::invincible(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'invincible'")); + return SQ_ERROR; + } + +} + +static SQInteger ghost_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::ghost(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'ghost'")); + return SQ_ERROR; + } + +} + +static SQInteger mortal_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::mortal(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'mortal'")); + return SQ_ERROR; + } + +} + +static SQInteger restart_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::restart(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'restart'")); + return SQ_ERROR; + } + +} + +static SQInteger whereami_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::whereami(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'whereami'")); + return SQ_ERROR; + } + +} + +static SQInteger gotoend_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::gotoend(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'gotoend'")); + return SQ_ERROR; + } + +} + +static SQInteger camera_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::camera(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'camera'")); + return SQ_ERROR; + } + +} + +static SQInteger set_gamma_wrapper(HSQUIRRELVM vm) +{ + SQFloat arg0; + if(SQ_FAILED(sq_getfloat(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a float")); + return SQ_ERROR; + } + + try { + scripting::set_gamma(static_cast (arg0)); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'set_gamma'")); + return SQ_ERROR; + } + +} + +static SQInteger quit_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::quit(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'quit'")); + return SQ_ERROR; + } + +} + +static SQInteger rand_wrapper(HSQUIRRELVM vm) +{ + + try { + int return_value = scripting::rand(); + + sq_pushinteger(vm, return_value); + return 1; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'rand'")); + return SQ_ERROR; + } + +} + +static SQInteger record_demo_wrapper(HSQUIRRELVM vm) +{ + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } + + try { + scripting::record_demo(arg0); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'record_demo'")); + return SQ_ERROR; + } + +} + +static SQInteger play_demo_wrapper(HSQUIRRELVM vm) +{ + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } + + try { + scripting::play_demo(arg0); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'play_demo'")); + return SQ_ERROR; + } + +} + +static SQInteger Level_finish_wrapper(HSQUIRRELVM vm) +{ + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } + + try { + scripting::Level_finish(arg0 == SQTrue); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'Level_finish'")); + return SQ_ERROR; + } + +} + +static SQInteger Level_spawn_wrapper(HSQUIRRELVM vm) +{ + const SQChar* arg0; + if(SQ_FAILED(sq_getstring(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a string")); + return SQ_ERROR; + } + const SQChar* arg1; + if(SQ_FAILED(sq_getstring(vm, 3, &arg1))) { + sq_throwerror(vm, _SC("Argument 2 not a string")); + return SQ_ERROR; + } + + try { + scripting::Level_spawn(arg0, arg1); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'Level_spawn'")); + return SQ_ERROR; + } + +} + +static SQInteger Level_flip_vertically_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::Level_flip_vertically(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'Level_flip_vertically'")); + return SQ_ERROR; + } + +} + +static SQInteger Level_toggle_pause_wrapper(HSQUIRRELVM vm) +{ + (void) vm; + + try { + scripting::Level_toggle_pause(); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'Level_toggle_pause'")); + return SQ_ERROR; + } + +} + +static SQInteger Level_edit_wrapper(HSQUIRRELVM vm) +{ + SQBool arg0; + if(SQ_FAILED(sq_getbool(vm, 2, &arg0))) { + sq_throwerror(vm, _SC("Argument 1 not a bool")); + return SQ_ERROR; + } + + try { + scripting::Level_edit(arg0 == SQTrue); + + return 0; + + } catch(std::exception& e) { + sq_throwerror(vm, e.what()); + return SQ_ERROR; + } catch(...) { + sq_throwerror(vm, _SC("Unexpected exception while executing function 'Level_edit'")); + return SQ_ERROR; + } + +} + +} // namespace wrapper +void create_squirrel_instance(HSQUIRRELVM v, scripting::AmbientSound* object, bool setup_releasehook) +{ + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "AmbientSound", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'AmbientSound'"; + throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Player'"; + msg << "Couldn't setup squirrel instance for object of type 'AmbientSound'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, Player_release_hook); + sq_setreleasehook(v, -1, AmbientSound_release_hook); + } + + sq_remove(v, -2); // remove root table +} + +void create_squirrel_instance(HSQUIRRELVM v, scripting::Camera* object, bool setup_releasehook) +{ + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "Camera", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'Camera'"; + throw SquirrelError(v, msg.str()); + } + + if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { + std::ostringstream msg; + msg << "Couldn't setup squirrel instance for object of type 'Camera'"; + throw SquirrelError(v, msg.str()); + } + sq_remove(v, -2); // remove object name + + if(setup_releasehook) { + sq_setreleasehook(v, -1, Camera_release_hook); + } + + sq_remove(v, -2); // remove root table +} + +void create_squirrel_instance(HSQUIRRELVM v, scripting::Candle* object, bool setup_releasehook) +{ + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "Candle", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'Candle'"; + throw SquirrelError(v, msg.str()); + } + + if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { + std::ostringstream msg; + msg << "Couldn't setup squirrel instance for object of type 'Candle'"; + throw SquirrelError(v, msg.str()); + } + sq_remove(v, -2); // remove object name + + if(setup_releasehook) { + sq_setreleasehook(v, -1, Candle_release_hook); } sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::FloatingImage* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::DisplayEffect* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "DisplayEffect", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'DisplayEffect'"; + throw SquirrelError(v, msg.str()); + } + + if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { + std::ostringstream msg; + msg << "Couldn't setup squirrel instance for object of type 'DisplayEffect'"; + throw SquirrelError(v, msg.str()); + } + sq_remove(v, -2); // remove object name + + if(setup_releasehook) { + sq_setreleasehook(v, -1, DisplayEffect_release_hook); + } + + sq_remove(v, -2); // remove root table +} + +void create_squirrel_instance(HSQUIRRELVM v, scripting::FloatingImage* object, bool setup_releasehook) +{ + using namespace wrapper; sq_pushroottable(v); sq_pushstring(v, "FloatingImage", -1); @@ -3435,9 +4071,35 @@ void create_squirrel_instance(HSQUIRRELVM v, Scripting::FloatingImage* object, b sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Platform* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::LevelTime* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "LevelTime", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'LevelTime'"; + throw SquirrelError(v, msg.str()); + } + + if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { + std::ostringstream msg; + msg << "Couldn't setup squirrel instance for object of type 'LevelTime'"; + throw SquirrelError(v, msg.str()); + } + sq_remove(v, -2); // remove object name + + if(setup_releasehook) { + sq_setreleasehook(v, -1, LevelTime_release_hook); + } + + sq_remove(v, -2); // remove root table +} + +void create_squirrel_instance(HSQUIRRELVM v, scripting::Platform* object, bool setup_releasehook) +{ + using namespace wrapper; sq_pushroottable(v); sq_pushstring(v, "Platform", -1); @@ -3461,87 +4123,113 @@ void create_squirrel_instance(HSQUIRRELVM v, Scripting::Platform* object, bool s sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Candle* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::Player* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); - sq_pushstring(v, "Candle", -1); + sq_pushstring(v, "Player", -1); if(SQ_FAILED(sq_get(v, -2))) { std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Candle'"; + msg << "Couldn't resolved squirrel type 'Player'"; throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Candle'"; + msg << "Couldn't setup squirrel instance for object of type 'Player'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, Candle_release_hook); + sq_setreleasehook(v, -1, Player_release_hook); } sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Wind* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::ScriptedObject* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); - sq_pushstring(v, "Wind", -1); + sq_pushstring(v, "ScriptedObject", -1); if(SQ_FAILED(sq_get(v, -2))) { std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'Wind'"; + msg << "Couldn't resolved squirrel type 'ScriptedObject'"; throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'Wind'"; + msg << "Couldn't setup squirrel instance for object of type 'ScriptedObject'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, Wind_release_hook); + sq_setreleasehook(v, -1, ScriptedObject_release_hook); } sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::AmbientSound* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::SSector* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); - sq_pushstring(v, "AmbientSound", -1); + sq_pushstring(v, "SSector", -1); if(SQ_FAILED(sq_get(v, -2))) { std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'AmbientSound'"; + msg << "Couldn't resolved squirrel type 'SSector'"; throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'AmbientSound'"; + msg << "Couldn't setup squirrel instance for object of type 'SSector'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, AmbientSound_release_hook); + sq_setreleasehook(v, -1, SSector_release_hook); } sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::Thunderstorm* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::Text* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; + + sq_pushroottable(v); + sq_pushstring(v, "Text", -1); + if(SQ_FAILED(sq_get(v, -2))) { + std::ostringstream msg; + msg << "Couldn't resolved squirrel type 'Text'"; + throw SquirrelError(v, msg.str()); + } + + if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { + std::ostringstream msg; + msg << "Couldn't setup squirrel instance for object of type 'Text'"; + throw SquirrelError(v, msg.str()); + } + sq_remove(v, -2); // remove object name + + if(setup_releasehook) { + sq_setreleasehook(v, -1, Text_release_hook); + } + + sq_remove(v, -2); // remove root table +} + +void create_squirrel_instance(HSQUIRRELVM v, scripting::Thunderstorm* object, bool setup_releasehook) +{ + using namespace wrapper; sq_pushroottable(v); sq_pushstring(v, "Thunderstorm", -1); @@ -3565,9 +4253,9 @@ void create_squirrel_instance(HSQUIRRELVM v, Scripting::Thunderstorm* object, bo sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::TileMap* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::TileMap* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); sq_pushstring(v, "TileMap", -1); @@ -3591,53 +4279,53 @@ void create_squirrel_instance(HSQUIRRELVM v, Scripting::TileMap* object, bool se sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::SSector* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::WillOWisp* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); - sq_pushstring(v, "SSector", -1); + sq_pushstring(v, "WillOWisp", -1); if(SQ_FAILED(sq_get(v, -2))) { std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'SSector'"; + msg << "Couldn't resolved squirrel type 'WillOWisp'"; throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'SSector'"; + msg << "Couldn't setup squirrel instance for object of type 'WillOWisp'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, SSector_release_hook); + sq_setreleasehook(v, -1, WillOWisp_release_hook); } sq_remove(v, -2); // remove root table } -void create_squirrel_instance(HSQUIRRELVM v, Scripting::LevelTime* object, bool setup_releasehook) +void create_squirrel_instance(HSQUIRRELVM v, scripting::Wind* object, bool setup_releasehook) { - using namespace Wrapper; + using namespace wrapper; sq_pushroottable(v); - sq_pushstring(v, "LevelTime", -1); + sq_pushstring(v, "Wind", -1); if(SQ_FAILED(sq_get(v, -2))) { std::ostringstream msg; - msg << "Couldn't resolved squirrel type 'LevelTime'"; + msg << "Couldn't resolved squirrel type 'Wind'"; throw SquirrelError(v, msg.str()); } if(SQ_FAILED(sq_createinstance(v, -1)) || SQ_FAILED(sq_setinstanceup(v, -1, object))) { std::ostringstream msg; - msg << "Couldn't setup squirrel instance for object of type 'LevelTime'"; + msg << "Couldn't setup squirrel instance for object of type 'Wind'"; throw SquirrelError(v, msg.str()); } sq_remove(v, -2); // remove object name if(setup_releasehook) { - sq_setreleasehook(v, -1, LevelTime_release_hook); + sq_setreleasehook(v, -1, Wind_release_hook); } sq_remove(v, -2); // remove root table @@ -3645,7 +4333,7 @@ void create_squirrel_instance(HSQUIRRELVM v, Scripting::LevelTime* object, bool void register_supertux_wrapper(HSQUIRRELVM v) { - using namespace Wrapper; + using namespace wrapper; sq_pushstring(v, "ANCHOR_TOP", -1); sq_pushinteger(v, 16); @@ -3703,229 +4391,321 @@ void register_supertux_wrapper(HSQUIRRELVM v) sq_pushstring(v, "display", -1); sq_newclosure(v, &display_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "t."); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'display'"); } sq_pushstring(v, "print_stacktrace", -1); sq_newclosure(v, &print_stacktrace_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'print_stacktrace'"); } sq_pushstring(v, "get_current_thread", -1); sq_newclosure(v, &get_current_thread_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_current_thread'"); } sq_pushstring(v, "display_text_file", -1); sq_newclosure(v, &display_text_file_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'display_text_file'"); } sq_pushstring(v, "load_worldmap", -1); sq_newclosure(v, &load_worldmap_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'load_worldmap'"); } sq_pushstring(v, "load_level", -1); sq_newclosure(v, &load_level_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'load_level'"); } sq_pushstring(v, "wait", -1); sq_newclosure(v, &wait_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'wait'"); } sq_pushstring(v, "wait_for_screenswitch", -1); sq_newclosure(v, &wait_for_screenswitch_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'wait_for_screenswitch'"); } sq_pushstring(v, "exit_screen", -1); sq_newclosure(v, &exit_screen_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'exit_screen'"); } sq_pushstring(v, "fadeout_screen", -1); sq_newclosure(v, &fadeout_screen_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'fadeout_screen'"); } sq_pushstring(v, "shrink_screen", -1); sq_newclosure(v, &shrink_screen_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'shrink_screen'"); } + sq_pushstring(v, "abort_screenfade", -1); + sq_newclosure(v, &abort_screenfade_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'abort_screenfade'"); + } + sq_pushstring(v, "translate", -1); sq_newclosure(v, &translate_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'translate'"); } sq_pushstring(v, "import", -1); sq_newclosure(v, &import_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'import'"); } sq_pushstring(v, "save_state", -1); sq_newclosure(v, &save_state_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'save_state'"); } - sq_pushstring(v, "update_worldmap", -1); - sq_newclosure(v, &update_worldmap_wrapper, 0); - if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'update_worldmap'"); - } - sq_pushstring(v, "debug_collrects", -1); sq_newclosure(v, &debug_collrects_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'debug_collrects'"); } sq_pushstring(v, "debug_show_fps", -1); sq_newclosure(v, &debug_show_fps_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'debug_show_fps'"); } sq_pushstring(v, "debug_draw_solids_only", -1); sq_newclosure(v, &debug_draw_solids_only_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'debug_draw_solids_only'"); } + sq_pushstring(v, "debug_draw_editor_images", -1); + sq_newclosure(v, &debug_draw_editor_images_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'debug_draw_editor_images'"); + } + + sq_pushstring(v, "debug_worldmap_ghost", -1); + sq_newclosure(v, &debug_worldmap_ghost_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'debug_worldmap_ghost'"); + } + sq_pushstring(v, "play_music", -1); sq_newclosure(v, &play_music_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'play_music'"); } sq_pushstring(v, "play_sound", -1); sq_newclosure(v, &play_sound_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'play_sound'"); } + sq_pushstring(v, "set_game_speed", -1); + sq_newclosure(v, &set_game_speed_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_game_speed'"); + } + sq_pushstring(v, "grease", -1); sq_newclosure(v, &grease_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'grease'"); } sq_pushstring(v, "invincible", -1); sq_newclosure(v, &invincible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'invincible'"); } sq_pushstring(v, "ghost", -1); sq_newclosure(v, &ghost_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'ghost'"); } sq_pushstring(v, "mortal", -1); sq_newclosure(v, &mortal_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'mortal'"); } sq_pushstring(v, "restart", -1); sq_newclosure(v, &restart_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'restart'"); } sq_pushstring(v, "whereami", -1); sq_newclosure(v, &whereami_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'whereami'"); } sq_pushstring(v, "gotoend", -1); sq_newclosure(v, &gotoend_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'gotoend'"); } sq_pushstring(v, "camera", -1); sq_newclosure(v, &camera_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'camera'"); } + sq_pushstring(v, "set_gamma", -1); + sq_newclosure(v, &set_gamma_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_gamma'"); + } + sq_pushstring(v, "quit", -1); sq_newclosure(v, &quit_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'quit'"); } sq_pushstring(v, "rand", -1); sq_newclosure(v, &rand_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'rand'"); } - // Register class DisplayEffect - sq_pushstring(v, "DisplayEffect", -1); - if(sq_newclass(v, SQFalse) < 0) { - std::ostringstream msg; - msg << "Couldn't create new class 'DisplayEffect'"; - throw SquirrelError(v, msg.str()); + sq_pushstring(v, "record_demo", -1); + sq_newclosure(v, &record_demo_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'record_demo'"); } - sq_pushstring(v, "fade_out", -1); - sq_newclosure(v, &DisplayEffect_fade_out_wrapper, 0); + + sq_pushstring(v, "play_demo", -1); + sq_newclosure(v, &play_demo_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_out'"); + throw SquirrelError(v, "Couldn't register function 'play_demo'"); } - sq_pushstring(v, "fade_in", -1); - sq_newclosure(v, &DisplayEffect_fade_in_wrapper, 0); + sq_pushstring(v, "Level_finish", -1); + sq_newclosure(v, &Level_finish_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_in'"); + throw SquirrelError(v, "Couldn't register function 'Level_finish'"); } - sq_pushstring(v, "set_black", -1); - sq_newclosure(v, &DisplayEffect_set_black_wrapper, 0); + sq_pushstring(v, "Level_spawn", -1); + sq_newclosure(v, &Level_spawn_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tss"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_black'"); + throw SquirrelError(v, "Couldn't register function 'Level_spawn'"); } - sq_pushstring(v, "is_black", -1); - sq_newclosure(v, &DisplayEffect_is_black_wrapper, 0); + sq_pushstring(v, "Level_flip_vertically", -1); + sq_newclosure(v, &Level_flip_vertically_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'is_black'"); + throw SquirrelError(v, "Couldn't register function 'Level_flip_vertically'"); } - sq_pushstring(v, "sixteen_to_nine", -1); - sq_newclosure(v, &DisplayEffect_sixteen_to_nine_wrapper, 0); + sq_pushstring(v, "Level_toggle_pause", -1); + sq_newclosure(v, &Level_toggle_pause_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'sixteen_to_nine'"); + throw SquirrelError(v, "Couldn't register function 'Level_toggle_pause'"); } - sq_pushstring(v, "four_to_three", -1); - sq_newclosure(v, &DisplayEffect_four_to_three_wrapper, 0); + sq_pushstring(v, "Level_edit", -1); + sq_newclosure(v, &Level_edit_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'four_to_three'"); + throw SquirrelError(v, "Couldn't register function 'Level_edit'"); + } + + // Register class AmbientSound + sq_pushstring(v, "AmbientSound", -1); + if(sq_newclass(v, SQFalse) < 0) { + std::ostringstream msg; + msg << "Couldn't create new class 'AmbientSound'"; + throw SquirrelError(v, msg.str()); + } + sq_pushstring(v, "set_pos", -1); + sq_newclosure(v, &AmbientSound_set_pos_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_pos'"); } + sq_pushstring(v, "get_pos_x", -1); + sq_newclosure(v, &AmbientSound_get_pos_x_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'DisplayEffect'"); + throw SquirrelError(v, "Couldn't register function 'get_pos_x'"); + } + + sq_pushstring(v, "get_pos_y", -1); + sq_newclosure(v, &AmbientSound_get_pos_y_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'get_pos_y'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'AmbientSound'"); } // Register class Camera @@ -3935,26 +4715,37 @@ void register_supertux_wrapper(HSQUIRRELVM v) msg << "Couldn't create new class 'Camera'"; throw SquirrelError(v, msg.str()); } + sq_pushstring(v, "reload_config", -1); + sq_newclosure(v, &Camera_reload_config_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'reload_config'"); + } + sq_pushstring(v, "shake", -1); sq_newclosure(v, &Camera_shake_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'shake'"); } sq_pushstring(v, "set_pos", -1); sq_newclosure(v, &Camera_set_pos_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_pos'"); } sq_pushstring(v, "set_mode", -1); sq_newclosure(v, &Camera_set_mode_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_mode'"); } sq_pushstring(v, "scroll_to", -1); sq_newclosure(v, &Camera_scroll_to_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'scroll_to'"); } @@ -3963,181 +4754,262 @@ void register_supertux_wrapper(HSQUIRRELVM v) throw SquirrelError(v, "Couldn't register class 'Camera'"); } - // Register class Level - sq_pushstring(v, "Level", -1); + // Register class Candle + sq_pushstring(v, "Candle", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'Level'"; + msg << "Couldn't create new class 'Candle'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "finish", -1); - sq_newclosure(v, &Level_finish_wrapper, 0); + sq_pushstring(v, "get_burning", -1); + sq_newclosure(v, &Candle_get_burning_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'finish'"); + throw SquirrelError(v, "Couldn't register function 'get_burning'"); } - sq_pushstring(v, "spawn", -1); - sq_newclosure(v, &Level_spawn_wrapper, 0); + sq_pushstring(v, "set_burning", -1); + sq_newclosure(v, &Candle_set_burning_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'spawn'"); + throw SquirrelError(v, "Couldn't register function 'set_burning'"); } - sq_pushstring(v, "flip_vertically", -1); - sq_newclosure(v, &Level_flip_vertically_wrapper, 0); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'flip_vertically'"); + throw SquirrelError(v, "Couldn't register class 'Candle'"); } - sq_pushstring(v, "toggle_pause", -1); - sq_newclosure(v, &Level_toggle_pause_wrapper, 0); + // Register class DisplayEffect + sq_pushstring(v, "DisplayEffect", -1); + if(sq_newclass(v, SQFalse) < 0) { + std::ostringstream msg; + msg << "Couldn't create new class 'DisplayEffect'"; + throw SquirrelError(v, msg.str()); + } + sq_pushstring(v, "fade_out", -1); + sq_newclosure(v, &DisplayEffect_fade_out_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'toggle_pause'"); + throw SquirrelError(v, "Couldn't register function 'fade_out'"); } + sq_pushstring(v, "fade_in", -1); + sq_newclosure(v, &DisplayEffect_fade_in_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'Level'"); + throw SquirrelError(v, "Couldn't register function 'fade_in'"); } - // Register class ScriptedObject - sq_pushstring(v, "ScriptedObject", -1); + sq_pushstring(v, "set_black", -1); + sq_newclosure(v, &DisplayEffect_set_black_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_black'"); + } + + sq_pushstring(v, "is_black", -1); + sq_newclosure(v, &DisplayEffect_is_black_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'is_black'"); + } + + sq_pushstring(v, "sixteen_to_nine", -1); + sq_newclosure(v, &DisplayEffect_sixteen_to_nine_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'sixteen_to_nine'"); + } + + sq_pushstring(v, "four_to_three", -1); + sq_newclosure(v, &DisplayEffect_four_to_three_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'four_to_three'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'DisplayEffect'"); + } + + // Register class FloatingImage + sq_pushstring(v, "FloatingImage", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'ScriptedObject'"; + msg << "Couldn't create new class 'FloatingImage'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "set_action", -1); - sq_newclosure(v, &ScriptedObject_set_action_wrapper, 0); + sq_pushstring(v, "constructor", -1); + sq_newclosure(v, &FloatingImage_constructor_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_action'"); + throw SquirrelError(v, "Couldn't register function 'constructor'"); } - sq_pushstring(v, "get_action", -1); - sq_newclosure(v, &ScriptedObject_get_action_wrapper, 0); + sq_pushstring(v, "set_layer", -1); + sq_newclosure(v, &FloatingImage_set_layer_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_action'"); + throw SquirrelError(v, "Couldn't register function 'set_layer'"); } - sq_pushstring(v, "move", -1); - sq_newclosure(v, &ScriptedObject_move_wrapper, 0); + sq_pushstring(v, "get_layer", -1); + sq_newclosure(v, &FloatingImage_get_layer_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'move'"); + throw SquirrelError(v, "Couldn't register function 'get_layer'"); } sq_pushstring(v, "set_pos", -1); - sq_newclosure(v, &ScriptedObject_set_pos_wrapper, 0); + sq_newclosure(v, &FloatingImage_set_pos_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_pos'"); } sq_pushstring(v, "get_pos_x", -1); - sq_newclosure(v, &ScriptedObject_get_pos_x_wrapper, 0); + sq_newclosure(v, &FloatingImage_get_pos_x_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_x'"); } sq_pushstring(v, "get_pos_y", -1); - sq_newclosure(v, &ScriptedObject_get_pos_y_wrapper, 0); + sq_newclosure(v, &FloatingImage_get_pos_y_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_y'"); } - sq_pushstring(v, "set_velocity", -1); - sq_newclosure(v, &ScriptedObject_set_velocity_wrapper, 0); + sq_pushstring(v, "set_anchor_point", -1); + sq_newclosure(v, &FloatingImage_set_anchor_point_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_velocity'"); + throw SquirrelError(v, "Couldn't register function 'set_anchor_point'"); } - sq_pushstring(v, "get_velocity_x", -1); - sq_newclosure(v, &ScriptedObject_get_velocity_x_wrapper, 0); + sq_pushstring(v, "get_anchor_point", -1); + sq_newclosure(v, &FloatingImage_get_anchor_point_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_velocity_x'"); + throw SquirrelError(v, "Couldn't register function 'get_anchor_point'"); } - sq_pushstring(v, "get_velocity_y", -1); - sq_newclosure(v, &ScriptedObject_get_velocity_y_wrapper, 0); + sq_pushstring(v, "set_visible", -1); + sq_newclosure(v, &FloatingImage_set_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_velocity_y'"); + throw SquirrelError(v, "Couldn't register function 'set_visible'"); } - sq_pushstring(v, "set_visible", -1); - sq_newclosure(v, &ScriptedObject_set_visible_wrapper, 0); + sq_pushstring(v, "get_visible", -1); + sq_newclosure(v, &FloatingImage_get_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_visible'"); + throw SquirrelError(v, "Couldn't register function 'get_visible'"); } - sq_pushstring(v, "is_visible", -1); - sq_newclosure(v, &ScriptedObject_is_visible_wrapper, 0); + sq_pushstring(v, "set_action", -1); + sq_newclosure(v, &FloatingImage_set_action_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'is_visible'"); + throw SquirrelError(v, "Couldn't register function 'set_action'"); } - sq_pushstring(v, "set_solid", -1); - sq_newclosure(v, &ScriptedObject_set_solid_wrapper, 0); + sq_pushstring(v, "get_action", -1); + sq_newclosure(v, &FloatingImage_get_action_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_solid'"); + throw SquirrelError(v, "Couldn't register function 'get_action'"); } - sq_pushstring(v, "is_solid", -1); - sq_newclosure(v, &ScriptedObject_is_solid_wrapper, 0); + sq_pushstring(v, "fade_in", -1); + sq_newclosure(v, &FloatingImage_fade_in_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'is_solid'"); + throw SquirrelError(v, "Couldn't register function 'fade_in'"); } - sq_pushstring(v, "get_name", -1); - sq_newclosure(v, &ScriptedObject_get_name_wrapper, 0); + sq_pushstring(v, "fade_out", -1); + sq_newclosure(v, &FloatingImage_fade_out_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_name'"); + throw SquirrelError(v, "Couldn't register function 'fade_out'"); } if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'ScriptedObject'"); + throw SquirrelError(v, "Couldn't register class 'FloatingImage'"); } - // Register class Text - sq_pushstring(v, "Text", -1); + // Register class LevelTime + sq_pushstring(v, "LevelTime", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'Text'"; + msg << "Couldn't create new class 'LevelTime'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "set_text", -1); - sq_newclosure(v, &Text_set_text_wrapper, 0); + sq_pushstring(v, "start", -1); + sq_newclosure(v, &LevelTime_start_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_text'"); + throw SquirrelError(v, "Couldn't register function 'start'"); } - sq_pushstring(v, "set_font", -1); - sq_newclosure(v, &Text_set_font_wrapper, 0); + sq_pushstring(v, "stop", -1); + sq_newclosure(v, &LevelTime_stop_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_font'"); + throw SquirrelError(v, "Couldn't register function 'stop'"); } - sq_pushstring(v, "fade_in", -1); - sq_newclosure(v, &Text_fade_in_wrapper, 0); + sq_pushstring(v, "get_time", -1); + sq_newclosure(v, &LevelTime_get_time_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_in'"); + throw SquirrelError(v, "Couldn't register function 'get_time'"); } - sq_pushstring(v, "fade_out", -1); - sq_newclosure(v, &Text_fade_out_wrapper, 0); + sq_pushstring(v, "set_time", -1); + sq_newclosure(v, &LevelTime_set_time_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_out'"); + throw SquirrelError(v, "Couldn't register function 'set_time'"); } - sq_pushstring(v, "set_visible", -1); - sq_newclosure(v, &Text_set_visible_wrapper, 0); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_visible'"); + throw SquirrelError(v, "Couldn't register class 'LevelTime'"); } - sq_pushstring(v, "set_centered", -1); - sq_newclosure(v, &Text_set_centered_wrapper, 0); + // Register class Platform + sq_pushstring(v, "Platform", -1); + if(sq_newclass(v, SQFalse) < 0) { + std::ostringstream msg; + msg << "Couldn't create new class 'Platform'"; + throw SquirrelError(v, msg.str()); + } + sq_pushstring(v, "goto_node", -1); + sq_newclosure(v, &Platform_goto_node_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_centered'"); + throw SquirrelError(v, "Couldn't register function 'goto_node'"); } + sq_pushstring(v, "start_moving", -1); + sq_newclosure(v, &Platform_start_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'Text'"); + throw SquirrelError(v, "Couldn't register function 'start_moving'"); + } + + sq_pushstring(v, "stop_moving", -1); + sq_newclosure(v, &Platform_stop_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'stop_moving'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'Platform'"); } // Register class Player @@ -4149,307 +5021,410 @@ void register_supertux_wrapper(HSQUIRRELVM v) } sq_pushstring(v, "add_bonus", -1); sq_newclosure(v, &Player_add_bonus_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'add_bonus'"); } sq_pushstring(v, "add_coins", -1); sq_newclosure(v, &Player_add_coins_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'add_coins'"); } sq_pushstring(v, "make_invincible", -1); sq_newclosure(v, &Player_make_invincible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'make_invincible'"); } sq_pushstring(v, "deactivate", -1); sq_newclosure(v, &Player_deactivate_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'deactivate'"); } sq_pushstring(v, "activate", -1); sq_newclosure(v, &Player_activate_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'activate'"); } sq_pushstring(v, "walk", -1); sq_newclosure(v, &Player_walk_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'walk'"); } + sq_pushstring(v, "set_dir", -1); + sq_newclosure(v, &Player_set_dir_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_dir'"); + } + sq_pushstring(v, "set_visible", -1); sq_newclosure(v, &Player_set_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_visible'"); } sq_pushstring(v, "get_visible", -1); sq_newclosure(v, &Player_get_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_visible'"); } sq_pushstring(v, "kill", -1); sq_newclosure(v, &Player_kill_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'kill'"); } sq_pushstring(v, "set_ghost_mode", -1); sq_newclosure(v, &Player_set_ghost_mode_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_ghost_mode'"); } sq_pushstring(v, "get_ghost_mode", -1); sq_newclosure(v, &Player_get_ghost_mode_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_ghost_mode'"); } + sq_pushstring(v, "kick", -1); + sq_newclosure(v, &Player_kick_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'kick'"); + } + sq_pushstring(v, "do_cheer", -1); sq_newclosure(v, &Player_do_cheer_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'do_cheer'"); } sq_pushstring(v, "do_duck", -1); sq_newclosure(v, &Player_do_duck_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'do_duck'"); } sq_pushstring(v, "do_standup", -1); sq_newclosure(v, &Player_do_standup_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'do_standup'"); } sq_pushstring(v, "do_backflip", -1); sq_newclosure(v, &Player_do_backflip_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'do_backflip'"); } sq_pushstring(v, "do_jump", -1); sq_newclosure(v, &Player_do_jump_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'do_jump'"); } sq_pushstring(v, "trigger_sequence", -1); sq_newclosure(v, &Player_trigger_sequence_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'trigger_sequence'"); } + sq_pushstring(v, "use_scripting_controller", -1); + sq_newclosure(v, &Player_use_scripting_controller_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'use_scripting_controller'"); + } + + sq_pushstring(v, "do_scripting_controller", -1); + sq_newclosure(v, &Player_do_scripting_controller_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tsb"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'do_scripting_controller'"); + } + if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register class 'Player'"); } - // Register class FloatingImage - sq_pushstring(v, "FloatingImage", -1); + // Register class ScriptedObject + sq_pushstring(v, "ScriptedObject", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'FloatingImage'"; + msg << "Couldn't create new class 'ScriptedObject'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "constructor", -1); - sq_newclosure(v, &FloatingImage_constructor_wrapper, 0); + sq_pushstring(v, "set_action", -1); + sq_newclosure(v, &ScriptedObject_set_action_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'constructor'"); + throw SquirrelError(v, "Couldn't register function 'set_action'"); } - sq_pushstring(v, "set_layer", -1); - sq_newclosure(v, &FloatingImage_set_layer_wrapper, 0); + sq_pushstring(v, "get_action", -1); + sq_newclosure(v, &ScriptedObject_get_action_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_layer'"); + throw SquirrelError(v, "Couldn't register function 'get_action'"); } - sq_pushstring(v, "get_layer", -1); - sq_newclosure(v, &FloatingImage_get_layer_wrapper, 0); + sq_pushstring(v, "move", -1); + sq_newclosure(v, &ScriptedObject_move_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_layer'"); + throw SquirrelError(v, "Couldn't register function 'move'"); } sq_pushstring(v, "set_pos", -1); - sq_newclosure(v, &FloatingImage_set_pos_wrapper, 0); + sq_newclosure(v, &ScriptedObject_set_pos_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_pos'"); } sq_pushstring(v, "get_pos_x", -1); - sq_newclosure(v, &FloatingImage_get_pos_x_wrapper, 0); + sq_newclosure(v, &ScriptedObject_get_pos_x_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_x'"); } sq_pushstring(v, "get_pos_y", -1); - sq_newclosure(v, &FloatingImage_get_pos_y_wrapper, 0); + sq_newclosure(v, &ScriptedObject_get_pos_y_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_y'"); } - sq_pushstring(v, "set_anchor_point", -1); - sq_newclosure(v, &FloatingImage_set_anchor_point_wrapper, 0); + sq_pushstring(v, "set_velocity", -1); + sq_newclosure(v, &ScriptedObject_set_velocity_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_anchor_point'"); + throw SquirrelError(v, "Couldn't register function 'set_velocity'"); } - sq_pushstring(v, "get_anchor_point", -1); - sq_newclosure(v, &FloatingImage_get_anchor_point_wrapper, 0); + sq_pushstring(v, "get_velocity_x", -1); + sq_newclosure(v, &ScriptedObject_get_velocity_x_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_anchor_point'"); + throw SquirrelError(v, "Couldn't register function 'get_velocity_x'"); } - sq_pushstring(v, "set_visible", -1); - sq_newclosure(v, &FloatingImage_set_visible_wrapper, 0); + sq_pushstring(v, "get_velocity_y", -1); + sq_newclosure(v, &ScriptedObject_get_velocity_y_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_visible'"); + throw SquirrelError(v, "Couldn't register function 'get_velocity_y'"); } - sq_pushstring(v, "get_visible", -1); - sq_newclosure(v, &FloatingImage_get_visible_wrapper, 0); + sq_pushstring(v, "enable_gravity", -1); + sq_newclosure(v, &ScriptedObject_enable_gravity_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_visible'"); + throw SquirrelError(v, "Couldn't register function 'enable_gravity'"); } - sq_pushstring(v, "set_action", -1); - sq_newclosure(v, &FloatingImage_set_action_wrapper, 0); + sq_pushstring(v, "gravity_enabled", -1); + sq_newclosure(v, &ScriptedObject_gravity_enabled_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_action'"); + throw SquirrelError(v, "Couldn't register function 'gravity_enabled'"); } - sq_pushstring(v, "get_action", -1); - sq_newclosure(v, &FloatingImage_get_action_wrapper, 0); + sq_pushstring(v, "set_visible", -1); + sq_newclosure(v, &ScriptedObject_set_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_action'"); + throw SquirrelError(v, "Couldn't register function 'set_visible'"); } - sq_pushstring(v, "fade_in", -1); - sq_newclosure(v, &FloatingImage_fade_in_wrapper, 0); + sq_pushstring(v, "is_visible", -1); + sq_newclosure(v, &ScriptedObject_is_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_in'"); + throw SquirrelError(v, "Couldn't register function 'is_visible'"); } - sq_pushstring(v, "fade_out", -1); - sq_newclosure(v, &FloatingImage_fade_out_wrapper, 0); + sq_pushstring(v, "set_solid", -1); + sq_newclosure(v, &ScriptedObject_set_solid_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'fade_out'"); + throw SquirrelError(v, "Couldn't register function 'set_solid'"); } + sq_pushstring(v, "is_solid", -1); + sq_newclosure(v, &ScriptedObject_is_solid_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'FloatingImage'"); + throw SquirrelError(v, "Couldn't register function 'is_solid'"); } - // Register class Platform - sq_pushstring(v, "Platform", -1); + sq_pushstring(v, "get_name", -1); + sq_newclosure(v, &ScriptedObject_get_name_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'get_name'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'ScriptedObject'"); + } + + // Register class SSector + sq_pushstring(v, "SSector", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'Platform'"; + msg << "Couldn't create new class 'SSector'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "goto_node", -1); - sq_newclosure(v, &Platform_goto_node_wrapper, 0); + sq_pushstring(v, "set_ambient_light", -1); + sq_newclosure(v, &SSector_set_ambient_light_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnnn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'goto_node'"); + throw SquirrelError(v, "Couldn't register function 'set_ambient_light'"); } - sq_pushstring(v, "start_moving", -1); - sq_newclosure(v, &Platform_start_moving_wrapper, 0); + sq_pushstring(v, "get_ambient_red", -1); + sq_newclosure(v, &SSector_get_ambient_red_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'start_moving'"); + throw SquirrelError(v, "Couldn't register function 'get_ambient_red'"); } - sq_pushstring(v, "stop_moving", -1); - sq_newclosure(v, &Platform_stop_moving_wrapper, 0); + sq_pushstring(v, "get_ambient_green", -1); + sq_newclosure(v, &SSector_get_ambient_green_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'stop_moving'"); + throw SquirrelError(v, "Couldn't register function 'get_ambient_green'"); } + sq_pushstring(v, "get_ambient_blue", -1); + sq_newclosure(v, &SSector_get_ambient_blue_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'Platform'"); + throw SquirrelError(v, "Couldn't register function 'get_ambient_blue'"); } - // Register class Candle - sq_pushstring(v, "Candle", -1); + sq_pushstring(v, "set_gravity", -1); + sq_newclosure(v, &SSector_set_gravity_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_gravity'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'SSector'"); + } + + // Register class Text + sq_pushstring(v, "Text", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'Candle'"; + msg << "Couldn't create new class 'Text'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "get_burning", -1); - sq_newclosure(v, &Candle_get_burning_wrapper, 0); + sq_pushstring(v, "set_text", -1); + sq_newclosure(v, &Text_set_text_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_burning'"); + throw SquirrelError(v, "Couldn't register function 'set_text'"); } - sq_pushstring(v, "set_burning", -1); - sq_newclosure(v, &Candle_set_burning_wrapper, 0); + sq_pushstring(v, "set_font", -1); + sq_newclosure(v, &Text_set_font_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_burning'"); + throw SquirrelError(v, "Couldn't register function 'set_font'"); } + sq_pushstring(v, "fade_in", -1); + sq_newclosure(v, &Text_fade_in_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'Candle'"); + throw SquirrelError(v, "Couldn't register function 'fade_in'"); } - // Register class Wind - sq_pushstring(v, "Wind", -1); - if(sq_newclass(v, SQFalse) < 0) { - std::ostringstream msg; - msg << "Couldn't create new class 'Wind'"; - throw SquirrelError(v, msg.str()); - } - sq_pushstring(v, "start", -1); - sq_newclosure(v, &Wind_start_wrapper, 0); + sq_pushstring(v, "fade_out", -1); + sq_newclosure(v, &Text_fade_out_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'start'"); + throw SquirrelError(v, "Couldn't register function 'fade_out'"); } - sq_pushstring(v, "stop", -1); - sq_newclosure(v, &Wind_stop_wrapper, 0); + sq_pushstring(v, "set_visible", -1); + sq_newclosure(v, &Text_set_visible_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'stop'"); + throw SquirrelError(v, "Couldn't register function 'set_visible'"); } + sq_pushstring(v, "set_centered", -1); + sq_newclosure(v, &Text_set_centered_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tb"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'Wind'"); + throw SquirrelError(v, "Couldn't register function 'set_centered'"); } - // Register class AmbientSound - sq_pushstring(v, "AmbientSound", -1); - if(sq_newclass(v, SQFalse) < 0) { - std::ostringstream msg; - msg << "Couldn't create new class 'AmbientSound'"; - throw SquirrelError(v, msg.str()); - } sq_pushstring(v, "set_pos", -1); - sq_newclosure(v, &AmbientSound_set_pos_wrapper, 0); + sq_newclosure(v, &Text_set_pos_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'set_pos'"); } sq_pushstring(v, "get_pos_x", -1); - sq_newclosure(v, &AmbientSound_get_pos_x_wrapper, 0); + sq_newclosure(v, &Text_get_pos_x_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_x'"); } sq_pushstring(v, "get_pos_y", -1); - sq_newclosure(v, &AmbientSound_get_pos_y_wrapper, 0); + sq_newclosure(v, &Text_get_pos_y_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'get_pos_y'"); } + sq_pushstring(v, "set_anchor_point", -1); + sq_newclosure(v, &Text_set_anchor_point_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'AmbientSound'"); + throw SquirrelError(v, "Couldn't register function 'set_anchor_point'"); + } + + sq_pushstring(v, "get_anchor_point", -1); + sq_newclosure(v, &Text_get_anchor_point_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'get_anchor_point'"); + } + + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register class 'Text'"); } // Register class Thunderstorm @@ -4461,36 +5436,42 @@ void register_supertux_wrapper(HSQUIRRELVM v) } sq_pushstring(v, "start", -1); sq_newclosure(v, &Thunderstorm_start_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'start'"); } sq_pushstring(v, "stop", -1); sq_newclosure(v, &Thunderstorm_stop_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'stop'"); } sq_pushstring(v, "thunder", -1); sq_newclosure(v, &Thunderstorm_thunder_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'thunder'"); } sq_pushstring(v, "lightning", -1); sq_newclosure(v, &Thunderstorm_lightning_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'lightning'"); } sq_pushstring(v, "flash", -1); sq_newclosure(v, &Thunderstorm_flash_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'flash'"); } sq_pushstring(v, "electrify", -1); sq_newclosure(v, &Thunderstorm_electrify_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'electrify'"); } @@ -4508,96 +5489,116 @@ void register_supertux_wrapper(HSQUIRRELVM v) } sq_pushstring(v, "goto_node", -1); sq_newclosure(v, &TileMap_goto_node_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'goto_node'"); } sq_pushstring(v, "start_moving", -1); sq_newclosure(v, &TileMap_start_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'start_moving'"); } sq_pushstring(v, "stop_moving", -1); sq_newclosure(v, &TileMap_stop_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'stop_moving'"); } + sq_pushstring(v, "fade", -1); + sq_newclosure(v, &TileMap_fade_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tnn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'fade'"); + } + + sq_pushstring(v, "set_alpha", -1); + sq_newclosure(v, &TileMap_set_alpha_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|tn"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'set_alpha'"); + } + + sq_pushstring(v, "get_alpha", -1); + sq_newclosure(v, &TileMap_get_alpha_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); + if(SQ_FAILED(sq_createslot(v, -3))) { + throw SquirrelError(v, "Couldn't register function 'get_alpha'"); + } + if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register class 'TileMap'"); } - // Register class SSector - sq_pushstring(v, "SSector", -1); + // Register class WillOWisp + sq_pushstring(v, "WillOWisp", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'SSector'"; + msg << "Couldn't create new class 'WillOWisp'"; throw SquirrelError(v, msg.str()); } - sq_pushstring(v, "set_ambient_light", -1); - sq_newclosure(v, &SSector_set_ambient_light_wrapper, 0); + sq_pushstring(v, "goto_node", -1); + sq_newclosure(v, &WillOWisp_goto_node_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ti"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_ambient_light'"); + throw SquirrelError(v, "Couldn't register function 'goto_node'"); } - sq_pushstring(v, "get_ambient_red", -1); - sq_newclosure(v, &SSector_get_ambient_red_wrapper, 0); + sq_pushstring(v, "set_state", -1); + sq_newclosure(v, &WillOWisp_set_state_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|ts"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_ambient_red'"); + throw SquirrelError(v, "Couldn't register function 'set_state'"); } - sq_pushstring(v, "get_ambient_green", -1); - sq_newclosure(v, &SSector_get_ambient_green_wrapper, 0); + sq_pushstring(v, "start_moving", -1); + sq_newclosure(v, &WillOWisp_start_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_ambient_green'"); + throw SquirrelError(v, "Couldn't register function 'start_moving'"); } - sq_pushstring(v, "get_ambient_blue", -1); - sq_newclosure(v, &SSector_get_ambient_blue_wrapper, 0); + sq_pushstring(v, "stop_moving", -1); + sq_newclosure(v, &WillOWisp_stop_moving_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_ambient_blue'"); + throw SquirrelError(v, "Couldn't register function 'stop_moving'"); } if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'SSector'"); + throw SquirrelError(v, "Couldn't register class 'WillOWisp'"); } - // Register class LevelTime - sq_pushstring(v, "LevelTime", -1); + // Register class Wind + sq_pushstring(v, "Wind", -1); if(sq_newclass(v, SQFalse) < 0) { std::ostringstream msg; - msg << "Couldn't create new class 'LevelTime'"; + msg << "Couldn't create new class 'Wind'"; throw SquirrelError(v, msg.str()); } sq_pushstring(v, "start", -1); - sq_newclosure(v, &LevelTime_start_wrapper, 0); + sq_newclosure(v, &Wind_start_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'start'"); } sq_pushstring(v, "stop", -1); - sq_newclosure(v, &LevelTime_stop_wrapper, 0); + sq_newclosure(v, &Wind_stop_wrapper, 0); + sq_setparamscheck(v, SQ_MATCHTYPEMASKSTRING, "x|t"); if(SQ_FAILED(sq_createslot(v, -3))) { throw SquirrelError(v, "Couldn't register function 'stop'"); } - sq_pushstring(v, "get_time", -1); - sq_newclosure(v, &LevelTime_get_time_wrapper, 0); - if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'get_time'"); - } - - sq_pushstring(v, "set_time", -1); - sq_newclosure(v, &LevelTime_set_time_wrapper, 0); - if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register function 'set_time'"); - } - if(SQ_FAILED(sq_createslot(v, -3))) { - throw SquirrelError(v, "Couldn't register class 'LevelTime'"); + throw SquirrelError(v, "Couldn't register class 'Wind'"); } } -} // end of namespace Scripting +} // namespace scripting + +/* EOF */