From 3e0b61dfec2261beabdfc7839505e03eb060da2d Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Fri, 11 Mar 2016 11:31:39 +0100
Subject: [PATCH] TCE: Use wetness map separate from terrain map.

---
 plugins/client/TheCrawlingEater.py | 104 +++++++-----------
 plugins/server/TheCrawlingEater.py | 164 ++++++++++++-----------------
 2 files changed, 105 insertions(+), 163 deletions(-)

diff --git a/plugins/client/TheCrawlingEater.py b/plugins/client/TheCrawlingEater.py
index 796f08c..081960a 100644
--- a/plugins/client/TheCrawlingEater.py
+++ b/plugins/client/TheCrawlingEater.py
@@ -93,20 +93,8 @@ def win_map(self):
                 attribute = col_mem
                 if char == " ":
                     attribute = col_unknown
-                elif char in "%#XABCDEFGHI":
+                elif char in "%#X":
                     attribute = col_mem_obstacle
-                    if char in "ADG":
-                        char = "%"
-                    elif char in "BEH":
-                        char = "#"
-                    elif char in "CFI":
-                        char = "X"
-                elif char in "LO":
-                    char = "~"
-                elif char in "JMP":
-                    char = "."
-                elif char in "KNQ":
-                    char = ":"
                 bonus = (" ", attribute)
                 winmap += [(char, attribute), bonus]
             else:
@@ -115,68 +103,52 @@ def win_map(self):
                 if char == "_":
                     attribute = col_ground
                 elif char == "~":
-                    attribute = col_ground_wet
-                elif char == "L":
-                    char = "~"
-                    attribute = col_ground_wetter
-                elif char == "O":
-                    char = "~"
-                    attribute = col_ground_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_ground_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_ground_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_ground_wettest
                 if char == ".":
                     attribute = col_dirt
-                if char == "J":
-                    char = "."
-                    attribute = col_dirt_wet
-                if char == "M":
-                    char = "."
-                    attribute = col_dirt_wetter
-                if char == "P":
-                    char = "."
-                    attribute = col_dirt_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_dirt_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_dirt_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_dirt_wettest
                 elif char == ":":
                     attribute = col_earth
-                elif char == "K":
-                    char = ":"
-                    attribute = col_earth_wet
-                elif char == "N":
-                    char = ":"
-                    attribute = col_earth_wetter
-                elif char == "Q":
-                    char = ":"
-                    attribute = col_earth_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_earth_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_earth_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_earth_wettest
                 elif char == "%":
                     attribute = col_wall_dirt
-                elif char == "A":
-                    char = "%"
-                    attribute = col_wall_dirt_wet
-                elif char == "D":
-                    char = "%"
-                    attribute = col_wall_dirt_wetter
-                elif char == "G":
-                    char = "%"
-                    attribute = col_wall_dirt_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_wall_dirt_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_wall_dirt_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_wall_dirt_wettest
                 elif char == "#":
                     attribute = col_wall_earth
-                elif char == "B":
-                    char = "#"
-                    attribute = col_wall_earth_wet
-                elif char == "E":
-                    char = "#"
-                    attribute = col_wall_earth_wetter
-                elif char == "H":
-                    char = "#"
-                    attribute = col_wall_earth_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_wall_earth_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_wall_earth_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_wall_earth_wettest
                 elif char == "X":
                     attribute = col_wall_stone
-                elif char == "C":
-                    char = "X"
-                    attribute = col_wall_stone_wet
-                elif char == "F":
-                    char = "X"
-                    attribute = col_wall_stone_wetter
-                elif char == "I":
-                    char = "X"
-                    attribute = col_wall_stone_wettest
+                    if world_data["wetmap"][pos] == "1":
+                        attribute = col_wall_stone_wet
+                    if world_data["wetmap"][pos] == "2":
+                        attribute = col_wall_stone_wetter
+                    if world_data["wetmap"][pos] == "3":
+                        attribute = col_wall_stone_wettest
                 elif char == "@":
                     attribute = col_player
                 winmap += [(char, attribute), bonus]
@@ -187,9 +159,11 @@ def win_map(self):
 from client.config.world_data import world_data
 world_data["bowel"] = 0
 world_data["bladder"] = 0
+world_data["wetmap"] = " " * (world_data["map_size"] ** 2)
 from client.config.io import io
 io["worldstate_read_order"] += [["bowel", "int"]]
 io["worldstate_read_order"] += [["bladder", "int"]]
+io["worldstate_read_order"] += [["wetmap", "map"]]
 from client.config.windows import windows_config
 from client.windows import win_log
 windows_config[:] = [
diff --git a/plugins/server/TheCrawlingEater.py b/plugins/server/TheCrawlingEater.py
index 6093311..7a63416 100644
--- a/plugins/server/TheCrawlingEater.py
+++ b/plugins/server/TheCrawlingEater.py
@@ -8,7 +8,7 @@ from server.config.world_data import world_db
 
 def play_drink():
     if action_exists("drink") and world_db["WORLD_ACTIVE"]:
-        if not chr(world_db["MAP"][world_db["Things"][0]["pos"]]) in "~LO":
+        if not chr(world_db["MAP"][world_db["Things"][0]["pos"]]) == "~":
             log("NOTHING to drink here.")
             return
         elif world_db["Things"][0]["T_BLADDER"] >= 32:
@@ -19,16 +19,12 @@ def play_drink():
 
 def actor_drink(t):
     pos = world_db["Things"][0]["pos"]
-    if chr(world_db["MAP"][pos]) in "~LO" and \
-            t["T_BLADDER"] < 32:
+    if chr(world_db["MAP"][pos]) == "~" and t["T_BLADDER"] < 32:
         log("You DRINK.")
         t["T_BLADDER"] += 1
-        if chr(world_db["MAP"][pos]) == "~":
+        world_db["wetmap"][pos] -= 1
+        if world_db["wetmap"][pos] == 48:
             world_db["MAP"][pos] = ord("_")
-        elif chr(world_db["MAP"][pos]) == "L":
-            world_db["MAP"][pos] = ord("~")
-        elif chr(world_db["MAP"][pos]) == "O":
-            world_db["MAP"][pos] = ord("L")
 
 
 def play_pee():
@@ -46,43 +42,10 @@ def actor_pee(t):
         log("You LOSE fluid.")
     t["T_BLADDER"] -= 1
     terrain = world_db["MAP"][t["pos"]]
+    world_db["wetmap"][t["pos"]] += 1
     if terrain == ord("_"):
         world_db["MAP"][t["pos"]] = ord("~")
-    elif terrain == ord("~"):
-        world_db["MAP"][t["pos"]] = ord("L")
-    elif terrain == ord("L"):
-        world_db["MAP"][t["pos"]] = ord("L") + 3
-    elif terrain == ord("."):
-        world_db["MAP"][t["pos"]] = ord("J")
-    elif terrain == ord("J"):
-        world_db["MAP"][t["pos"]] = ord("J") + 3
-    elif terrain == ord("J") + 3:
-        world_db["MAP"][t["pos"]] = ord("J") + 6
-    elif terrain == ord(":"):
-        world_db["MAP"][t["pos"]] = ord("K")
-    elif terrain == ord("K"):
-        world_db["MAP"][t["pos"]] = ord("K") + 3
-    elif terrain == ord("K") + 3:
-        world_db["MAP"][t["pos"]] = ord("K") + 6
-    elif terrain == ord("%"):
-        world_db["MAP"][t["pos"]] = ord("A")
-    elif terrain == ord("A"):
-        world_db["MAP"][t["pos"]] = ord("A") + 3
-    elif terrain == ord("A") + 3:
-        world_db["MAP"][t["pos"]] = ord("A") + 6
-    elif terrain == ord("#"):
-        world_db["MAP"][t["pos"]] = ord("B")
-    elif terrain == ord("B"):
-        world_db["MAP"][t["pos"]] = ord("B") + 3
-    elif terrain == ord("B") + 3:
-        world_db["MAP"][t["pos"]] = ord("B") + 6
-    elif terrain == ord("X"):
-        world_db["MAP"][t["pos"]] = ord("C")
-    elif terrain == ord("C"):
-        world_db["MAP"][t["pos"]] = ord("C") + 3
-    elif terrain == ord("C") + 3:
-        world_db["MAP"][t["pos"]] = ord("C") + 6
-    elif chr(terrain) in "GHIOPQ":
+    elif world_db["wetmap"][t["pos"]] > 51:
         t["T_LIFEPOINTS"] = 0
         if t == world_db["Things"][0]:
             t["fovmap"] = bytearray(b' ' * (world_db["MAP_LENGTH"] ** 2))
@@ -104,47 +67,17 @@ def actor_drop(t):
         log("You DROP waste.")
     terrain = world_db["MAP"][t["pos"]]
     t["T_BOWEL"] -= 1
-    if terrain == ord("_"):
+    if chr(terrain) in "_~":
         world_db["MAP"][t["pos"]] = ord(".")
-    elif terrain == ord("~"):
-        world_db["MAP"][t["pos"]] = ord("J")
-    elif terrain == ord("L") :
-        world_db["MAP"][t["pos"]] = ord("J") + 3
-    elif terrain == ord("L") + 3:
-        world_db["MAP"][t["pos"]] = ord("J") + 6
     elif terrain == ord("."):
         world_db["MAP"][t["pos"]] = ord(":")
-    elif terrain == ord("J"):
-        world_db["MAP"][t["pos"]] = ord("K")
-    elif terrain == ord("J") + 3:
-        world_db["MAP"][t["pos"]] = ord("K") + 3
-    elif terrain == ord("J") + 6:
-        world_db["MAP"][t["pos"]] = ord("K") + 6
     elif terrain == ord(":"):
         world_db["MAP"][t["pos"]] = ord("%")
-    elif terrain == ord("K"):
-        world_db["MAP"][t["pos"]] = ord("A")
-    elif terrain == ord("K") + 3:
-        world_db["MAP"][t["pos"]] = ord("A") + 3
-    elif terrain == ord("K") + 6:
-        world_db["MAP"][t["pos"]] = ord("A") + 6
     elif terrain == ord("%"):
         world_db["MAP"][t["pos"]] = ord("#")
-    elif terrain == ord("A"):
-        world_db["MAP"][t["pos"]] = ord("B")
-    elif terrain == ord("A") + 3:
-        world_db["MAP"][t["pos"]] = ord("B") + 3
-    elif terrain == ord("A") + 6:
-        world_db["MAP"][t["pos"]] = ord("B") + 6
     elif terrain == ord("#"):
         world_db["MAP"][t["pos"]] = ord("X")
-    elif terrain == ord("B"):
-        world_db["MAP"][t["pos"]] = ord("C")
-    elif terrain == ord("B") + 3:
-        world_db["MAP"][t["pos"]] = ord("C") + 3
-    elif terrain == ord("B") + 6:
-        world_db["MAP"][t["pos"]] = ord("C") + 6
-    elif chr(terrain) in "XCFI":
+    elif terrain == ord("X"):
         t["T_LIFEPOINTS"] = 0
         if t == world_db["Things"][0]:
             t["fovmap"] = bytearray(b' ' * (world_db["MAP_LENGTH"] ** 2))
@@ -164,7 +97,7 @@ def play_move(str_arg):
         move_result = mv_yx_in_dir_legal(chr(d), t["T_POSY"], t["T_POSX"])
         if 1 == move_result[0]:
             pos = (move_result[1] * world_db["MAP_LENGTH"]) + move_result[2]
-            if chr(world_db["MAP"][pos]) in "%#ABDEGH":
+            if chr(world_db["MAP"][pos]) in "%#":
                 if t["T_BOWEL"] >= 32:
                     if t == world_db["Things"][0]:
                         log("You're too FULL to eat.")
@@ -212,30 +145,17 @@ def actor_move(t):
         t["pos"] = move_result[1] * world_db["MAP_LENGTH"] + move_result[2]
         build_fov_map(t)
     else:
-        if t["T_BOWEL"] >= 32:
+        if t["T_BOWEL"] >= 32 or chr(world_db["MAP"][pos]) == "X":
             return
-        elif chr(world_db["MAP"][pos]) in "%ADG" and 0 == int(rand.next() % 2):
-            log("You EAT.")
-            if world_db["MAP"][pos] == ord("%"):
-                world_db["MAP"][pos] = ord("_")
-            elif world_db["MAP"][pos] == ord("A"):
-                world_db["MAP"][pos] = ord("~")
-            elif world_db["MAP"][pos] == ord("A") + 3:
-                world_db["MAP"][pos] = ord("L")
-            elif world_db["MAP"][pos] == ord("A") + 6:
-                world_db["MAP"][pos] = ord("L") + 3
+        elif chr(world_db["MAP"][pos]) == "%" and 0 == int(rand.next() % 2):
             t["T_BOWEL"] += 3
         elif chr(world_db["MAP"][pos]) in "#BEH" and 0 == int(rand.next() % 5):
-            log("You EAT.")
-            if world_db["MAP"][pos] == ord("#"):
-                world_db["MAP"][pos] = ord("_")
-            elif world_db["MAP"][pos] == ord("B"):
-                world_db["MAP"][pos] = ord("~")
-            elif world_db["MAP"][pos] == ord("B") + 3:
-                world_db["MAP"][pos] = ord("L")
-            elif world_db["MAP"][pos] == ord("B") + 6:
-                world_db["MAP"][pos] = ord("L") + 3
             t["T_BOWEL"] += 4
+        log("You EAT.")
+        if world_db["wetmap"][pos] == 48:
+            world_db["MAP"][pos] = ord("_")
+        else:
+            world_db["MAP"][pos] = ord("~")
         if t["T_BOWEL"] > 32:
             t["T_BOWEL"] = 32
 
@@ -268,8 +188,9 @@ def make_map():
         single_allowed = rand.next() % 32
         y, x, pos = new_pos()
         if "_" == chr(world_db["MAP"][pos]) \
-                and ((not single_allowed) or is_neighbor((y, x), "O")):
-            world_db["MAP"][pos] = ord("O")
+                and ((not single_allowed) or is_neighbor((y, x), "~")):
+            world_db["MAP"][pos] = ord("~")
+            world_db["wetmap"][pos] = 51
             i_water += 1
 
 
@@ -353,14 +274,60 @@ def play_wait():
         world_db["set_command"]("wait")
 
 
+def save_wetmap():
+    length = world_db["MAP_LENGTH"]
+    string = ""
+    for i in range(length):
+        line = world_db["wetmap"][i * length:(i * length) + length].decode()
+        string = string + "WETMAP" + " "  + str(i) + " " + line + "\n"
+    return string
+
+
+def wetmapset(str_int, mapline):
+    def valid_map_line(str_int, mapline):
+        from server.utils import integer_test
+        val = integer_test(str_int, 0, 255)
+        if None != val:
+            if val >= world_db["MAP_LENGTH"]:
+                print("Illegal value for map line number.")
+            elif len(mapline) != world_db["MAP_LENGTH"]:
+                print("Map line length is unequal map width.")
+            else:
+                return val
+        return None
+    val = valid_map_line(str_int, mapline)
+    if None != val:
+        length = world_db["MAP_LENGTH"]
+        if not world_db["wetmap"]:
+            m = bytearray(b' ' * (length ** 2))
+        else:
+            m = world_db["wetmap"]
+        m[val * length:(val * length) + length] = mapline.encode()
+        if not world_db["wetmap"]:
+            world_db["wetmap"] = m
+
+
+def write_wetmap():
+    from server.worldstate_write_helpers import write_map
+    length = world_db["MAP_LENGTH"]
+    visible_wetmap = bytearray(b' ' * (length ** 2))
+    for i in range(length ** 2):
+        if world_db["Things"][0]["fovmap"][i] == ord('v'):
+            visible_wetmap[i] = world_db["wetmap"][i]
+    return write_map(visible_wetmap, world_db["MAP_LENGTH"])
+
+
 from server.config.io import io_db
 io_db["worldstate_write_order"] += [["T_BOWEL", "player_int"]]
 io_db["worldstate_write_order"] += [["T_BLADDER", "player_int"]]
+io_db["worldstate_write_order"] += [[write_wetmap, "func"]]
 import server.config.world_data
 server.config.world_data.symbols_hide = "%#X" + "ABC" + "DEF" + "GHI"
 server.config.world_data.symbols_passable = "_.:" + "~JK" + "LMN" + "OPQ"
 server.config.world_data.thing_defaults["T_BOWEL"] = 0
 server.config.world_data.thing_defaults["T_BLADDER"] = 0
+world_db["wetmap"] = bytearray(b"0" * world_db["MAP_LENGTH"] ** 2)
+io_db["hook_save"] = save_wetmap
 import server.config.make_world_helpers
 server.config.make_world_helpers.make_map = make_map
 from server.config.commands import commands_db
@@ -375,6 +342,7 @@ commands_db["use"] = (1, False, lambda x: None)
 commands_db["pickup"] = (0, False, lambda: None)
 commands_db["T_BOWEL"] = (1, False, setter("Thing", "T_BOWEL", 0, 255))
 commands_db["T_BLADDER"] = (1, False, setter("Thing", "T_BLADDER", 0, 255))
+commands_db["WETMAP"] = (2, False, wetmapset)
 from server.actions import actor_wait
 import server.config.actions
 server.config.actions.action_db = {
-- 
2.30.2