X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Fscripted_object.hpp;h=e7d6f9dbffcb30843c506780af4c74ec27d98d9f;hb=657fc40723665c04b3150946f5bd66b6b0af9230;hp=e1bc6663fffd1447a647d825f64a701b00796dd9;hpb=1ff837fd2c166214bfec2b573424ddfc03cce8c1;p=supertux.git diff --git a/src/object/scripted_object.hpp b/src/object/scripted_object.hpp index e1bc6663f..e7d6f9dbf 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 z_pos; Vector new_vel; - Physic physic; - Sprite* sprite; }; #endif -