X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=newdungeon.py;h=873990c46d10996c74c5665929f860333caf1de0;hb=6bd1c356e2b358d855d0e70c53fee0fec385a48d;hp=092c342e52038588bc08550cc985fb3bbca5e4d0;hpb=537c4511e2f3802421f79aed7b6af16d66adb518;p=open-adventure.git diff --git a/newdungeon.py b/newdungeon.py index 092c342..873990c 100755 --- a/newdungeon.py +++ b/newdungeon.py @@ -13,6 +13,9 @@ h_template = """/* Generated from adventure.yaml - do not hand-hack! */ #define NEWDB_H #include +#include + +#define SILENT -1 /* no sound */ typedef struct {{ const char* inventory; @@ -26,6 +29,8 @@ typedef struct {{ typedef struct {{ descriptions_t description; + const long sound; + const bool loud; }} location_t; typedef struct {{ @@ -59,7 +64,7 @@ extern const class_t classes[]; extern turn_threshold_t turn_thresholds[]; extern obituary_t obituaries[]; extern hint_t hints[]; -extern const long conditions[]; +extern long conditions[]; extern const size_t CLSSES; extern const int maximum_deaths; @@ -114,7 +119,7 @@ hint_t hints[] = {{ {} }}; -const long conditions[] = {{ +long conditions[] = {{ {} }}; @@ -189,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