X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=newdungeon.py;h=873990c46d10996c74c5665929f860333caf1de0;hb=6bd1c356e2b358d855d0e70c53fee0fec385a48d;hp=52380e6705c55a5774c15055c5d079eca892f084;hpb=c3a71f6db6781e40a9e75bb1107c901d791aab04;p=open-adventure.git diff --git a/newdungeon.py b/newdungeon.py index 52380e6..873990c 100755 --- a/newdungeon.py +++ b/newdungeon.py @@ -9,8 +9,13 @@ h_name = "newdb.h" c_name = "newdb.c" h_template = """/* Generated from adventure.yaml - do not hand-hack! */ +#ifndef NEWDB_H +#define NEWDB_H #include +#include + +#define SILENT -1 /* no sound */ typedef struct {{ const char* inventory; @@ -24,6 +29,8 @@ typedef struct {{ typedef struct {{ descriptions_t description; + const long sound; + const bool loud; }} location_t; typedef struct {{ @@ -57,10 +64,12 @@ extern const class_t classes[]; extern turn_threshold_t turn_thresholds[]; extern obituary_t obituaries[]; extern hint_t hints[]; +extern long conditions[]; extern const size_t CLSSES; extern const int maximum_deaths; extern const int turn_threshold_count; +#define HINT_COUNT {} enum arbitrary_messages_refs {{ {} @@ -74,11 +83,12 @@ enum object_descriptions_refs {{ {} }}; -/* end */ +#endif /* end NEWDB_H */ """ c_template = """/* Generated from adventure.yaml - do not hand-hack! */ +#include "common.h" #include "{}" const char* arbitrary_messages[] = {{ @@ -109,6 +119,10 @@ hint_t hints[] = {{ {} }}; +long conditions[] = {{ +{} +}}; + const size_t CLSSES = {}; const int maximum_deaths = {}; const int turn_threshold_count = {}; @@ -180,13 +194,17 @@ def get_locations(loc): .small = {}, .big = {}, }}, + .sound = {}, + .loud = {}, }}, """ loc_str = "" for item in loc: short_d = make_c_string(item[1]["description"]["short"]) long_d = make_c_string(item[1]["description"]["long"]) - loc_str += template.format(short_d, long_d) + sound = item[1].get("sound", "SILENT") + loud = "true" if item[1].get("loud") else "false" + loc_str += template.format(short_d, long_d, sound, loud) loc_str = loc_str[:-1] # trim trailing newline return loc_str @@ -237,7 +255,8 @@ def get_hints(hnt, arb): """ hnt_str = "" md = dict(arb) - for item in hnt: + for member in hnt: + item = member["hint"] number = item["number"] penalty = item["penalty"] turns = item["turns"] @@ -247,12 +266,32 @@ def get_hints(hnt, arb): hnt_str = hnt_str[:-1] # trim trailing newline return hnt_str +def get_condbits(locations): + cnd_str = "" + for (name, loc) in locations: + conditions = loc["conditions"] + hints = loc.get("hints") or [] + flaglist = [] + for flag in conditions: + if conditions[flag]: + flaglist.append(flag) + line = "|".join([("(1<