Ensure that clipboard changes are tracked properly & don't fire events on same clipboard content

MYC-Refactor
Hammy 3 years ago
parent 92f0d820a1
commit 8f5cfd2493

@ -1,5 +1,6 @@
package me.goudham; package me.goudham;
import java.awt.Dimension;
import java.awt.Image; import java.awt.Image;
import java.awt.datatransfer.Clipboard; import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.ClipboardOwner; import java.awt.datatransfer.ClipboardOwner;
@ -53,24 +54,39 @@ class WindowsOrUnixClipboardListener extends ClipboardListener implements Runnab
if (isTextMonitored()) { if (isTextMonitored()) {
if (TEXT.isAvailable(oldClipboard) && !FILELIST.isAvailable(oldClipboard)) { if (TEXT.isAvailable(oldClipboard) && !FILELIST.isAvailable(oldClipboard)) {
String stringContent = getStringContent(newClipboardContents); String stringContent = getStringContent(newClipboardContents);
if (!stringContent.equals(oldClipboardContent.getOldText())) {
getEventManager().notifyTextEvent(oldClipboardContent, stringContent); getEventManager().notifyTextEvent(oldClipboardContent, stringContent);
} }
} }
}
if (isImageMonitored()) { if (isImageMonitored()) {
if (IMAGE.isAvailable(oldClipboard)) { if (IMAGE.isAvailable(oldClipboard)) {
BufferedImage bufferedImage = getImageContent(newClipboardContents); BufferedImage bufferedImage = getImageContent(newClipboardContents);
BufferedImage oldBufferedImage = oldClipboardContent.getOldImage();
if (bufferedImage != oldBufferedImage) {
if (oldBufferedImage != null) {
Dimension imageDimension = new Dimension(bufferedImage.getWidth(), bufferedImage.getHeight());
Dimension oldImageDimension = new Dimension(oldBufferedImage.getWidth(), oldBufferedImage.getHeight());
if (!imageDimension.equals(oldImageDimension)) {
getEventManager().notifyImageEvent(oldClipboardContent, bufferedImage);
}
} else {
getEventManager().notifyImageEvent(oldClipboardContent, bufferedImage); getEventManager().notifyImageEvent(oldClipboardContent, bufferedImage);
} }
} }
}
}
if (isFileMonitored()) { if (isFileMonitored()) {
if (FILELIST.isAvailable(oldClipboard)) { if (FILELIST.isAvailable(oldClipboard)) {
List<File> fileList = getFileContent(newClipboardContents); List<File> fileList = getFileContent(newClipboardContents);
if (!fileList.equals(oldClipboardContent.getOldFiles())) {
getEventManager().notifyFilesEvent(oldClipboardContent, fileList); getEventManager().notifyFilesEvent(oldClipboardContent, fileList);
} }
} }
} }
}
void regainOwnership(Clipboard clipboard, Transferable newClipboardContents) { void regainOwnership(Clipboard clipboard, Transferable newClipboardContents) {
clipboard.setContents(newClipboardContents, this); clipboard.setContents(newClipboardContents, this);
@ -108,7 +124,12 @@ class WindowsOrUnixClipboardListener extends ClipboardListener implements Runnab
ie.printStackTrace(); ie.printStackTrace();
} }
try {
clipboard.setContents(new StringSelection(stringContent), this); clipboard.setContents(new StringSelection(stringContent), this);
} catch (IllegalStateException ise) {
ise.printStackTrace();
executorService.submit(this);
}
} }
@Override @Override
@ -119,7 +140,12 @@ class WindowsOrUnixClipboardListener extends ClipboardListener implements Runnab
ie.printStackTrace(); ie.printStackTrace();
} }
try {
clipboard.setContents(new TransferableImage(imageContent), this); clipboard.setContents(new TransferableImage(imageContent), this);
} catch (IllegalStateException ise) {
ise.printStackTrace();
executorService.submit(this);
}
} }
@Override @Override
@ -130,32 +156,39 @@ class WindowsOrUnixClipboardListener extends ClipboardListener implements Runnab
ie.printStackTrace(); ie.printStackTrace();
} }
try {
clipboard.setContents(new TransferableFileList(fileContent), this); clipboard.setContents(new TransferableFileList(fileContent), this);
} catch (IllegalStateException ise) {
ise.printStackTrace();
executorService.submit(this);
}
} }
@Override @Override
void insertAndNotify(String stringContent) { void insertAndNotify(String stringContent) {
Transferable currentClipboardContents = clipboard.getContents(this);
insert(stringContent); insert(stringContent);
run(); lostOwnership(clipboard, currentClipboardContents);
} }
@Override @Override
void insertAndNotify(Image imageContent) { void insertAndNotify(Image imageContent) {
Transferable currentClipboardContents = clipboard.getContents(this);
insert(imageContent); insert(imageContent);
run(); lostOwnership(clipboard, currentClipboardContents);
} }
@Override @Override
void insertAndNotify(List<File> fileContent) { void insertAndNotify(List<File> fileContent) {
Transferable currentClipboardContents = clipboard.getContents(this);
insert(fileContent); insert(fileContent);
run(); lostOwnership(clipboard, currentClipboardContents);
} }
@Override @Override
public void run() { public void run() {
try { try {
Transferable currentClipboardContents = clipboard.getContents(null); Transferable currentClipboardContents = clipboard.getContents(null);
processContents(clipboard, currentClipboardContents, currentClipboardContents);
regainOwnership(clipboard, currentClipboardContents); regainOwnership(clipboard, currentClipboardContents);
} catch (IllegalStateException err) { } catch (IllegalStateException err) {
err.printStackTrace(); err.printStackTrace();

Loading…
Cancel
Save