home · contact · privacy
Improve admin modes.
[plomrogue2] / rogue_chat_curses.py
index 698360915a513fa0329e220680081f731ee13866..a6e05ab1bf98eb0b02ab2bf12b60678bec576ddc 100755 (executable)
@@ -29,7 +29,7 @@ mode_helps = {
     },
     'control_pw_type': {
         'short': 'change tiles control password',
-        'long': 'This mode is the first of two steps to change the password for a tile control character.  First enter the tile control character for which you want to change the password!'
+        'long': 'This mode is the first of two steps to change the password for a tile control character.  First enter the tile control character for which you want to change the password.'
     },
     'control_pw_pw': {
         'short': 'change tiles control password',
@@ -353,9 +353,9 @@ class TUI:
     mode_study = Mode('study', shows_info=True)
     mode_write = Mode('write', is_single_char_entry=True)
     mode_edit = Mode('edit')
-    mode_control_pw_type = Mode('control_pw_type', is_single_char_entry=True)
+    mode_control_pw_type = Mode('control_pw_type', has_input_prompt=True)
     mode_control_pw_pw = Mode('control_pw_pw', has_input_prompt=True)
-    mode_control_tile_type = Mode('control_tile_type', is_single_char_entry=True)
+    mode_control_tile_type = Mode('control_tile_type', has_input_prompt=True)
     mode_control_tile_draw = Mode('control_tile_draw')
     mode_annotate = Mode('annotate', has_input_prompt=True, shows_info=True)
     mode_portal = Mode('portal', has_input_prompt=True, shows_info=True)
@@ -525,8 +525,14 @@ class TUI:
                 self.log_msg('@ enter username')
         elif self.mode.name == 'admin_enter':
             self.log_msg('@ enter admin password:')
+        elif self.mode.name == 'control_pw_type':
+            self.log_msg('@ enter tile control character for which you want to change the password:')
+        elif self.mode.name == 'control_tile_type':
+            self.log_msg('@ enter tile control character which you want to draw:')
         elif self.mode.name == 'control_pw_pw':
             self.log_msg('@ enter tile control password for "%s":' % self.tile_control_char)
+        elif self.mode.name == 'control_tile_draw':
+            self.log_msg('@ can draw tile control character "%s", turn drawing on/off with [%s], finish with [%s].' % (self.tile_control_char, self.keys['toggle_tile_draw'], self.keys['switch_to_admin_enter']))
         self.restore_input_values()
 
     def loop(self, stdscr):
@@ -861,6 +867,24 @@ class TUI:
                 self.send('BECOME_ADMIN ' + quote(self.input_))
                 self.input_ = ""
                 self.switch_mode('play')
+            elif self.mode.name == 'control_pw_type' and key == '\n':
+                if len(self.input_) != 1:
+                    self.log_msg('@ entered non-single-char, therefore aborted')
+                    self.switch_mode('admin')
+                    self.input_ = ""
+                else:
+                    self.tile_control_char = self.input_
+                    self.input_ = ""
+                    self.switch_mode('control_pw_pw')
+            elif self.mode.name == 'control_tile_type' and key == '\n':
+                if len(self.input_) != 1:
+                    self.log_msg('@ entered non-single-char, therefore aborted')
+                    self.switch_mode('admin')
+                    self.input_ = ""
+                else:
+                    self.tile_control_char = self.input_
+                    self.input_ = ""
+                    self.switch_mode('control_tile_draw')
             elif self.mode.name == 'chat' and key == '\n':
                 if self.input_ == '':
                     continue
@@ -930,12 +954,6 @@ class TUI:
             elif self.mode.name == 'write':
                 self.send('TASK:WRITE %s %s' % (key, quote(self.password)))
                 self.switch_mode('edit')
-            elif self.mode.name == 'control_pw_type':
-                self.tile_control_char = key
-                self.switch_mode('control_pw_pw')
-            elif self.mode.name == 'control_tile_type':
-                self.tile_control_char = key
-                self.switch_mode('control_tile_draw')
             elif self.mode.name == 'control_tile_draw':
                 if self.mode.mode_switch_on_key(self, key):
                     continue