X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fbadguy%2Fmrbomb.hpp;h=14f326decf0aedc9781663aac9121029b2746c06;hb=2ad3ecbc14b77d373c796ad04d6389489666cc01;hp=450d0d11f214ad8af518c1ed830a5b4e0d9247f6;hpb=a3316d68ca17966517c3f7bb0c0cb2b7e612fd0a;p=supertux.git diff --git a/src/badguy/mrbomb.hpp b/src/badguy/mrbomb.hpp index 450d0d11f..14f326dec 100644 --- a/src/badguy/mrbomb.hpp +++ b/src/badguy/mrbomb.hpp @@ -20,26 +20,36 @@ #ifndef __MRBOMB_H__ #define __MRBOMB_H__ -#include "badguy.hpp" +#include "walking_badguy.hpp" +#include "object/portable.hpp" -class MrBomb : public BadGuy +class MrBomb : public WalkingBadguy, public Portable { public: MrBomb(const lisp::Lisp& reader); MrBomb(const Vector& pos, Direction d); - void activate(); - void active_update(float elapsed_time); void write(lisp::Writer& writer); - void collision_solid(const CollisionHit& hit); - HitResponse collision_badguy(BadGuy& badguy, const CollisionHit& hit); void kill_fall(); + HitResponse collision(GameObject& object, const CollisionHit& hit); + HitResponse collision_player(Player& player, const CollisionHit& hit); + + void active_update(float elapsed_time); + + void grab(MovingObject& object, const Vector& pos, Direction dir); + void ungrab(MovingObject& object, Direction dir); + bool is_portable() const; + + void freeze(); + bool is_freezable() const; virtual MrBomb* clone() const { return new MrBomb(*this); } protected: - bool collision_squished(Player& player); + bool collision_squished(GameObject& object); + +private: + bool grabbed; }; #endif -