}
#include <boost/spirit/include/qi_symbols.hpp>
+#include <boost/algorithm/string/trim.hpp>
#include <algorithm>
#include <fstream>
#include <vector>
enum {
- LEVEL_LINE_COUNT = 13
+ LEVEL_LINE_COUNT = 14
};
+#define PATH_PREFIX "../badge/jumpnrun/levels/"
+
namespace jnrcpp {
struct descriptors {
descriptors() {
("tube_right" , JUMPNRUN_TILE_TYPE_TUBE_RIGHT )
("brick" , JUMPNRUN_TILE_TYPE_BRICK )
("square" , JUMPNRUN_TILE_TYPE_SQUARE )
+ ("spike_up" , JUMPNRUN_TILE_TYPE_SPIKE_UP )
+ ("spike_right" , JUMPNRUN_TILE_TYPE_SPIKE_RIGHT )
+ ("spike_down" , JUMPNRUN_TILE_TYPE_SPIKE_DOWN )
+ ("spike_left" , JUMPNRUN_TILE_TYPE_SPIKE_LEFT )
;
items.add
- ("doc", JUMPNRUN_ITEM_TYPE_DOCUMENT)
+ ("doc" , JUMPNRUN_ITEM_TYPE_DOCUMENT )
+ ("checkpoint" , JUMPNRUN_ITEM_TYPE_CHECKPOINT )
+ ("key" , JUMPNRUN_ITEM_TYPE_KEY )
+ ("doc_encrypted", JUMPNRUN_ITEM_TYPE_ENCRYPTED_DOCUMENT)
;
enemies.add
- ("cat" , JUMPNRUN_ENEMY_TYPE_CAT )
- ("mushroom" , JUMPNRUN_ENEMY_TYPE_MUSHROOM )
- ("kaninchen", JUMPNRUN_ENEMY_TYPE_KANINCHEN)
+ ("cat" , JUMPNRUN_ENEMY_TYPE_CAT )
+ ("mushroom" , JUMPNRUN_ENEMY_TYPE_MUSHROOM )
+ ("bunny" , JUMPNRUN_ENEMY_TYPE_BUNNY )
+ ("kaninchen" , JUMPNRUN_ENEMY_TYPE_BUNNY ) // legacy
+ ("snake" , JUMPNRUN_ENEMY_TYPE_SNAKE )
+ ("spiral" , JUMPNRUN_ENEMY_TYPE_SPIRAL )
+ ("rotor" , JUMPNRUN_ENEMY_TYPE_ROTOR )
+ ("dog" , JUMPNRUN_ENEMY_TYPE_DOG )
+ ("giraffe" , JUMPNRUN_ENEMY_TYPE_GIRAFFE )
+ ("bird" , JUMPNRUN_ENEMY_TYPE_BIRD )
+ ("bird_straight", JUMPNRUN_ENEMY_TYPE_BIRD_STRAIGHT)
+ ("bird_dip" , JUMPNRUN_ENEMY_TYPE_BIRD_DIP )
;
}
struct level_name_map {
level_name_map() {
- std::ifstream in("jumpnrun/levels.txt");
+ std::ifstream in(PATH_PREFIX "levels.txt");
if(!in) {
- throw std::logic_error("jumpnrun/levels.txt konnte nicht geöffnet werden.");
+ throw std::logic_error(PATH_PREFIX "levels.txt konnte nicht geöffnet werden.");
}
std::string name;
while(std::getline(in, name)) {
- if(name != "") {
+ if(boost::trim_copy(name) != "") {
names.push_back(name);
}
}
: name(name),
level_lines(LEVEL_LINE_COUNT)
{
- std::ifstream in(("jumpnrun/" + name + ".lv").c_str());
+ std::ifstream in((PATH_PREFIX + name + ".lv").c_str());
if(!in) {
throw std::invalid_argument("Could not open file: " + name + ".lv");
objmap = &item_types;
} else if(line == "[enemies]") {
objmap = &enemy_types;
+ } else if(line == "[parameters]") {
+ objmap = &level_params;
} else {
throw std::invalid_argument("Unkown type: " + line);
}
- } else if(line != "") {
+ } else if(boost::trim_right_copy(line) != "") {
char c;
std::string tok;
std::istringstream parser(line);
static_cast<uint16_t>(player_pos.second)
};
- dest.write(static_cast<char const *>(static_cast<void const *>(head)), sizeof(head));
- dest.write(static_cast<char const *>(static_cast<void const *>(spos)), sizeof(spos));
+ uint8_t lives = 3;
+ {
+ std::map<char, std::string>::const_iterator iter = level_params.find('L');
+ if(iter != level_params.end()) {
+ unsigned x;
+ std::istringstream parser(iter->second);
+ if(parser >> x) {
+ lives = static_cast<uint8_t>(x);
+ }
+ }
+ }
+
+ dest.write(static_cast<char const *>(static_cast<void const *>(head )), sizeof(head ));
+ dest.write(static_cast<char const *>(static_cast<void const *>(spos )), sizeof(spos ));
+ dest.write(static_cast<char const *>(static_cast<void const *>(&lives)), sizeof(lives));
dump_tiles(dest);
dump_items(dest);
std::map<char, std::string> tile_types;
std::map<char, std::string> item_types;
std::map<char, std::string> enemy_types;
+ std::map<char, std::string> level_params;
};
}
void jumpnrun_level_dump(size_t level) {
std::string name = jnrcpp::level_names.names[level];
jnrcpp::level lv(name);
- std::ofstream out(("jumpnrun/" + name + ".lvl").c_str());
+ std::ofstream out((PATH_PREFIX + name + ".lvl").c_str());
lv.dump(out);
}