home · contact · privacy
Add field of view.
[plomrogue2] / plomrogue / commands.py
index 85ec5d31b2d4c3c40ae1bf0ee0a3f9e877e00167..a3d1f4ce685cfabb9f6108ff8bd7f0f154e8434b 100644 (file)
@@ -10,10 +10,19 @@ def cmd_TASKS(game, connection_id):
 cmd_TASKS.argtypes = ''
 
 def cmd_ALL(game, msg, connection_id):
+    import math
     if not connection_id in game.sessions:
         raise GameError('need to be logged in for this')
-    t = game.get_thing(game.sessions[connection_id], False)
-    game.io.send('CHAT ' + quote(t.nickname + ': ' + msg))
+    speaker = game.get_thing(game.sessions[connection_id], False)
+    for c_id in game.sessions:
+        listener = game.get_thing(game.sessions[c_id], create_unfound=False)
+        d_y = abs(speaker.position.y - listener.position.y)
+        d_x = abs(speaker.position.x - listener.position.x)
+        d = math.sqrt(d_y ** 2 + d_x ** 2)
+        distance = '(close)' if d < 3 else '(distant)'
+        game.io.send('CHAT ' +
+                     quote('%s %s: %s' % (distance, speaker.nickname, msg)),
+                     c_id)
 cmd_ALL.argtypes = 'string'
 
 def cmd_LOGIN(game, nick, connection_id):
@@ -72,8 +81,11 @@ def cmd_TURN(game, n):
     game.turn = n
 cmd_TURN.argtypes = 'int:nonneg'
 
-def cmd_ANNOTATE(game, yx, msg, pw=None, connection_id=None):
-    if connection_id and not game.can_do_tile_with_pw(yx, pw):
+def cmd_ANNOTATE(game, yx, msg, pw, connection_id):
+    player = game.get_thing(game.sessions[connection_id], False)
+    if player.fov_stencil[yx] == '.':
+        raise GameError('cannot annotate tile outside field of view')
+    if not game.can_do_tile_with_pw(yx, pw):
         raise GameError('wrong password for tile')
     if msg == ' ':
         if yx in game.annotations:
@@ -83,8 +95,11 @@ def cmd_ANNOTATE(game, yx, msg, pw=None, connection_id=None):
     game.changed = True
 cmd_ANNOTATE.argtypes = 'yx_tuple:nonneg string string'
 
-def cmd_PORTAL(game, yx, msg, pw=None, connection_id=None):
-    if connection_id and not game.can_do_tile_with_pw(yx, pw):
+def cmd_PORTAL(game, yx, msg, pw, connection_id):
+    player = game.get_thing(game.sessions[connection_id], False)
+    if player.fov_stencil[yx] == '.':
+        raise GameError('cannot edit portal on tile outside field of view')
+    if not game.can_do_tile_with_pw(yx, pw):
         raise GameError('wrong password for tile')
     if msg == ' ':
         if yx in game.portals:
@@ -94,10 +109,23 @@ def cmd_PORTAL(game, yx, msg, pw=None, connection_id=None):
     game.changed = True
 cmd_PORTAL.argtypes = 'yx_tuple:nonneg string string'
 
+def cmd_GOD_ANNOTATE(game, yx, msg):
+    game.annotations[yx] = msg
+    game.changed = True
+cmd_GOD_ANNOTATE.argtypes = 'yx_tuple:nonneg string'
+
+def cmd_GOD_PORTAL(game, yx, msg):
+    game.portals[yx] = msg
+    game.changed = True
+cmd_GOD_PORTAL.argtypes = 'yx_tuple:nonneg string'
+
 def cmd_GET_ANNOTATION(game, yx, connection_id):
-    annotation = '(none)';
-    if yx in game.annotations:
-        annotation = game.annotations[yx]
+    player = game.get_thing(game.sessions[connection_id], False)
+    annotation = '(unknown)';
+    if player.fov_stencil[yx] == '.':
+        annotation = '(none)';
+        if yx in game.annotations:
+            annotation = game.annotations[yx]
     game.io.send('ANNOTATION %s %s' % (yx, quote(annotation)))
 cmd_GET_ANNOTATION.argtypes = 'yx_tuple:nonneg'