X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fsprite.cpp;h=bb31251a8becf225554b29f1983bab43813eaa2e;hb=2ec1be264110139466ab70422b8f4fd9c22e5c8c;hp=434c7d5c9b9195d2b27482544386ec0604231b2c;hpb=7ca7b8e7d46020da41a192a7cd82f5cf5a36a9ef;p=supertux.git diff --git a/src/sprite.cpp b/src/sprite.cpp index 434c7d5c9..bb31251a8 100644 --- a/src/sprite.cpp +++ b/src/sprite.cpp @@ -21,6 +21,7 @@ #include #include "globals.h" #include "sprite.h" +#include "setup.h" Sprite::Sprite(lisp_object_t* cur) { @@ -28,22 +29,32 @@ Sprite::Sprite(lisp_object_t* cur) LispReader reader(cur); - reader.read_string("name", &name); + if(!reader.read_string("name", &name)) + st_abort("Sprite wihtout name", ""); reader.read_int("x-hotspot", &x_hotspot); reader.read_int("y-hotspot", &y_hotspot); reader.read_float("fps", &fps); + std::vector images; - reader.read_string_vector("images", &images); - surfaces.resize(images.size()); + if(!reader.read_string_vector("images", &images)) + st_abort("Sprite contains no images: ", name.c_str()); for(std::vector::size_type i = 0; i < images.size(); ++i) { - surfaces[i] = new Surface(datadir + "/images/" + images[i], USE_ALPHA); + surfaces.push_back( + new Surface(datadir + "/images/" + images[i], USE_ALPHA)); } frame_delay = 1000.0f/fps; } +Sprite::~Sprite() +{ + for(std::vector::iterator i = surfaces.begin(); i != surfaces.end(); + ++i) + delete *i; +} + void Sprite::init_defaults() {