From: Christian Heller Date: Sun, 8 Mar 2015 00:05:21 +0000 (+0100) Subject: Server/py: Let actor_pick_up() pick up Things by highest ID. X-Git-Tag: tce~380 X-Git-Url: https://plomlompom.com/repos/%7B%7Bdb.prefix%7D%7D/%7B%7B%20web_path%20%7D%7D/decks/%7B%7Bprefix%7D%7D/coming?a=commitdiff_plain;h=48f541330d16b71141136d929b78a44a7afeb5d5;p=plomrogue Server/py: Let actor_pick_up() pick up Things by highest ID. --- diff --git a/plomrogue-server.py b/plomrogue-server.py index 2d53bb5..b08899a 100755 --- a/plomrogue-server.py +++ b/plomrogue-server.py @@ -629,14 +629,18 @@ 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. + # Topmostness is actually not defined so far. Picks Thing with highest ID. ids = [id for id in world_db["Things"] if 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"]] if len(ids): - world_db["Things"][ids[0]]["carried"] = True - t["T_CARRIES"].append(ids[0]) + highest_id = 0 + for id in ids: + if id > highest_id: + highest_id = id + world_db["Things"][highest_id]["carried"] = True + t["T_CARRIES"].append(highest_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]: