X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=plomrogue%2Fcommands.py;h=9c34a1c98058043027e9cf9766c7ac9eeaedacfe;hb=3b86e8effe9aa77fa87f86a1057d12d4c8019324;hp=49312eeff129006a7755bee3ed4645088eaacf5e;hpb=faf760cf585b035e207e5bc80ec4fce720685c23;p=plomrogue2
diff --git a/plomrogue/commands.py b/plomrogue/commands.py
index 49312ee..9c34a1c 100644
--- a/plomrogue/commands.py
+++ b/plomrogue/commands.py
@@ -60,25 +60,9 @@ def cmd_LOGIN(game, nick, connection_id):
nick = nick.strip()
if len(nick) == 0:
raise GameError('empty name')
- for t in [t for t in game.things if t.type_ == 'Player' and t.name == nick]:
- raise GameError('name already in use')
if game.get_player(connection_id):
raise GameError('cannot log in twice')
- t = game.add_thing('Player', game.spawn_point)
- t.name = nick
- t.thing_char = game.get_next_player_char()
- game.sessions[connection_id] = {
- 'thing_id': t.id_,
- 'status': 'player'
- }
- game.io.send('PLAYER_ID %s' % t.id_, connection_id)
- game.io.send('LOGIN_OK', connection_id)
- game.io.send('CHAT ' + quote(t.name + ' entered the map.'))
- for s in [s for s in game.things
- if s.type_ == 'SpawnPoint' and s.name == t.name]:
- t.position = s.position
- break
- # game.changed = True # handled by game.add_thing
+ game.login_requests += [(nick, connection_id)]
cmd_LOGIN.argtypes = 'string'
def cmd_BECOME_ADMIN(game, password, connection_id):
@@ -293,14 +277,16 @@ def cmd_GOD_THING_PROTECTION(game, thing_id, protection_char):
t.protection = protection_char
cmd_GOD_THING_PROTECTION.argtypes = 'int:pos char'
-def cmd_THING_DOOR_CLOSED(game, thing_id):
+def cmd_THING_DOOR_CLOSED(game, thing_id, locked):
t = game.get_thing(thing_id)
if not t:
raise GameError('thing of ID %s not found' % thing_id)
if not t.type_ == 'Door':
raise GameError('thing of ID %s not door' % thing_id)
t.close()
-cmd_THING_DOOR_CLOSED.argtypes = 'int:pos'
+ if locked:
+ t.lock()
+cmd_THING_DOOR_CLOSED.argtypes = 'int:pos bool'
def cmd_THING_MUSICPLAYER_SETTINGS(game, thing_id, playing, index, repeat):
t = game.get_thing(thing_id)
@@ -351,25 +337,6 @@ def cmd_PLAYER_FACE(game, face, connection_id):
game.record_change(t.position, 'other')
cmd_PLAYER_FACE.argtypes = 'string'
-def cmd_PLAYER_HAT(game, hat, connection_id):
- t = game.get_player(connection_id)
- if not t:
- raise GameError('can only edit hat when already logged in')
- if not t.name in game.hats:
- raise GameError('not currently wearing an editable hat')
- if len(hat) != 18:
- raise GameError('wrong hat string length')
- legal_chars = t.get_cookie_chars()
- for c in hat:
- if c not in legal_chars:
- raise GameError('used illegal character: "%s" â '
- 'allowed characters: %s'
- % (c, legal_chars))
- game.hats[t.name] = hat
- game.changed = True
- game.record_change(t.position, 'other')
-cmd_PLAYER_HAT.argtypes = 'string'
-
def cmd_GOD_PLAYER_FACE(game, name, face):
if len(face) != 18:
raise GameError('wrong face string length')
@@ -386,13 +353,86 @@ def cmd_GOD_PLAYERS_HAT_CHARS(game, name, hat_chars):
game.players_hat_chars[name] = hat_chars
cmd_GOD_PLAYERS_HAT_CHARS.argtypes = 'string string'
-def cmd_THING_HAT_DESIGN(game, thing_id, design):
- if len(design) != 18:
- raise GameError('hat design of wrong length')
+def cmd_THING_DESIGN(game, design, pw, connection_id):
+ player = game.get_player(connection_id)
+ if not player:
+ raise GameError('need to be logged in for this')
+ if not player.carrying:
+ raise GameError('need to carry a thing to re-draw it')
+ if not game.can_do_thing_with_pw(player.carrying, pw):
+ raise GameError('wrong password for thing')
+ if not hasattr(player.carrying, 'design'):
+ raise GameError('carried thing not designable')
+ if player.carrying.type_ == 'Hat':
+ legal_chars = player.get_cookie_chars()
+ for c in design:
+ if c not in legal_chars:
+ raise GameError('used illegal character: "%s" â '
+ 'allowed characters: %s'
+ % (c, legal_chars))
+ size = player.carrying.design_size
+ if len(design) != size.y * size.x:
+ raise GameError('design for carried thing of wrong length')
+ player.carrying.design = design
+ game.changed = True
+ game.record_change(player.carrying.position, 'other')
+cmd_THING_DESIGN.argtypes = 'string string'
+
+def cmd_GOD_THING_DESIGN(game, thing_id, design):
t = game.get_thing(thing_id)
if not t:
raise GameError('thing of ID %s not found' % thing_id)
- if t.type_ != 'Hat':
- raise GameError('thing of ID %s not a hat' % thing_id)
+ if not hasattr(t, 'design'):
+ raise GameError('thing of ID %s not designable' % thing_id)
+ if len(design) != t.design_size.y * t.design_size.x:
+ raise GameError('design for thing of ID %s of wrong length' % thing_id)
t.design = design
-cmd_THING_HAT_DESIGN.argtypes = 'int:pos string'
+cmd_GOD_THING_DESIGN.argtypes = 'int:pos string'
+
+# TODO: refactor similar god and player commands
+
+def cmd_THING_DOOR_KEY(game, key_id, door_id):
+ key = game.get_thing(key_id)
+ if not key:
+ raise GameError('thing of ID %s not found' % key_id)
+ if key.type_ != 'DoorKey':
+ raise GameError('thing of ID %s not a door key' % key_id)
+ door = game.get_thing(door_id)
+ if not door:
+ raise GameError('thing of ID %s not found' % door_id)
+ if door.type_ != 'Door':
+ raise GameError('thing of ID %s not a door' % key_id)
+ key.door = door
+cmd_THING_DOOR_KEY.argtypes = 'int:pos int:pos'
+
+def cmd_THING_CRATE_ITEM(game, crate_id, item_id):
+ crate = game.get_thing(crate_id)
+ if not crate:
+ raise GameError('thing of ID %s not found' % crate_id)
+ if crate.type_ != 'Crate':
+ raise GameError('thing of ID %s not a crate' % crate_id)
+ item = game.get_thing(item_id)
+ if not item:
+ raise GameError('thing of ID %s not found' % item_id)
+ if item.type_ == 'Crate':
+ raise GameError('thing of ID %s is a crate' % item_id)
+ crate.accept(item)
+cmd_THING_CRATE_ITEM.argtypes = 'int:pos int:pos'
+
+def cmd_MAP_CONTROL_PRESETS(game, draw_control_presets):
+ game.draw_control_presets = draw_control_presets
+cmd_MAP_CONTROL_PRESETS.argtypes = 'bool'
+
+def cmd_THING_SPAWNPOINT_CREATED(game, spawnpoint_id, timestamp):
+ import datetime
+ spawnpoint = game.get_thing(spawnpoint_id)
+ if not spawnpoint:
+ raise GameError('thing of ID %s not found' % spawnpoint_id)
+ if spawnpoint.type_ != 'SpawnPoint':
+ raise GameError('thing of ID %s not a SpawnPoint' % spawnpoint_id)
+ if timestamp == 0:
+ spawnpoint.temporary = False
+ else:
+ spawnpoint.temporary = True
+ spawnpoint.created_at = datetime.datetime.fromtimestamp(timestamp)
+cmd_THING_SPAWNPOINT_CREATED.argtypes = 'int:pos int:nonneg'