From: Christian Heller <c.heller@plomlompom.de>
Date: Wed, 4 Mar 2015 13:42:09 +0000 (+0100)
Subject: Server/py: Undummify actor_pick_up(), plus some stylistic fixes.
X-Git-Tag: tce~417
X-Git-Url: https://plomlompom.com/repos/%7B%7Bprefix%7D%7D/%7B%7Bdb.prefix%7D%7D/%7B%7Bdb.prefix%7D%7D/unset_cookie?a=commitdiff_plain;h=21873292b1a80e842bdb7b9ac8ee763d9ab2ead5;p=plomrogue

Server/py: Undummify actor_pick_up(), plus some stylistic fixes.
---

diff --git a/plomrogue-server.py b/plomrogue-server.py
index a66e2ae..cb7f9b0 100755
--- a/plomrogue-server.py
+++ b/plomrogue-server.py
@@ -449,9 +449,9 @@ def build_fov_map(t):
     # DUMMY so far. Just builds an all-visible map.
 
 
-def actor_wait(Thing):
-    """Do nothing (but loudly, if by player)."""
-    if Thing == world_db["Things"][0]:
+def actor_wait(t):
+    """Make t do nothing (but loudly, if player avatar)."""
+    if t == world_db["Things"][0]:
         strong_write(io_db["file_out"], "LOG You wait.\n")
 
 
@@ -459,24 +459,34 @@ def actor_move(Thing):
     pass
 
 
-def actor_pick_up(Thing):
-    """Pick up (topmost?) thing from ground into inventory."""
+def actor_pick_up(t):
+    """Make t pick up (topmost?) Thing from ground into inventory."""
     # Topmostness is actually not defined so far.
-    ids = [id for id in world_db["Things"] if world_db["Things"][id] != Thing
+    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"] == Thing["T_POSY"]
-           if world_db["Things"][id]["T_POSX"] == Thing["T_POSX"]]
-    if ids:
+           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
-        Thing["T_CARRIES"].append(ids[0])
-        strong_write(io_db["file_out"], "LOG You pick up an object.\n")
-    else:
+        t["T_CARRIES"].append(ids[0])
+        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]:
         err = "You try to pick up an object, but there is none."
         strong_write(io_db["file_out"], "LOG " + err + "\n")
 
 
-def actor_drop(Thing):
-    pass
+def actor_drop(t):
+    """Make t rop Thing from inventory to ground indexed by T_ARGUMENT."""
+    # TODO: Handle case where T_ARGUMENT matches nothing.
+    if len(t["T_CARRIES"]):
+        id = t["T_CARRIES"][t["T_ARGUMENT"]]
+        t["T_CARRIES"].remove(id)
+        world_db["Things"][id]["carried"] = False
+        if t == world_db["Things"][0]:
+            print("You drop an object.")
+    elif t == world_db["Things"][0]:
+        print("You try to drop an object, but you own none.")
 
 
 def actor_use(Thing):