- reader.read_int("width", &plevel->width);
- reader.read_int("time", &plevel->time_left);
- reader.read_int("bkgd_red", &plevel->bkgd_red);
- reader.read_int("bkgd_green", &plevel->bkgd_green);
- reader.read_int("bkgd_blue", &plevel->bkgd_blue);
- reader.read_float("gravity", &plevel->gravity);
- reader.read_string("name", &plevel->name);
- reader.read_string("theme", &plevel->theme);
- reader.read_string("music", &plevel->song_title);
- reader.read_string("background", &plevel->bkgd_image);
- reader.read_string("particle_system", &plevel->particle_system);
- reader.read_int_vector("background-tm", &bg_tm);
- reader.read_int_vector("interactive-tm", &ia_tm);
- reader.read_int_vector("dynamic-tm", &dn_tm);
- reader.read_int_vector("foreground-tm", &fg_tm);
-
- // Convert old levels to the new tile numbers
- if (version == 0)
- {
- int transtable[256];
- transtable[(int)'.'] = 0;
- transtable[(int)'0'] = 0;
- transtable[(int)'1'] = 1;
- transtable[(int)'2'] = 2;
- transtable[(int)'x'] = 77;
- transtable[(int)'X'] = 77;
- transtable[(int)'y'] = 78;
- transtable[(int)'Y'] = 78;
- transtable[(int)'A'] = 83;
- transtable[(int)'B'] = 102;
- transtable[(int)'!'] = 103;
- transtable[(int)'a'] = 84;
- transtable[(int)'C'] = 85;
- transtable[(int)'D'] = 86;
- transtable[(int)'E'] = 87;
- transtable[(int)'F'] = 88;
- transtable[(int)'c'] = 89;
- transtable[(int)'d'] = 90;
- transtable[(int)'e'] = 91;
- transtable[(int)'f'] = 92;
-
- transtable[(int)'G'] = 93;
- transtable[(int)'H'] = 94;
- transtable[(int)'I'] = 95;
- transtable[(int)'J'] = 96;
-
- transtable[(int)'g'] = 97;
- transtable[(int)'h'] = 98;
- transtable[(int)'i'] = 99;
- transtable[(int)'j'] = 100
-;
- transtable[(int)'#'] = 11;
- transtable[(int)'['] = 13;
- transtable[(int)'='] = 14;
- transtable[(int)']'] = 15;
- transtable[(int)'$'] = 82;
- transtable[(int)'^'] = 76;
- transtable[(int)'*'] = 80;
- transtable[(int)'|'] = 79;
- transtable[(int)'\\'] = 81;
- transtable[(int)'&'] = 75;
-
- for(std::vector<int>::iterator i = ia_tm.begin(); i != ia_tm.end(); ++i)
- if (*i < 256)
- *i = transtable[*i];
- else
- puts("Error: Value to high, conversion will fail");
- }
- }
-
- for(int i = 0; i < 15; ++i)
- {
- plevel->dn_tiles[i] = (unsigned int*) calloc((plevel->width +1) , sizeof(unsigned int) );
- plevel->ia_tiles[i] = (unsigned int*) calloc((plevel->width +1) , sizeof(unsigned int) );
- plevel->bg_tiles[i] = (unsigned int*) calloc((plevel->width +1) , sizeof(unsigned int) );
- plevel->fg_tiles[i] = (unsigned int*) calloc((plevel->width +1) , sizeof(unsigned int) );
- }
-
- int i = 0;
- int j = 0;
- for(vector<int>::iterator it = ia_tm.begin(); it != ia_tm.end(); ++it, ++i)
- {
- plevel->ia_tiles[j][i] = (*it);
- if(i == plevel->width - 1)
- {
- i = -1;
- ++j;
- }
- }
-
- i = j = 0;
- for(vector<int>::iterator it = dn_tm.begin(); it != dn_tm.end(); ++it, ++i)
- {
-
- plevel->dn_tiles[j][i] = (*it);
- if(i == plevel->width - 1)
- {
- i = -1;
- ++j;
- }
- }
-
- i = j = 0;
- for(vector<int>::iterator it = bg_tm.begin(); it != bg_tm.end(); ++it, ++i)
- {
-
- plevel->bg_tiles[j][i] = (*it);
- if(i == plevel->width - 1)
- {
- i = -1;
- ++j;
- }
- }
-
- i = j = 0;
- for(vector<int>::iterator it = fg_tm.begin(); it != fg_tm.end(); ++it, ++i)
- {
-
- plevel->fg_tiles[j][i] = (*it);
- if(i == plevel->width - 1)
- {
- i = -1;
- ++j;
- }
+ if(!reader.read_int("width", &width))
+ st_abort("No width specified for level.", "");
+ if (!reader.read_float("start_pos_x", &start_pos.x)) start_pos.x = 100;
+ if (!reader.read_float("start_pos_y", &start_pos.y)) start_pos.y = 170;
+ time_left = 500;
+ if(!reader.read_int("time", &time_left)) {
+ printf("Warning: no time specified for level.\n");
+ }
+
+ height = 15;
+ if(!reader.read_int("height", &height)) {
+ printf("Warning: no height specified for level.\n");
+ }
+
+ bkgd_speed = 50;
+ reader.read_int("bkgd_speed", &bkgd_speed);
+
+ bkgd_top.red = bkgd_top.green = bkgd_top.blue = 0;
+ reader.read_int("bkgd_red_top", &bkgd_top.red);
+ reader.read_int("bkgd_green_top", &bkgd_top.green);
+ reader.read_int("bkgd_blue_top", &bkgd_top.blue);
+
+ bkgd_bottom.red = bkgd_bottom.green = bkgd_bottom.blue = 0;
+ reader.read_int("bkgd_red_bottom", &bkgd_bottom.red);
+ reader.read_int("bkgd_green_bottom", &bkgd_bottom.green);
+ reader.read_int("bkgd_blue_bottom", &bkgd_bottom.blue);
+
+ gravity = 10;
+ reader.read_float("gravity", &gravity);
+ name = "Noname";
+ reader.read_string("name", &name);
+ author = "unknown author";
+ reader.read_string("author", &author);
+ song_title = "";
+ reader.read_string("music", &song_title);
+ bkgd_image = "";
+ reader.read_string("background", &bkgd_image);
+ particle_system = "";
+ reader.read_string("particle_system", &particle_system);
+
+ reader.read_int_vector("background-tm", &bg_tiles);
+ if(int(bg_tiles.size()) != width * height)
+ st_abort("Wrong size of backgroundtilemap", "");
+
+ if (!reader.read_int_vector("interactive-tm", &ia_tiles))
+ reader.read_int_vector("tilemap", &ia_tiles);
+ if(int(ia_tiles.size()) != width * height)
+ st_abort("Wrong size of interactivetilemap", "");
+
+ reader.read_int_vector("foreground-tm", &fg_tiles);
+ if(int(fg_tiles.size()) != width * height)
+ st_abort("Wrong size of foregroundtilemap", "");
+
+ { // Read ResetPoints
+ lisp_object_t* cur = 0;
+ if (reader.read_lisp("reset-points", &cur))
+ {
+ while (!lisp_nil_p(cur))
+ {
+ lisp_object_t* data = lisp_car(cur);
+
+ ResetPoint pos;
+
+ LispReader reader(lisp_cdr(data));
+ if (reader.read_int("x", &pos.x)
+ && reader.read_int("y", &pos.y))
+ {
+ reset_points.push_back(pos);
+ }
+
+ cur = lisp_cdr(cur);
+ }
+ }
+ }
+
+ { // Read Objects
+ lisp_object_t* cur = 0;
+ if (reader.read_lisp("objects", &cur))
+ {
+ if(world)
+ world->parse_objects(cur);
+ }
+ }
+
+ { // Read Camera
+ lisp_object_t* cur = 0;
+ if (reader.read_lisp("camera", &cur))
+ {
+ LispReader reader(cur);
+ if(world) {
+ world->camera->read(reader);
+ }
+ }
+ }