X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftile.cpp;h=c45f79c9c9028222753bda25d51c66a5c397755c;hb=69f1f633dec2d8a8f1286cf072b6725c75eaeb6a;hp=c402cf4547e66e37601fe28af55cb2e4b62439cf;hpb=77d6c22146b06e5737b905795c8d7aab3f146527;p=supertux.git diff --git a/src/tile.cpp b/src/tile.cpp index c402cf454..c45f79c9c 100644 --- a/src/tile.cpp +++ b/src/tile.cpp @@ -20,8 +20,8 @@ // 02111-1307, USA. #include -#include -#include +#include +#include #include #include @@ -59,7 +59,7 @@ Tile::parse(const lisp::Lisp& reader) if(!reader.get("id", id)) { throw std::runtime_error("Missing tile-id."); } - + bool value = false; if(reader.get("solid", value) && value) attributes |= SOLID; @@ -73,6 +73,8 @@ Tile::parse(const lisp::Lisp& reader) attributes |= WATER; if(reader.get("hurts", value) && value) attributes |= HURTS; + if(reader.get("fire", value) && value) + attributes |= FIRE; if(reader.get("fullbox", value) && value) attributes |= FULLBOX; if(reader.get("coin", value) && value) @@ -86,10 +88,10 @@ Tile::parse(const lisp::Lisp& reader) data |= WORLDMAP_SOUTH; if(reader.get("west", value) && value) data |= WORLDMAP_WEST; - if(reader.get("east", value) && value) + if(reader.get("east", value) && value) data |= WORLDMAP_EAST; if(reader.get("stop", value) && value) - data |= WORLDMAP_STOP; + data |= WORLDMAP_STOP; reader.get("data", data); reader.get("anim-fps", anim_fps); @@ -97,7 +99,7 @@ Tile::parse(const lisp::Lisp& reader) if(reader.get("slope-type", data)) { attributes |= SOLID | SLOPE; } - + const lisp::Lisp* images = reader.get_lisp("images"); if(images) parse_images(*images); @@ -113,8 +115,9 @@ Tile::parse_images(const lisp::Lisp& images_lisp) std::string file; cur->get(file); imagespecs.push_back(ImageSpec(file, Rect(0, 0, 0, 0))); - } else if(cur->get_type() == lisp::Lisp::TYPE_CONS && - cur->get_car()->get_type() == lisp::Lisp::TYPE_SYMBOL) { + } else if(cur->get_type() == lisp::Lisp::TYPE_CONS && + cur->get_car()->get_type() == lisp::Lisp::TYPE_SYMBOL && + cur->get_car()->get_symbol() == "region") { const lisp::Lisp* ptr = cur->get_cdr(); std::string file; @@ -129,7 +132,7 @@ Tile::parse_images(const lisp::Lisp& images_lisp) log_warning << "Expected string or list in images tag" << std::endl; continue; } - + list = list->get_cdr(); } } @@ -166,4 +169,3 @@ Tile::draw(DrawingContext& context, const Vector& pos, int z_pos) const context.draw_surface(images[0], pos, z_pos); } } -