X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fscripting%2Ffunctions.cpp;h=ecc2bf96da38d108b3610989b1a875b71f3c0457;hb=714a30abd887def6331a193216387e66cbfbd1bb;hp=874dfa651c2f22c75ab8d934bd1ecb1cb81c7c48;hpb=13c6f377301f91c8d79ab768ba97b5eb771ed624;p=supertux.git diff --git a/src/scripting/functions.cpp b/src/scripting/functions.cpp index 874dfa651..ecc2bf96d 100644 --- a/src/scripting/functions.cpp +++ b/src/scripting/functions.cpp @@ -45,6 +45,7 @@ #include "object/camera.hpp" #include "flip_level_transformer.hpp" #include "audio/sound_manager.hpp" +#include "random_generator.hpp" #include "squirrel_error.hpp" #include "squirrel_util.hpp" @@ -53,7 +54,7 @@ namespace Scripting { -int display(HSQUIRRELVM vm) +SQInteger display(HSQUIRRELVM vm) { Console::output << squirrel2string(vm, -1) << std::endl; return 0; @@ -64,7 +65,7 @@ void print_stacktrace(HSQUIRRELVM vm) print_squirrel_stack(vm); } -int get_current_thread(HSQUIRRELVM vm) +SQInteger get_current_thread(HSQUIRRELVM vm) { sq_pushobject(vm, vm_to_object(vm)); return 1; @@ -130,11 +131,11 @@ static SQInteger squirrel_read_char(SQUserPointer file) void import(HSQUIRRELVM vm, const std::string& filename) { IFileStream in(filename); - + if(SQ_FAILED(sq_compile(vm, squirrel_read_char, &in, filename.c_str(), SQTrue))) throw SquirrelError(vm, "Couldn't parse script"); - + sq_pushroottable(vm); if(SQ_FAILED(sq_call(vm, 1, SQFalse, SQTrue))) { sq_pop(vm, 1); @@ -148,7 +149,7 @@ void debug_collrects(bool enable) Sector::show_collrects = enable; } -void debug_draw_fps(bool enable) +void debug_show_fps(bool enable) { config->show_fps = enable; } @@ -161,7 +162,7 @@ void debug_draw_solids_only(bool enable) void save_state() { using namespace WorldMapNS; - + if(World::current() == NULL) throw std::runtime_error("Can't save state without active World"); @@ -202,7 +203,7 @@ void grease() { if (!validate_sector_player()) return; ::Player* tux = Sector::current()->player; // Scripting::Player != ::Player - tux->physic.set_velocity_x(tux->physic.get_velocity_x()*3); + tux->physic.vx = tux->physic.vx*3; } void invincible() @@ -212,25 +213,19 @@ void invincible() tux->invincible_timer.start(10000); } -void mortal() -{ - if (!validate_sector_player()) return; - ::Player* tux = Sector::current()->player; - tux->invincible_timer.stop(); -} - -void shrink() +void ghost() { if (!validate_sector_player()) return; ::Player* tux = Sector::current()->player; - tux->kill(tux->SHRINK); + tux->set_ghost_mode(true); } -void kill() +void mortal() { if (!validate_sector_player()) return; ::Player* tux = Sector::current()->player; - tux->kill(tux->KILL); + tux->invincible_timer.stop(); + tux->set_ghost_mode(false); } void restart() @@ -255,7 +250,7 @@ void gotoend() if (!validate_sector_player()) return; ::Player* tux = Sector::current()->player; tux->move(Vector( - (Sector::current()->solids->get_width()*32) - (SCREEN_WIDTH*2), 0)); + (Sector::current()->get_width()) - (SCREEN_WIDTH*2), 0)); Sector::current()->camera->reset( Vector(tux->get_pos().x, tux->get_pos().y)); } @@ -271,5 +266,9 @@ void quit() main_loop->quit(); } +int rand() +{ + return systemRandom.rand(); } +}