From: Brian P. Hinz Date: Wed, 19 Nov 2014 23:58:59 +0000 (-0500) Subject: More Java viewer clipboard handler fixes X-Git-Tag: v1.4.0~10 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=1e6cb40a1d33e50a9d3c118689284c593e8fcbe7;p=tigervnc.git More Java viewer clipboard handler fixes * Override TransferHandler.exportToClipboard method to ensure that serverCutText updates get sent to the system clipboard. This wasn't always happening when relying on the super class' paste() method alone. * Removed some unnecessary setText() statements and one check for whether sending client cut text is enabled. (cherry picked from commit 4f95737b72a516f0ca2ffdd1d299b7469ea90962) --- diff --git a/java/com/tigervnc/vncviewer/ClipboardDialog.java b/java/com/tigervnc/vncviewer/ClipboardDialog.java index fff7dc3e..e7aa7e96 100644 --- a/java/com/tigervnc/vncviewer/ClipboardDialog.java +++ b/java/com/tigervnc/vncviewer/ClipboardDialog.java @@ -37,6 +37,14 @@ class ClipboardDialog extends Dialog implements ActionListener { // clipboard transfers to VncViewer.maxCutText.getValue() bytes. private LogWriter vlog = new LogWriter("VncTransferHandler"); + public void exportToClipboard(JComponent c, Clipboard clip, int a) + throws IllegalStateException { + if (!(c instanceof JTextComponent)) return; + StringSelection selection = + new StringSelection(((JTextComponent)c).getText()); + clip.setContents(selection, null); + } + public boolean importData(JComponent c, Transferable t) { if (canImport(c, t.getTransferDataFlavors())) { try { @@ -114,13 +122,11 @@ class ClipboardDialog extends Dialog implements ActionListener { public void serverCutText(String str, int len) { textArea.setText(str); - textArea.selectAll(); textArea.copy(); } public void clientCutText() { int hc = textArea.getText().hashCode(); - textArea.setText(""); textArea.paste(); textArea.setCaretPosition(0); String text = textArea.getText(); @@ -139,8 +145,7 @@ class ClipboardDialog extends Dialog implements ActionListener { serverCutText(new String(""), 0); } else if (s instanceof JButton && (JButton)s == sendButton) { String text = textArea.getText(); - if (cc.viewer.sendClipboard.getValue()) - cc.writeClientCutText(text, text.length()); + cc.writeClientCutText(text, text.length()); endDialog(); } else if (s instanceof JButton && (JButton)s == cancelButton) { endDialog();