Ë
    
Bjœ  ã                  ó$   — d Z ddlmZ dd„Zdd„Zy)u½  Augmentations to prompt_toolkit's input-parsing tables.

Imported once at CLI startup. Each helper installs a small mapping into
prompt_toolkit's `ANSI_SEQUENCES` so byte sequences emitted by modern
keyboard protocols (Kitty / xterm `modifyOtherKeys`) decode to existing
key tuples Hermes already binds.

Kept in a standalone module â€” separate from `cli.py` â€” so the registrations
can be unit-tested without importing the whole CLI runtime.
é    )Úannotationsc                 ó¾   — 	 ddl m}  ddlm} |j
                  |j                  f}d}dD ]!  }| j                  |«      |k7  sŒ|| |<   |dz  }Œ# |S # t        $ r Y yw xY w)uÃ  Map Shift+Enter byte sequences to the (Escape, ControlM) key tuple
    that Alt+Enter produces, so the existing Alt+Enter newline handler
    fires for terminals that emit a distinct Shift+Enter.

    Sequences mapped:
      - "\x1b[13;2u"     â€” Kitty keyboard protocol / CSI-u, modifier=2 (Shift)
      - "\x1b[27;2;13~"  â€” xterm modifyOtherKeys=2, modifier=2 (Shift)
      - "\x1b[27;2;13u"  â€” alternate ordering some emitters use

    The CSI-u sequence is not in stock prompt_toolkit. The modifyOtherKeys
    variant `\x1b[27;2;13~` IS in stock prompt_toolkit but mapped to plain
    `Keys.ControlM` â€” i.e. Shift+Enter behaves identically to Enter, which
    is the very bug this helper exists to fix. We therefore overwrite
    those two specific keys (and `\x1b[27;2;13u`) unconditionally; other
    `\x1b[27;...;13~` sequences (Ctrl+Enter, Alt+Enter via modifyOtherKeys
    variants 5/6/etc.) are left untouched.

    Default macOS Terminal and stock Windows Terminal still send the same
    byte for Enter and Shift+Enter, so there is no fix for those terminals
    at the application layer â€” the sequences above never reach Hermes.

    Returns the number of sequences whose mapping was changed.
    r   ©ÚANSI_SEQUENCES©ÚKeys)z[13;2uz
[27;2;13~z
[27;2;13ué   ©Ú*prompt_toolkit.input.ansi_escape_sequencesr   Úprompt_toolkit.keysr   Ú	ExceptionÚEscapeÚControlMÚget©r   r   Ú	alt_enterÚchangedÚseqs        ú?/home/ubuntu/.hermes/hermes-agent/hermes_cli/pt_input_extras.pyÚinstall_shift_enter_aliasr      sv   € ð0ÝMÝ,ð —‘˜dŸm™mÐ,€IØ€GØ?ò ˆØ×Ñ˜cÓ" iÓ/Ø"+ˆN˜3ÑØq‰L‰Gðð €Nøô ò Ùðúó   ‚A Á	AÁAc                 ó¾   — 	 ddl m}  ddlm} |j
                  |j                  f}d}dD ]!  }| j                  |«      |k7  sŒ|| |<   |dz  }Œ# |S # t        $ r Y yw xY w)u  Map Ctrl+Enter byte sequences to the (Escape, ControlM) key tuple
    that Alt+Enter produces, so the existing Alt+Enter newline handler
    fires for terminals that emit a distinct Ctrl+Enter.

    Sequences mapped:
      - "\x1b[13;5u"     â€” Kitty keyboard protocol / CSI-u, modifier=5 (Ctrl)
      - "\x1b[27;5;13~"  â€” xterm modifyOtherKeys=2, modifier=5 (Ctrl)
      - "\x1b[27;5;13u"  â€” alternate ordering some emitters use

    Stock prompt_toolkit doesn't map any of these. Without this alias,
    Kitty/mintty/xterm-with-modifyOtherKeys users over SSH never get a
    Ctrl+Enter newline â€” the keystroke arrives as a raw CSI sequence that
    falls through to the default character-insert handler. See #22379.

    Returns the number of sequences whose mapping was changed.
    r   r   r   )z[13;5uz
[27;5;13~z
[27;5;13ur	   r
   r   s        r   Úinstall_ctrl_enter_aliasr   6   sv   € ð"ÝMÝ,ð —‘˜dŸm™mÐ,€IØ€GØ?ò ˆØ×Ñ˜cÓ" iÓ/Ø"+ˆN˜3ÑØq‰L‰Gðð €Nøô ò Ùðúr   N)ÚreturnÚint)Ú__doc__Ú
__future__r   r   r   © ó    r   ú<module>r       s   ðñ	õ #ó$ôNr   