1 # This file is part of PlomRogue. PlomRogue is licensed under the GPL version 3
2 # or any later version. For details on its copyright, license, and warranties,
3 # see the file NOTICE in the root directory of the PlomRogue source package.
6 from server.config.world_data import world_db
7 from server.io import log
8 from server.utils import rand
12 """If t's HP < max, increment them if well-nourished, maybe waiting."""
13 if t["T_LIFEPOINTS"] < \
14 world_db["ThingTypes"][t["T_TYPE"]]["TT_LIFEPOINTS"]:
15 wait_id = [id for id in world_db["ThingActions"]
16 if world_db["ThingActions"][id]["TA_NAME"] == "wait"][0]
17 wait_divider = 8 if t["T_COMMAND"] == wait_id else 1
18 testval = int(abs(t["T_SATIATION"]) / wait_divider)
19 if (testval <= 1 or 1 == (rand.next() % testval)):
20 t["T_LIFEPOINTS"] += 1
21 if t == world_db["Things"][0]:
25 def hunger_per_turn(type_id):
26 """The amount of satiation score lost per turn for things of given type."""
28 return int(math.sqrt(world_db["ThingTypes"][type_id]["TT_LIFEPOINTS"]))
32 """Decrement t's satiation,dependent on it trigger lifepoint dec chance."""
33 from server.config.misc import decrement_lifepoints
34 if t["T_SATIATION"] > -32768:
35 t["T_SATIATION"] -= hunger_per_turn(t["T_TYPE"])
36 if 0 != t["T_SATIATION"] and 0 == int(rand.next() / abs(t["T_SATIATION"])):
37 if t == world_db["Things"][0]:
38 if t["T_SATIATION"] < 0:
39 log("You SUFFER from hunger.")
41 log("You SUFFER from over-eating.")
42 decrement_lifepoints(t)
45 def set_world_inactive():
46 """Set world_db["WORLD_ACTIVE"] to 0 and remove worldstate file."""
47 from server.io import safely_remove_worldstate_file
48 safely_remove_worldstate_file()
49 world_db["WORLD_ACTIVE"] = 0
53 """Run game world and its inhabitants until new player input expected."""
54 from server.ai import ai
55 from server.config.actions import action_db
56 from server.config.misc import calc_effort_func
57 from server.update_map_memory import update_map_memory
58 from server.thingproliferation import thingproliferation
60 while world_db["Things"][0]["T_LIFEPOINTS"]:
61 proliferable_map = world_db["MAP"][:]
62 for id in [id for id in world_db["Things"]
63 if not world_db["Things"][id]["carried"]]:
64 y = world_db["Things"][id]["T_POSY"]
65 x = world_db["Things"][id]["T_POSX"]
66 proliferable_map[y * world_db["MAP_LENGTH"] + x] = ord('X')
67 for id in [id for id in world_db["Things"]]: # Only what's from start!
68 if not id in world_db["Things"] or \
69 world_db["Things"][id]["carried"]: # May have been consumed or
70 continue # picked up during turn …
71 Thing = world_db["Things"][id]
72 if Thing["T_LIFEPOINTS"]:
73 if not Thing["T_COMMAND"]:
74 update_map_memory(Thing)
80 if Thing["T_LIFEPOINTS"]:
81 Thing["T_PROGRESS"] += 1
82 taid = [a for a in world_db["ThingActions"]
83 if a == Thing["T_COMMAND"]][0]
84 ThingAction = world_db["ThingActions"][taid]
85 effort = calc_effort_func(ThingAction, Thing)
86 if Thing["T_PROGRESS"] == effort:
87 action = action_db["actor_" + ThingAction["TA_NAME"]]
89 Thing["T_COMMAND"] = 0
90 Thing["T_PROGRESS"] = 0
91 thingproliferation(Thing, proliferable_map)