home · contact · privacy
Start new players in middle of map instead of topleft corner.
[plomrogue2-experiments] / new2 / plomrogue / commands.py
index 397dbe45f332aae29d22e6fba8671786496a4316..4daf0ba5b8365cc19fd98efc6b208407fa2b48f6 100644 (file)
@@ -1,5 +1,6 @@
 from plomrogue.misc import quote
 from plomrogue.errors import GameError
+from plomrogue.mapping import YX
 
 
 
@@ -7,17 +8,24 @@ def cmd_ALL(game, msg, connection_id):
     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('LOG ' + quote(t.nickname + ': ' + msg))
+    game.io.send('CHAT ' + quote(t.nickname + ': ' + msg))
 cmd_ALL.argtypes = 'string'
 
 def cmd_LOGIN(game, nick, connection_id):
     for t in [t for t in game.things if t.type_ == 'player' and t.nickname == nick]:
         raise GameError('name already in use')
-    t = game.thing_types['player'](game)
+    if connection_id in game.sessions:
+        t_id = game.sessions[connection_id]
+        t = game.get_thing(t_id, False)
+        game.io.send('META ' + quote('you rename yourself to: ' + nick), connection_id)
+    else:
+        t = game.thing_types['player'](game)
+        t.position = YX(game.map.size.y // 2, game.map.size.x // 2)
+        game.things += [t]  # TODO refactor into Thing.__init__?
+        game.sessions[connection_id] = t.id_
+        game.io.send('META ' + quote('you are now: ' + nick), connection_id)
     t.nickname = nick
-    game.things += [t]  # TODO refactor into Thing.__init__?
-    game.sessions[connection_id] = t.id_ 
-    game.io.send('META ' + quote('you are now: ' + nick), connection_id)
+    game.io.send('PLAYER_ID %s' % t.id_, connection_id)
 cmd_LOGIN.argtypes = 'string'
 
 def cmd_QUERY(game, target_nick, msg, connection_id):
@@ -28,8 +36,8 @@ def cmd_QUERY(game, target_nick, msg, connection_id):
     for t in [t for t in game.things if t.type_ == 'player' and t.nickname == target_nick]:
         for c_id in game.sessions:
             if game.sessions[c_id] == t.id_:
-                game.io.send('LOG ' + quote(source_nick+ '->' + target_nick + ': ' + msg), c_id)
-                game.io.send('LOG ' + quote(source_nick+ '->' + target_nick + ': ' + msg), connection_id)
+                game.io.send('CHAT ' + quote(source_nick+ '->' + target_nick + ': ' + msg), c_id)
+                game.io.send('CHAT ' + quote(source_nick+ '->' + target_nick + ': ' + msg), connection_id)
                 return
         raise GameError('target user offline')
     raise GameError('can only query with registered nicknames')
@@ -43,6 +51,26 @@ def cmd_TURN(game, n):
     game.turn = n
 cmd_TURN.argtypes = 'int:nonneg'
 
+def cmd_ANNOTATE(game, yx, msg, connection_id):
+    if msg == ' ':
+        if yx in game.annotations:
+            del game.annotations[yx]
+    else:
+        game.annotations[yx] = msg
+    game.changed = True
+cmd_ANNOTATE.argtypes = 'yx_tuple:nonneg string'
+
+def cmd_GET_ANNOTATION(game, yx, connection_id):
+    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'
+
 def cmd_MAP_LINE(game, y, line):
     game.map.set_line(y, line)
 cmd_MAP_LINE.argtypes = 'int:nonneg string'
+
+def cmd_MAP(game, size):
+    game.new_world(size)
+cmd_MAP.argtypes = 'yx_tuple:pos'