From 8ee1a43e70d13ca23e7dd6af808d32596171d480 Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Sat, 12 Mar 2016 01:05:32 +0100
Subject: [PATCH] TCE: Add stomach, kidney, death by hunger and dehydration.

---
 confserver/TheCrawlingEater        |   3 +
 plugins/client/TheCrawlingEater.py |  55 +++++++++-----
 plugins/server/TheCrawlingEater.py | 116 ++++++++++++++++++++---------
 3 files changed, 118 insertions(+), 56 deletions(-)

diff --git a/confserver/TheCrawlingEater b/confserver/TheCrawlingEater
index 81e10dc..ab27c59 100644
--- a/confserver/TheCrawlingEater
+++ b/confserver/TheCrawlingEater
@@ -18,6 +18,9 @@ TA_NAME drink
 TA_ID 5
 TA_NAME pee
 
+TA_ID 6
+TA_NAME eat
+
 TT_ID 0
 TT_START_NUMBER 1
 TT_LIFEPOINTS 1
diff --git a/plugins/client/TheCrawlingEater.py b/plugins/client/TheCrawlingEater.py
index e3e413f..1bcf7af 100644
--- a/plugins/client/TheCrawlingEater.py
+++ b/plugins/client/TheCrawlingEater.py
@@ -3,24 +3,21 @@
 # see the file NOTICE in the root directory of the PlomRogue source package.
 
 
-def win_bladder(self):
-    winmap = []
-    curses.init_pair(79, curses.COLOR_WHITE, curses.COLOR_BLUE)
-    for i in range(world_data["bladder"]):
-        winmap += [("~", curses.color_pair(79))]
-    winmap_size = [1, len(winmap)]
-    offset = [0, 0]
-    return offset, winmap_size, winmap
+curses.init_pair(77, curses.COLOR_WHITE, curses.COLOR_GREEN)
+curses.init_pair(78, curses.COLOR_BLACK, curses.COLOR_RED)
+curses.init_pair(79, curses.COLOR_WHITE, curses.COLOR_BLUE)
+curses.init_pair(80, curses.COLOR_BLACK, curses.COLOR_YELLOW)
 
 
-def win_bowel(self):
-    winmap = []
-    curses.init_pair(80, curses.COLOR_YELLOW, curses.COLOR_RED)
-    for i in range(world_data["bowel"]):
-        winmap += [("#", curses.color_pair(80))]
-    winmap_size = [1, len(winmap)]
-    offset = [0, 0]
-    return offset, winmap_size, winmap
+def win_bar_maker(color_number, symbol, title):
+    def win_bar(self):
+        winmap = []
+        for i in range(world_data[title]):
+            winmap += [(symbol, curses.color_pair(color_number))]
+        winmap_size = [1, len(winmap)]
+        offset = [0, 0]
+        return offset, winmap_size, winmap
+    return win_bar
 
 
 def win_map(self):
@@ -121,20 +118,38 @@ def win_map(self):
 
 
 from client.config.world_data import world_data
+world_data["kidney"] = 0
+world_data["stomach"] = 0
 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"] += [["stomach", "int"]]
+io["worldstate_read_order"] += [["kidney", "int"]]
 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[:] = [
-    {"config": [0, -34], "func": win_map, "title": "The Crawling Eater"},
-    {"config": [1, 33], "func": win_bowel, "title": "bowel"},
-    {"config": [1, 33], "func": win_bladder, "title": "bladder"},
-    {"config": [-4, 33], "func": win_log, "title": "log"}
+    {"config": [0, -34],
+     "func": win_map,
+      "title": "The Crawling Eater"},
+    {"config": [1, 33],
+     "func": win_bar_maker(77, "%", "stomach"),
+     "title": "stomach"},
+    {"config": [1, 33],
+     "func": win_bar_maker(78, "%", "bowel"),
+     "title": "bowel"},
+    {"config": [1, 33],
+     "func": win_bar_maker(79, "~", "kidney"),
+      "title": "kidney"},
+    {"config": [1, 33],
+     "func": win_bar_maker(80, "~", "bladder"),
+      "title": "bladder"},
+    {"config": [-8, 33],
+     "func": win_log,
+     "title": "log"}
 ]
 from client.window_management import set_windows
 set_windows()
diff --git a/plugins/server/TheCrawlingEater.py b/plugins/server/TheCrawlingEater.py
index 3bafef9..b1dc407 100644
--- a/plugins/server/TheCrawlingEater.py
+++ b/plugins/server/TheCrawlingEater.py
@@ -13,7 +13,7 @@ def play_drink():
                 and world_db["wetmap"][pos] > ord("0")):
             log("NOTHING to drink here.")
             return
-        elif world_db["Things"][0]["T_BLADDER"] >= 32:
+        elif world_db["Things"][0]["T_KIDNEY"] >= 32:
             log("You're too FULL to drink more.")
             return
         world_db["set_command"]("drink")
@@ -22,9 +22,9 @@ def play_drink():
 def actor_drink(t):
     pos = world_db["Things"][0]["pos"]
     if chr(world_db["MAP"][pos]) == "0" and \
-                world_db["wetmap"][pos] > ord("0") and t["T_BLADDER"] < 32:
+                world_db["wetmap"][pos] > ord("0") and t["T_KIDNEY"] < 32:
         log("You DRINK.")
-        t["T_BLADDER"] += 1
+        t["T_KIDNEY"] += 1
         world_db["wetmap"][pos] -= 1
         if world_db["wetmap"][pos] == ord("0"):
             world_db["MAP"][pos] = ord("0")
@@ -82,12 +82,12 @@ def play_move(str_arg):
         if 1 == move_result[0]:
             pos = (move_result[1] * world_db["MAP_LENGTH"]) + move_result[2]
             if chr(world_db["MAP"][pos]) in "34":
-                if t["T_BOWEL"] >= 32:
+                if t["T_STOMACH"] >= 32:
                     if t == world_db["Things"][0]:
                         log("You're too FULL to eat.")
                     return
                 world_db["Things"][0]["T_ARGUMENT"] = d
-                world_db["set_command"]("move")
+                world_db["set_command"]("eat")
                 return
             if chr(world_db["MAP"][pos]) in symbols_passable:
                 world_db["Things"][0]["T_ARGUMENT"] = d
@@ -96,54 +96,82 @@ def play_move(str_arg):
         log("You CAN'T eat your way through there.")
 
 
-def actor_move(t):
-    from server.build_fov_map import build_fov_map
+def actor_eat(t):
     from server.utils import mv_yx_in_dir_legal, rand
-    from server.config.world_data import directions_db, symbols_passable
+    from server.config.world_data import symbols_passable
     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]
-        hitted = [tid for tid in world_db["Things"]
-                  if world_db["Things"][tid] != t
-                  if world_db["Things"][tid]["T_LIFEPOINTS"]
-                  if world_db["Things"][tid]["T_POSY"] == move_result[1]
-                  if world_db["Things"][tid]["T_POSX"] == move_result[2]]
-        if len(hitted):
-            hit_id = hitted[0]
-            hitted_tid = world_db["Things"][hit_id]["T_TYPE"]
-            if t == world_db["Things"][0]:
-                hitted_name = world_db["ThingTypes"][hitted_tid]["TT_NAME"]
-                log("You BUMP into " + hitted_name + ".")
-            elif 0 == hit_id:
-                hitter_name = world_db["ThingTypes"][t["T_TYPE"]]["TT_NAME"]
-                log(hitter_name +" BUMPS into you.")
-            return
+        #hitted = [tid for tid in world_db["Things"]
+        #          if world_db["Things"][tid] != t
+        #          if world_db["Things"][tid]["T_LIFEPOINTS"]
+        #          if world_db["Things"][tid]["T_POSY"] == move_result[1]
+        #          if world_db["Things"][tid]["T_POSX"] == move_result[2]]
+        #if len(hitted):
+        #    hit_id = hitted[0]
+        #    hitted_tid = world_db["Things"][hit_id]["T_TYPE"]
+        #    if t == world_db["Things"][0]:
+        #        hitted_name = world_db["ThingTypes"][hitted_tid]["TT_NAME"]
+        #        log("You BUMP into " + hitted_name + ".")
+        #    elif 0 == hit_id:
+        #        hitter_name = world_db["ThingTypes"][t["T_TYPE"]]["TT_NAME"]
+        #        log(hitter_name +" BUMPS into you.")
+        #    return
         passable = chr(world_db["MAP"][pos]) in symbols_passable
-    direction = [direction for direction in directions_db
-                 if directions_db[direction] == chr(t["T_ARGUMENT"])][0]
     if passable:
-        t["T_POSY"] = move_result[1]
-        t["T_POSX"] = move_result[2]
-        t["pos"] = move_result[1] * world_db["MAP_LENGTH"] + move_result[2]
-        build_fov_map(t)
+        log("You try to EAT, but fail.")
     else:
         height = world_db["MAP"][pos] - ord("0")
-        if t["T_BOWEL"] >= 32 or height == 5:
+        if t["T_STOMACH"] >= 32 or height == 5:
             return
         eaten = False
         if height == 3 and 0 == int(rand.next() % 2):
-            t["T_BOWEL"] += height
+            t["T_STOMACH"] += height
             eaten = True
         elif height == 4 and 0 == int(rand.next() % 5):
-            t["T_BOWEL"] += height
+            t["T_STOMACH"] += height
             eaten = True
         log("You EAT.")
         if eaten:
             world_db["MAP"][pos] = ord("0")
-            if t["T_BOWEL"] > 32:
-                t["T_BOWEL"] = 32
+            if t["T_STOMACH"] > 32:
+                t["T_STOMACH"] = 32
+
+
+def actor_move(t):
+    from server.build_fov_map import build_fov_map
+    from server.utils import mv_yx_in_dir_legal, rand
+    from server.config.world_data import symbols_passable
+    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]
+        #hitted = [tid for tid in world_db["Things"]
+        #          if world_db["Things"][tid] != t
+        #          if world_db["Things"][tid]["T_LIFEPOINTS"]
+        #          if world_db["Things"][tid]["T_POSY"] == move_result[1]
+        #          if world_db["Things"][tid]["T_POSX"] == move_result[2]]
+        #if len(hitted):
+        #    hit_id = hitted[0]
+        #    hitted_tid = world_db["Things"][hit_id]["T_TYPE"]
+        #    if t == world_db["Things"][0]:
+        #        hitted_name = world_db["ThingTypes"][hitted_tid]["TT_NAME"]
+        #        log("You BUMP into " + hitted_name + ".")
+        #    elif 0 == hit_id:
+        #        hitter_name = world_db["ThingTypes"][t["T_TYPE"]]["TT_NAME"]
+        #        log(hitter_name +" BUMPS into you.")
+        #    return
+        passable = chr(world_db["MAP"][pos]) in symbols_passable
+    if passable:
+        t["T_POSY"] = move_result[1]
+        t["T_POSX"] = move_result[2]
+        t["pos"] = move_result[1] * world_db["MAP_LENGTH"] + move_result[2]
+        build_fov_map(t)
+    else:
+        log("You try to MOVE there, but fail.")
 
 
 def test_hole(t):
@@ -193,7 +221,7 @@ def make_map():
                 and ((not single_allowed) or is_neighbor((y, x), "0")):
             world_db["MAP"][pos] = ord("0")
             i_ground += 1
-    n_water = int((length ** 2) / 16)
+    n_water = int((length ** 2) / 64)
     i_water = 0
     while (i_water <= n_water):
         y, x, pos = new_pos()
@@ -253,6 +281,14 @@ def turn_over():
                     if t["T_BLADDER"] > 16:
                         if 0 == (rand.next() % (33 - t["T_BLADDER"])):
                             action_db["actor_pee"](t)
+                    t["T_STOMACH"] -= 1
+                    t["T_BOWEL"] += 1
+                    t["T_KIDNEY"] -= 1
+                    t["T_BLADDER"] += 1
+                    if t["T_STOMACH"] == 0:
+                        world_db["die"](t, "You DIE of hunger.")
+                    elif t["T_KIDNEY"] == 0:
+                        world_db["die"](t, "You DIE of dehydration.")
         water = 0
         positions_to_wet = []
         for pos in range(world_db["MAP_LENGTH"] ** 2):
@@ -264,7 +300,7 @@ def turn_over():
             wetness = world_db["wetmap"][pos] - ord("0")
             height = world_db["MAP"][pos] - ord("0")
             if height == 0 and wetness > 0 \
-                    and 0 == rand.next() % ((2 ** 12) / (2 ** wetness)):
+                    and 0 == rand.next() % ((2 ** 13) / (2 ** wetness)):
                 world_db["MAP"][pos] = ord("-")
                 if pos in positions_to_wet:
                     positions_to_wet.remove(pos)
@@ -355,13 +391,17 @@ def write_wetmap():
 
 
 from server.config.io import io_db
+io_db["worldstate_write_order"] += [["T_STOMACH", "player_int"]]
+io_db["worldstate_write_order"] += [["T_KIDNEY", "player_int"]]
 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 = "345"
 server.config.world_data.symbols_passable = "012-"
+server.config.world_data.thing_defaults["T_STOMACH"] = 16
 server.config.world_data.thing_defaults["T_BOWEL"] = 0
+server.config.world_data.thing_defaults["T_KIDNEY"] = 16
 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
@@ -371,12 +411,15 @@ from server.config.commands import commands_db
 commands_db["THINGS_HERE"] = (2, True, lambda x, y: None)
 commands_db["ai"] = (0, False, command_ai)
 commands_db["move"] = (1, False, play_move)
+commands_db["eat"] = (1, False, play_move)
 commands_db["wait"] = (0, False, play_wait)
 commands_db["drop"] = (0, False, play_drop)
 commands_db["drink"] = (0, False, play_drink)
 commands_db["pee"] = (0, False, play_pee)
 commands_db["use"] = (1, False, lambda x: None)
 commands_db["pickup"] = (0, False, lambda: None)
+commands_db["T_STOMACH"] = (1, False, setter("Thing", "T_BOWEL", 0, 255))
+commands_db["T_KIDNEY"] = (1, False, setter("Thing", "T_BLADDER", 0, 255))
 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)
@@ -388,6 +431,7 @@ server.config.actions.action_db = {
     "actor_drop": actor_drop,
     "actor_drink": actor_drink,
     "actor_pee": actor_pee,
+    "actor_eat": actor_eat,
 }
 
 strong_write(io_db["file_out"], "PLUGIN TheCrawlingEater\n")
-- 
2.30.2