Fixes copy/paste issue#18.

This commit is contained in:
Graeme Humphries 2013-03-15 12:10:04 -07:00
parent b248a1db49
commit 65893e806c

View File

@ -261,7 +261,7 @@ class CruSSH:
def feed_paste(widget): def feed_paste(widget):
for host in self.Terminals: for host in self.Terminals:
if self.Terminals[host].copy_input: if self.Terminals[host].copy_input:
self.Terminals[host].feed_child(self.Clipboard.wait_for_text()) self.Terminals[host].paste_clipboard()
self.EntryBox.props.buffer.delete_text(0, -1) self.EntryBox.props.buffer.delete_text(0, -1)
# forward key events to all terminals with copy_input set # forward key events to all terminals with copy_input set
@ -271,7 +271,7 @@ class CruSSH:
if (event.type == gtk.gdk.KEY_PRESS) \ if (event.type == gtk.gdk.KEY_PRESS) \
and (event.state & gtk.gdk.CONTROL_MASK == gtk.gdk.CONTROL_MASK) \ and (event.state & gtk.gdk.CONTROL_MASK == gtk.gdk.CONTROL_MASK) \
and (event.state & gtk.gdk.SHIFT_MASK == gtk.gdk.SHIFT_MASK) \ and (event.state & gtk.gdk.SHIFT_MASK == gtk.gdk.SHIFT_MASK) \
and (event.keyval == 86): and (event.keyval == gtk.gdk.keyval_from_name('V')):
feed_paste(widget) feed_paste(widget)
else: else:
# propagate to every terminal # propagate to every terminal
@ -308,6 +308,21 @@ class CruSSH:
except: except:
pass pass
def handle_copy_paste(widget, event):
self.EntryBox.props.buffer.delete_text(0, -1)
# check for paste key shortcut (ctl-shift-v)
if (event.type == gtk.gdk.KEY_PRESS) \
and (event.state & gtk.gdk.CONTROL_MASK == gtk.gdk.CONTROL_MASK) \
and (event.state & gtk.gdk.SHIFT_MASK == gtk.gdk.SHIFT_MASK) \
and (event.keyval == gtk.gdk.keyval_from_name('V')):
widget.paste_clipboard()
return True
elif (event.type == gtk.gdk.KEY_PRESS) \
and (event.state & gtk.gdk.CONTROL_MASK == gtk.gdk.CONTROL_MASK) \
and (event.state & gtk.gdk.SHIFT_MASK == gtk.gdk.SHIFT_MASK) \
and (event.keyval == gtk.gdk.keyval_from_name('C')):
widget.copy_clipboard()
return True
# init all terminals # init all terminals
for host in hosts: for host in hosts:
terminal = vte.Terminal() terminal = vte.Terminal()
@ -321,6 +336,8 @@ class CruSSH:
terminal.fork_command(command=cmd[0], argv=cmd) terminal.fork_command(command=cmd[0], argv=cmd)
# track whether we mirror output to this terminal # track whether we mirror output to this terminal
terminal.copy_input = True terminal.copy_input = True
# attach copy/paste handler
terminal.connect("key_press_event", handle_copy_paste)
self.Terminals[host] = terminal self.Terminals[host] = terminal
# hook terminals so they reflow layout on exit # hook terminals so they reflow layout on exit