X-Git-Url: https://plomlompom.com/repos/todo?a=blobdiff_plain;f=new2%2Fplomrogue%2Fcommands.py;h=8aec89b6583f3376e7acdeebf61fc12fd25e8c89;hb=59a3670b274793215fbea550d2ec7f90527ad53c;hp=9e67ce02600682eaa12823c3d63bf7c6ffaed6a8;hpb=beebfdb7dac8e7630643c44e9ae8d3c79d5d39d8;p=plomrogue2-experiments diff --git a/new2/plomrogue/commands.py b/new2/plomrogue/commands.py index 9e67ce0..8aec89b 100644 --- a/new2/plomrogue/commands.py +++ b/new2/plomrogue/commands.py @@ -1,5 +1,6 @@ from plomrogue.misc import quote from plomrogue.errors import GameError +from plomrogue.mapping import YX @@ -19,13 +20,18 @@ def cmd_LOGIN(game, nick, connection_id): 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) + game.io.send('LOGIN_OK ' + quote('you are now: ' + nick), connection_id) t.nickname = nick game.io.send('PLAYER_ID %s' % t.id_, connection_id) cmd_LOGIN.argtypes = 'string' +def cmd_GET_GAMESTATE(game, connection_id): + game.send_gamestate(connection_id) +cmd_GET_GAMESTATE.argtypes = '' + def cmd_QUERY(game, target_nick, msg, connection_id): if not connection_id in game.sessions: raise GameError('can only query when logged in') @@ -49,8 +55,7 @@ def cmd_TURN(game, n): game.turn = n cmd_TURN.argtypes = 'int:nonneg' -#def cmd_ANNOTATE(game, yx, connection_id): -def cmd_ANNOTATE(game, yx, msg): +def cmd_ANNOTATE(game, yx, msg, connection_id): if msg == ' ': if yx in game.annotations: del game.annotations[yx] @@ -66,7 +71,6 @@ def cmd_GET_ANNOTATION(game, yx, connection_id): game.io.send('ANNOTATION %s %s' % (yx, quote(annotation))) cmd_GET_ANNOTATION.argtypes = 'yx_tuple:nonneg' -# TODO: disallow these commands from clients? (maybe by failing on connection_id?) def cmd_MAP_LINE(game, y, line): game.map.set_line(y, line) cmd_MAP_LINE.argtypes = 'int:nonneg string'