X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Fscripted_object.hpp;h=9ac72c56e67e4a911a420db87bb15a21cf9114b5;hb=4587bd9c8fc5cbb20f1e442de76bc06571ab56ba;hp=7935aa2c7e7606c863f5bd7df30b7ee72420ae32;hpb=07ddaed2a657e4d2a3d038fed223fc5827159caf;p=supertux.git diff --git a/src/object/scripted_object.hpp b/src/object/scripted_object.hpp index 7935aa2c7..9ac72c56e 100644 --- a/src/object/scripted_object.hpp +++ b/src/object/scripted_object.hpp @@ -22,24 +22,25 @@ #include #include "physic.hpp" -#include "sprite/sprite.hpp" #include "lisp/lisp.hpp" -#include "moving_object.hpp" +#include "object/moving_sprite.hpp" #include "script_interface.hpp" #include "scripting/scripted_object.hpp" -class ScriptedObject : public MovingObject, public Scripting::ScriptedObject, - public ScriptInterface +class ScriptedObject : public MovingSprite, public UsesPhysic, + public Scripting::ScriptedObject, public ScriptInterface { public: ScriptedObject(const lisp::Lisp& lisp); - virtual ~ScriptedObject(); + virtual ScriptedObject* clone() const { return new ScriptedObject(*this); } - virtual void expose(HSQUIRRELVM vm, int table_idx); - virtual void unexpose(HSQUIRRELVM vm, int table_idx); + virtual void expose(HSQUIRRELVM vm, SQInteger table_idx); + virtual void unexpose(HSQUIRRELVM vm, SQInteger table_idx); void update(float elapsed_time); void draw(DrawingContext& context); + + void collision_solid(const CollisionHit& hit); HitResponse collision(GameObject& other, const CollisionHit& hit); // --- Scripting Interface stuff --- @@ -56,6 +57,8 @@ public: float get_velocity_y(); void set_visible(bool visible); bool is_visible(); + void set_solid(bool solid); + bool is_solid(); std::string get_name(); @@ -65,11 +68,7 @@ private: bool physic_enabled; bool visible; bool new_vel_set; - int layer; Vector new_vel; - Physic physic; - Sprite* sprite; }; #endif -