X-Git-Url: https://plomlompom.com/repos/berlin_corona.txt?a=blobdiff_plain;f=roguelike-server;h=7a61c81bec1fedbcf98476981dfbb65fe566089a;hb=53de46c74e6f3829828d29da82ee3c644c1a0980;hp=40bfcb84a6fbad44a1642f51b73cac02c7fa708f;hpb=288d17d90b02d8648f6629b814c9e6d699a371c1;p=plomrogue diff --git a/roguelike-server b/roguelike-server index 40bfcb8..7a61c81 100755 --- a/roguelike-server +++ b/roguelike-server @@ -308,21 +308,6 @@ def try_worldstate_update(): """Write worldstate file if io_db["worldstate_updateable"] is set.""" if io_db["worldstate_updateable"]: - def draw_visible_Things(map, run): - for id in world_db["Things"]: - type = world_db["Things"][id]["T_TYPE"] - consumable = world_db["ThingTypes"][type]["TT_TOOL"] == "food" - alive = world_db["ThingTypes"][type]["TT_LIFEPOINTS"] - if (0 == run and not consumable and not alive) \ - or (1 == run and consumable and not alive) \ - or (2 == run and alive): - y = world_db["Things"][id]["T_POSY"] - x = world_db["Things"][id]["T_POSX"] - fovflag = world_db["Things"][0]["fovmap"][(y * length) + x] - if 'v' == chr(fovflag): - c = world_db["ThingTypes"][type]["TT_SYMBOL"] - map[(y * length) + x] = ord(c) - def write_map(string, map): for i in range(length): line = map[i * length:(i * length) + length].decode() @@ -348,21 +333,79 @@ def try_worldstate_update(): str(world_db["Things"][0]["T_POSX"]) + "\n" + \ str(world_db["MAP_LENGTH"]) + "\n" length = world_db["MAP_LENGTH"] + fov = bytearray(b' ' * (length ** 2)) - for pos in range(length ** 2): - if 'v' == chr(world_db["Things"][0]["fovmap"][pos]): - fov[pos] = world_db["MAP"][pos] - for i in range(3): - draw_visible_Things(fov, i) + ord_v = ord("v") + for pos in [pos for pos in range(length ** 2) + if ord_v == world_db["Things"][0]["fovmap"][pos]]: + fov[pos] = world_db["MAP"][pos] + for id in [id for tid in reversed(sorted(list(world_db["ThingTypes"]))) + for id in world_db["Things"] + if not world_db["Things"][id]["carried"] + if world_db["Things"][id]["T_TYPE"] == tid + if world_db["Things"][0]["fovmap"][ + world_db["Things"][id]["T_POSY"] * length + + world_db["Things"][id]["T_POSX"]] == ord_v]: + type = world_db["Things"][id]["T_TYPE"] + c = ord(world_db["ThingTypes"][type]["TT_SYMBOL"]) + fov[world_db["Things"][id]["T_POSY"] * length + + world_db["Things"][id]["T_POSX"]] = c string = write_map(string, fov) + mem = world_db["Things"][0]["T_MEMMAP"][:] - for i in range(2): - for mt in world_db["Things"][0]["T_MEMTHING"]: - consumable = world_db["ThingTypes"][mt[0]]["TT_TOOL"] == "food" - if (i == 0 and not consumable) or (i == 1 and consumable): - c = world_db["ThingTypes"][mt[0]]["TT_SYMBOL"] - mem[(mt[1] * length) + mt[2]] = ord(c) + for mt in [mt for tid in reversed(sorted(list(world_db["ThingTypes"]))) + for mt in world_db["Things"][0]["T_MEMTHING"] + if mt[0] == tid]: + c = world_db["ThingTypes"][mt[0]]["TT_SYMBOL"] + mem[(mt[1] * length) + mt[2]] = ord(c) string = write_map(string, mem) + + metamapA = bytearray(b'0' * (length ** 2)) # # + for id in [id for id in world_db["Things"] # # + if not world_db["Things"][id]["carried"] # # + if world_db["Things"][id]["T_LIFEPOINTS"] # # + if world_db["Things"][0]["fovmap"][ # # + world_db["Things"][id]["T_POSY"] * length # # + + world_db["Things"][id]["T_POSX"]] == ord_v]: # # + pos = (world_db["Things"][id]["T_POSY"] * length # # + + world_db["Things"][id]["T_POSX"]) # # + if id == 0 or world_db["EMPATHY"]: # # + type = world_db["Things"][id]["T_TYPE"] # # + max_hp = world_db["ThingTypes"][type]["TT_LIFEPOINTS"] # # + third_of_hp = max_hp / 3 # # + hp = world_db["Things"][id]["T_LIFEPOINTS"] # # + add = 0 # # + if hp > 2 * third_of_hp: # # + add = 2 # # + elif hp > third_of_hp: # # + add = 1 # # + metamapA[pos] = ord('a') + add # # + else: # # + metamapA[pos] = ord('X') # # + for mt in world_db["Things"][0]["T_MEMTHING"]: # # + pos = mt[1] * length + mt[2] # # + if metamapA[pos] < ord('2'): # # + metamapA[pos] += 1 # # + string = write_map(string, metamapA) # # + + metamapB = bytearray(b' ' * (length ** 2)) # # + for id in [id for id in world_db["Things"] # # + if not world_db["Things"][id]["carried"] # # + if world_db["Things"][id]["T_LIFEPOINTS"] # # + if world_db["Things"][0]["fovmap"][ # # + world_db["Things"][id]["T_POSY"] * length # # + + world_db["Things"][id]["T_POSX"]] == ord_v]: # # + pos = (world_db["Things"][id]["T_POSY"] * length # # + + world_db["Things"][id]["T_POSX"]) # # + if id == 0 or world_db["EMPATHY"]: # # + action = world_db["Things"][id]["T_COMMAND"] # # + if 0 != action: # # + name = world_db["ThingActions"][action]["TA_NAME"] # # + else: # # + name = " " # # + metamapB[pos] = ord(name[0]) # # + string = write_map(string, metamapB) # # + atomic_write(io_db["path_worldstate"], string, delete=False) strong_write(io_db["file_out"], "WORLD_UPDATED\n") io_db["worldstate_updateable"] = False @@ -495,7 +538,7 @@ def make_map(): pos = (y * length) + x # # if (("." == chr(world_db["MAP"][pos] # # or ":" == chr(world_db["MAP"][pos])) - and not is_neighbor((y, x), 'X'))): # # + and not is_neighbor((y, x), "X"))): # # world_db["MAP"][pos] = ord("_") # # world_db["altar"] = (y, x) # # altar_placed = True # # @@ -530,8 +573,7 @@ def update_map_memory(t, age_map=True): for pos in [pos for pos in range(world_db["MAP_LENGTH"] ** 2) if ord_v == t["fovmap"][pos]]: t["T_MEMDEPTHMAP"][pos] = ord_0 - if ord_space == t["T_MEMMAP"][pos]: - t["T_MEMMAP"][pos] = world_db["MAP"][pos] + t["T_MEMMAP"][pos] = world_db["MAP"][pos] if age_map: age_some_memdepthmap_on_nonfov_cells() t["T_MEMTHING"] = [mt for mt in t["T_MEMTHING"] @@ -615,12 +657,13 @@ def log_help(): strong_write(io_db["file_out"], "LOG " + "Some objects can be used (such as: eaten) by 'u' if " + "they are in your inventory. " - + "Use 'UP'/'DOWN' to navigate the inventory.\n") + + "Use 'Up'/'Down' to navigate the inventory.\n") strong_write(io_db["file_out"], "LOG " + "Use 'l' to toggle 'look' mode (move an exploration cursor " + "instead of the player over the map).\n") + strong_write(io_db["file_out"], "LOG " + + "Use 'PgUp'/PgDn' to scroll the 'Things here' window.\n") strong_write(io_db["file_out"], "LOG See README file for more details.\n") - strong_write(io_db["file_out"], "LOG \n") def decrement_lifepoints(t): @@ -694,21 +737,54 @@ def enter_altar(): # # return strong_write(io_db["file_out"], "LOG YOU ENTER SACRED GROUND.\n") if world_db["FAVOR_STAGE"] == 0: - world_db["FAVOR_STAGE"] = 1 - strong_write(io_db["file_out"], "LOG The Island God speaks to you: " - + "\"I don't trust you. You intrude on the island's " - + "affairs. I think you're a nuisance at best, and a " - + "danger to my children at worst. I will give you a " - + "chance to lighten my mood, however: For a while now, " - + "I've been trying to spread the plant " - + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_NAME"] - + " (\"" - + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_SYMBOL"] - + "\"). I have not been very successful so far. Maybe " - + "you can make yourself useful there. I will count " - + "each further " - + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_NAME"] - + " that grows to your favor.\n") + world_db["FAVOR_STAGE"] = 1 + strong_write(io_db["file_out"], "LOG The Island God speaks to you: " + + "\"I don't trust you. You intrude on the island's " + + "affairs. I think you're a nuisance at best, and a " + + "danger to my children at worst. I will give you a " + + "chance to lighten my mood, however: For a while now, " + + "I've been trying to spread the plant " + + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_NAME"] + + " (\"" + + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_SYMBOL"] + + "\"). I have not been very successful so far. Maybe " + + "you can make yourself useful there. I will count " + + "each further " + + world_db["ThingTypes"][world_db["PLANT_0"]]["TT_NAME"] + + " that grows to your favor.\n") + elif world_db["FAVOR_STAGE"] == 1 and world_db["GOD_FAVOR"] >= 100: + world_db["FAVOR_STAGE"] = 2 + strong_write(io_db["file_out"], "LOG The Island God speaks to you: " + + "\"You could have done worse so far. Maybe you are not " + + "the worst to happen to this island since the metal " + + "birds threw the great lightning ball. Maybe you can " + + "help me spread another plant. It multiplies faster, " + + "and it is highly nutritious: " + + world_db["ThingTypes"][world_db["PLANT_1"]]["TT_NAME"] + + " (\"" + + world_db["ThingTypes"][world_db["PLANT_1"]]["TT_SYMBOL"] + + "\"). It is new. I give you the only example. Be very " + + "careful with it! I also give you another tool that " + + "might be helpful.\n") + id = id_setter(-1, "Things") + world_db["Things"][id] = new_Thing(world_db["PLANT_1"], + world_db["altar"]) + id = id_setter(-1, "Things") + world_db["Things"][id] = new_Thing(world_db["TOOL_0"], + world_db["altar"]) + elif world_db["FAVOR_STAGE"] == 2 and \ + 0 == len([id for id in world_db["Things"] + if world_db["Things"][id]["T_TYPE"] + == world_db["PLANT_1"]]): + strong_write(io_db["file_out"], "LOG The Island God speaks to you: " + + "\"I am greatly disappointed that you lost all " + + world_db["ThingTypes"][world_db["PLANT_1"]]["TT_NAME"] + + " this island had. Here is another one. It cost me " + + " great work. Be more careful this time.\n") + id = id_setter(-1, "Things") + world_db["Things"][id] = new_Thing(world_db["PLANT_1"], + world_db["altar"]) + add_gods_favor(-250) elif world_db["GOD_FAVOR"] > 9000: world_db["FAVOR_STAGE"] = 9001 strong_write(io_db["file_out"], "LOG The Island God speaks to you: " @@ -736,14 +812,12 @@ def actor_move(t): """If passable, move/collide(=attack) thing into T_ARGUMENT's direction.""" # 7DRL: Player wounding (worse: killing) others will lower God's favor. # 7DRL: Player entering the altar triggers enter_altar(). + # 7DRL: Player with axe chops down trees. passable = False move_result = mv_yx_in_dir_legal(chr(t["T_ARGUMENT"]), t["T_POSY"], t["T_POSX"]) if 1 == move_result[0]: pos = (move_result[1] * world_db["MAP_LENGTH"]) + move_result[2] - passable = ("." == chr(world_db["MAP"][pos]) or - ":" == chr(world_db["MAP"][pos]) or # # - "_" == chr(world_db["MAP"][pos])) # # hitted = [id for id in world_db["Things"] if world_db["Things"][id] != t if world_db["Things"][id]["T_LIFEPOINTS"] @@ -765,6 +839,46 @@ def actor_move(t): if test and t == world_db["Things"][0]: # # add_gods_favor(-test) # # return + if (ord("X") == world_db["MAP"][pos] # # + or ord("|") == world_db["MAP"][pos]): # # + carries_axe = False # # + for id in t["T_CARRIES"]: # # + type = world_db["Things"][id]["T_TYPE"] # # + if world_db["ThingTypes"][type]["TT_TOOL"] == "axe": # # + carries_axe = True # # + break # # + if carries_axe: # # + axe_name = world_db["ThingTypes"][type]["TT_NAME"] # # + if t == world_db["Things"][0]: # # + strong_write(io_db["file_out"], "LOG With your " # # + + axe_name # # + + ", you chop!\n") # # + if ord("X") == world_db["MAP"][pos]: # # + add_gods_favor(-1) # # + chop_power = world_db["ThingTypes"][type]["TT_TOOLPOWER"] + case_X = world_db["MAP"][pos] == ord("X") # # + if (chop_power > 0 # # + and ((case_X and # # + 0 == int(rand.next() / chop_power)) # # + or (not case_X and # # + 0 == int(rand.next() / (3 * chop_power))))): # # + if t == world_db["Things"][0]: # # + strong_write(io_db["file_out"], # # + "LOG You chop it down.\n") # # + if world_db["MAP"][pos] == ord("X"): # # + add_gods_favor(-10) # # + world_db["MAP"][pos] = ord(".") # # + i = 3 if case_X else 1 # # + for i in range(i): # # + id = id_setter(-1, "Things") # # + world_db["Things"][id] = \ + new_Thing(world_db["LUMBER"], # # + (move_result[1], move_result[2])) # # + build_fov_map(t) # # + return # # + passable = ("." == chr(world_db["MAP"][pos]) or + ":" == chr(world_db["MAP"][pos]) or # # + "_" == chr(world_db["MAP"][pos])) # # dir = [dir for dir in directions_db if directions_db[dir] == chr(t["T_ARGUMENT"])][0] if passable: @@ -784,8 +898,10 @@ def actor_move(t): def actor_pick_up(t): - """Make t pick up (topmost?) Thing from ground into inventory.""" - # Topmostness is actually not defined so far. Picks most nutritious Thing. + """Make t pick up (topmost?) Thing from ground into inventory. + + Define topmostness by how low the thing's type ID is. + """ # 7DRL: Non-player picking up player-dropped consumable -> GOD_FAVOR gain. used_slots = len(t["T_CARRIES"]) # # if used_slots < world_db["ThingTypes"][t["T_TYPE"]]["TT_STORAGE"]: # # @@ -794,23 +910,21 @@ def actor_pick_up(t): if world_db["Things"][id]["T_POSY"] == t["T_POSY"] if world_db["Things"][id]["T_POSX"] == t["T_POSX"]] if len(ids): - highest_id = ids[0] - nutritious = 0 - for id in ids: - type = world_db["Things"][id]["T_TYPE"] - if world_db["ThingTypes"][type]["TT_TOOL"] == "food" \ - and world_db["ThingTypes"][type]["TT_TOOLPOWER"] > nutritious: - nutritious = world_db["ThingTypes"][type]["TT_TOOLPOWER"] - highest_id = id - world_db["Things"][highest_id]["carried"] = True - type = world_db["Things"][highest_id]["T_TYPE"] # # + lowest_tid = -1 + for iid in ids: + tid = world_db["Things"][iid]["T_TYPE"] + if lowest_tid == -1 or tid < lowest_tid: + id = iid + lowest_tid = tid + world_db["Things"][id]["carried"] = True + type = world_db["Things"][id]["T_TYPE"] # # if (t != world_db["Things"][0] # # - and world_db["Things"][highest_id]["T_PLAYERDROP"] # # + and world_db["Things"][id]["T_PLAYERDROP"] # # and world_db["ThingTypes"][type]["TT_TOOL"] == "food"): # # score = world_db["ThingTypes"][type]["TT_TOOLPOWER"] / 32 # # add_gods_favor(score) # # - world_db["Things"][highest_id]["T_PLAYERDROP"] = 0 # # - t["T_CARRIES"].append(highest_id) + world_db["Things"][id]["T_PLAYERDROP"] = 0 # # + t["T_CARRIES"].append(id) if t == world_db["Things"][0]: strong_write(io_db["file_out"], "LOG You pick up an object.\n") elif t == world_db["Things"][0]: @@ -852,6 +966,53 @@ def actor_use(t): + "Island God laughs.\n") # # t["T_LIFEPOINTS"] = 1 # # decrement_lifepoints(t) # # + elif (world_db["ThingTypes"][type]["TT_TOOL"] == "axe" # # + and t == world_db["Things"][0]): # # + strong_write(io_db["file_out"], # # + "LOG To use this item for chopping, move " # # + "towards a tree while carrying it in " # # + "your inventory.\n") # # + elif (world_db["ThingTypes"][type]["TT_TOOL"] == "carpentry"): # # + pos = t["T_POSY"] * world_db["MAP_LENGTH"] + t["T_POSX"] + if (world_db["MAP"][pos] == ord("X") # # + or world_db["MAP"][pos] == ord("|")): # # + strong_write(io_db["file_out"], # # + "LOG Can't build when standing on barrier.\n") # # + return + for id in [id for id in world_db["Things"] + if not world_db["Things"][id] == t + if not world_db["Things"][id]["carried"] + if world_db["Things"][id]["T_POSY"] == t["T_POSY"] + if world_db["Things"][id]["T_POSX"] == t["T_POSX"]]: + strong_write(io_db["file_out"], + "LOG Can't build when standing objects.\n") # # + return + for id in t["T_CARRIES"]: # # + type_tool = world_db["Things"][id]["T_TYPE"] # # + if (world_db["ThingTypes"][type_tool]["TT_TOOL"] # # + == "carpentry"): # # + break # # + wood_id = None # # + for id in t["T_CARRIES"]: # # + type_material = world_db["Things"][id]["T_TYPE"] # # + if (world_db["ThingTypes"][type_material]["TT_TOOL"] # # + == "wood"): # # + wood_id = id # # + break # # + if wood_id != None: # # + t["T_CARRIES"].remove(wood_id) # # + del world_db["Things"][wood_id] # # + world_db["MAP"][pos] = ord("|") # # + strong_write(io_db["file_out"], "LOG With your " # # + + world_db["ThingTypes"][type_tool]["TT_NAME"] # # + + " you build a wooden barrier from your " # # + + world_db["ThingTypes"][type_material] # # + ["TT_NAME"] # # + + ".\n") # # + else: # # + strong_write(io_db["file_out"], "LOG You can't use a " # # + + world_db["ThingTypes"][type_tool]["TT_NAME"] # # + + " without some wood in your inventory.\n") # # elif world_db["ThingTypes"][type]["TT_TOOL"] == "food": t["T_CARRIES"].remove(id) del world_db["Things"][id] @@ -868,33 +1029,43 @@ def actor_use(t): def thingproliferation(t, prol_map): - """To chance of 1/TT_PROLIFERATE,create t offspring in open neighbor cell. + """To chance of 1/TT_PROLIFERATE, create t offspring in open neighbor cell. Naturally only works with TT_PROLIFERATE > 0. The neighbor cell must be be marked "." in prol_map. If there are several map cell candidates, one is selected randomly. """ # 7DRL: success increments God's mood - # 7DRL: Things proliferate only on ":" ground. + # 7DRL: Plants (no TT_LIFEPOINTS) proliferate only on ":" ground. prolscore = world_db["ThingTypes"][t["T_TYPE"]]["TT_PROLIFERATE"] if prolscore and (1 == prolscore or 1 == (rand.next() % prolscore)): candidates = [] for dir in [directions_db[key] for key in directions_db]: mv_result = mv_yx_in_dir_legal(dir, t["T_POSY"], t["T_POSX"]) - if mv_result[0] and ord(":") == prol_map[mv_result[1] # # + pos = mv_result[1] * world_db["MAP_LENGTH"] + mv_result[2] + if mv_result[0] and \ + (ord(":") == prol_map[pos] # # + or (world_db["ThingTypes"][t["T_TYPE"]]["TT_LIFEPOINTS"] # # + and ord(".") == prol_map[pos])): # if mv_result[0] and ord(".") == prol_map[mv_result[1] - * world_db["MAP_LENGTH"] - + mv_result[2]]: + # * world_db["MAP_LENGTH"] + # + mv_result[2]]: candidates.append((mv_result[1], mv_result[2])) if len(candidates): i = rand.next() % len(candidates) id = id_setter(-1, "Things") newT = new_Thing(t["T_TYPE"], (candidates[i][0], candidates[i][1])) world_db["Things"][id] = newT - world_db["GOD_MOOD"] += 1 # # + animacy = world_db["ThingTypes"][t["T_TYPE"]]["TT_LIFEPOINTS"] # # + if animacy: # # + world_db["GOD_MOOD"] += animacy # # + else: # # + world_db["GOD_MOOD"] += 1 # # if (world_db["FAVOR_STAGE"] > 0 # # - and t["T_TYPE"] == world_db["PLANT_0"]): - world_db["GOD_FAVOR"] += 5 + and t["T_TYPE"] == world_db["PLANT_0"]): # # + world_db["GOD_FAVOR"] += 5 # # + elif t["T_TYPE"] == world_db["PLANT_1"]: # # + world_db["GOD_FAVOR"] += 25 # # def try_healing(t): @@ -927,7 +1098,11 @@ def hunger(t): stomach = int(32767 / world_db["ThingTypes"][t["T_TYPE"]]["TT_LIFEPOINTS"]) if int(int(testbase / stomach) / ((rand.next() % stomach) + 1)): if t == world_db["Things"][0]: - strong_write(io_db["file_out"], "LOG You suffer from hunger.\n") + if t["T_SATIATION"] < 0: + strong_write(io_db["file_out"], "LOG You suffer from hunger.\n") + else: + strong_write(io_db["file_out"], + "LOG You suffer from over-eating.\n") decrement_lifepoints(t) @@ -1199,7 +1374,7 @@ def turn_over(): if not world_db["Things"][id]["carried"]]: y = world_db["Things"][id]["T_POSY"] x = world_db["Things"][id]["T_POSX"] - proliferable_map[y * world_db["MAP_LENGTH"] + x] = ord('X') + proliferable_map[y * world_db["MAP_LENGTH"] + x] = ord("X") for id in [id for id in world_db["Things"]]: # Only what's from start! if not id in world_db["Things"] or \ world_db["Things"][id]["carried"]: # May have been consumed or @@ -1299,6 +1474,7 @@ def command_quit(): def command_thingshere(str_y, str_x): """Write to out file list of Things known to player at coordinate y, x.""" + # 7DRL: terrain, too if world_db["WORLD_ACTIVE"]: y = integer_test(str_y, 0, 255) x = integer_test(str_x, 0, 255) @@ -1306,19 +1482,38 @@ def command_thingshere(str_y, str_x): if None != y and None != x and y < length and x < length: pos = (y * world_db["MAP_LENGTH"]) + x strong_write(io_db["file_out"], "THINGS_HERE START\n") + pos = y * world_db["MAP_LENGTH"] + x; # # if "v" == chr(world_db["Things"][0]["fovmap"][pos]): - for id in world_db["Things"]: - if y == world_db["Things"][id]["T_POSY"] \ - and x == world_db["Things"][id]["T_POSX"] \ - and not world_db["Things"][id]["carried"]: - type = world_db["Things"][id]["T_TYPE"] - name = world_db["ThingTypes"][type]["TT_NAME"] - strong_write(io_db["file_out"], name + "\n") + for id in [id for tid in sorted(list(world_db["ThingTypes"])) + for id in world_db["Things"] + if not world_db["Things"][id]["carried"] + if world_db["Things"][id]["T_TYPE"] == tid + if y == world_db["Things"][id]["T_POSY"] + if x == world_db["Things"][id]["T_POSX"]]: + type = world_db["Things"][id]["T_TYPE"] + name = world_db["ThingTypes"][type]["TT_NAME"] + strong_write(io_db["file_out"], name + "\n") else: - for mt in world_db["Things"][0]["T_MEMTHING"]: - if y == mt[1] and x == mt[2]: - name = world_db["ThingTypes"][mt[0]]["TT_NAME"] - strong_write(io_db["file_out"], name + "\n") + for mt in [mt for tid in sorted(list(world_db["ThingTypes"])) + for mt in world_db["Things"][0]["T_MEMTHING"] + if mt[0] == tid if y == mt[1] if x == mt[2]]: + name = world_db["ThingTypes"][mt[0]]["TT_NAME"] + strong_write(io_db["file_out"], name + "\n") + if world_db["Things"][0]["T_MEMMAP"][pos] == ord("~"): # # + name = "(terrain: SEA)" # # + elif world_db["Things"][0]["T_MEMMAP"][pos] == ord("."): # # + name = "(terrain: EARTH)" # # + elif world_db["Things"][0]["T_MEMMAP"][pos] == ord(":"): # # + name = "(terrain: SOIL)" # # + elif world_db["Things"][0]["T_MEMMAP"][pos] == ord("X"): # # + name = "(terrain: TREE)" # # + elif world_db["Things"][0]["T_MEMMAP"][pos] == ord("|"): # # + name = "(terrain: WALL)" # # + elif world_db["Things"][0]["T_MEMMAP"][pos] == ord("_"): # # + name = "(terrain: ALTAR)" # # + else: # # + name = "(?)" # # + strong_write(io_db["file_out"], name + "\n") # # strong_write(io_db["file_out"], "THINGS_HERE END\n") else: print("Ignoring: Invalid map coordinates.") @@ -1425,12 +1620,10 @@ def command_makeworld(seed_string): if not wait_action: print("Ignoring: No thing action with name 'wait' defined.") return - if not world_db["SLIPPERS"] in world_db["ThingTypes"]: # # - print("Ignoring: No valid SLIPPERS set.") # # - return # # - if not world_db["PLANT_0"] in world_db["ThingTypes"]: # # - print("Ignoring: No valid PLANT_0 set.") # # - return # # + for name in specials: # # + if world_db[name] not in world_db["ThingTypes"]: # # + print("Ignoring: No valid " + name + " set.") # # + return # # world_db["Things"] = {} make_map() world_db["WORLD_ACTIVE"] = 1 @@ -1471,8 +1664,7 @@ def command_worldactive(worldactive_string): map. On activation, rebuild all Things' FOVs, and the player's map memory. Also call log_help(). """ - # 7DRL: altar must be on map, and (valid) SLIPPERS and PLANT_0must be set - # for world activation. + # 7DRL: altar must be on map, and specials must be set for active world. val = integer_test(worldactive_string, 0, 1) if None != val: if 0 != world_db["WORLD_ACTIVE"]: @@ -1491,8 +1683,10 @@ def command_worldactive(worldactive_string): if 0 == Thing: player_exists = True break - valid_slippers = world_db["SLIPPERS"] in world_db["ThingTypes"] # # - valid_plant0 = world_db["PLANT_0"] in world_db["ThingTypes"] # # + specials_set = True # # + for name in specials: # # + if world_db[name] not in world_db["ThingTypes"]: # # + specials_set = False # # altar_found = False # # if world_db["MAP"]: # # pos = world_db["MAP"].find(b'_') # # @@ -1502,7 +1696,7 @@ def command_worldactive(worldactive_string): world_db["altar"] = (y, x) # # altar_found = True # # if wait_exists and player_exists and world_db["MAP"] \ - and altar_found and valid_slippers and valid_plant0: # # + and specials_set: # # for id in world_db["Things"]: if world_db["Things"][id]["T_LIFEPOINTS"]: build_fov_map(world_db["Things"][id]) @@ -1517,26 +1711,17 @@ def command_worldactive(worldactive_string): print("Ignoring: Not all conditions for world activation met.") -def command_slippers(str_int): # # - """Set SLIPPERS, but deactivate world if not in ThingTypes.""" - val = integer_test(str_int, 0) - if None != val: - world_db["SLIPPERS"] = val - if world_db["WORLD_ACTIVE"] and \ - world_db["SLIPPERS"] not in world_db["ThingTypes"]: - world_db["WORLD_ACTIVE"] = 0 - print("SLIPPERS matches no known ThingTypes, deactivating world.") - - -def command_plant0(str_int): # # - """Set PLANT_0, but deactivate world if not in ThingTypes.""" - val = integer_test(str_int, 0) - if None != val: - world_db["PLANT_0"] = val - if world_db["WORLD_ACTIVE"] and \ - world_db["PLANT_0"] not in world_db["ThingTypes"]: - world_db["WORLD_ACTIVE"] = 0 - print("PLANT_0 matches no known ThingTypes, deactivating world.") +def specialtypesetter(name): # # + """Setter world_db[name], deactivating world if set int no ThingType.""" + def helper(str_int): + val = integer_test(str_int, 0) + if None != val: + world_db[name] = val + if world_db["WORLD_ACTIVE"] \ + and world_db[name] not in world_db["ThingTypes"]: + world_db["WORLD_ACTIVE"] = 0 + print(name + " fits no known ThingType, deactivating world.") + return helper def test_for_id_maker(object, category): @@ -1819,8 +2004,12 @@ commands_db = { "WORLD_ACTIVE": (1, False, command_worldactive), "MAP": (2, False, setter_map("MAP")), "FAVOR_STAGE": (1, False, setter(None, "FAVOR_STAGE", 0, 65535)), # # - "SLIPPERS": (1, False, command_slippers), # # - "PLANT_0": (1, False, command_plant0), # # + "SLIPPERS": (1, False, specialtypesetter("SLIPPERS")), # # + "PLANT_0": (1, False, specialtypesetter("PLANT_0")), # # + "PLANT_1": (1, False, specialtypesetter("PLANT_1")), # # + "LUMBER": (1, False, specialtypesetter("LUMBER")), # # + "TOOL_0": (1, False, specialtypesetter("TOOL_0")), # # + "EMPATHY": (1, False, setter(None, "EMPATHY", 0, 1)), # # "TA_ID": (1, False, command_taid), "TA_EFFORT": (1, False, setter("ThingAction", "TA_EFFORT", 0, 255)), "TA_NAME": (1, False, command_taname), @@ -1872,11 +2061,19 @@ world_db = { "FAVOR_STAGE": 0, # # "SLIPPERS": 0, # # "PLANT_0": 0, # # + "PLANT_1": 0, # # + "LUMBER": 0, # # + "TOOL_0": 0, # # + "EMPATHY": 1, # # "ThingActions": {}, "ThingTypes": {}, "Things": {} } +# 7DRL-specific! +"""Special type settings.""" +specials = ["SLIPPERS", "PLANT_0", "PLANT_1", "LUMBER", "TOOL_0"] # # + """Mapping of direction names to internal direction chars.""" directions_db = {"east": "d", "south-east": "c", "south-west": "x", "west": "s", "north-west": "w", "north-east": "e"}