211 lines
6.9 KiB
Diff
211 lines
6.9 KiB
Diff
From 756021d1e433925cf9a732d7ea67b01b0beb061c Mon Sep 17 00:00:00 2001
|
|
From: Will Cohen <willcohen@users.noreply.github.com>
|
|
Date: Tue, 29 Mar 2022 14:00:56 -0400
|
|
Subject: [PATCH] Revert "ui/cocoa: Add clipboard support"
|
|
|
|
This reverts commit 7e3e20d89129614f4a7b2451fe321cc6ccca3b76.
|
|
---
|
|
include/ui/clipboard.h | 2 +-
|
|
ui/clipboard.c | 2 +-
|
|
ui/cocoa.m | 123 -----------------------------------------
|
|
3 files changed, 2 insertions(+), 125 deletions(-)
|
|
|
|
diff --git a/include/ui/clipboard.h b/include/ui/clipboard.h
|
|
index ce76aa451f..c4e1dc4ff4 100644
|
|
--- a/include/ui/clipboard.h
|
|
+++ b/include/ui/clipboard.h
|
|
@@ -269,7 +269,7 @@ void qemu_clipboard_set_data(QemuClipboardPeer *peer,
|
|
QemuClipboardInfo *info,
|
|
QemuClipboardType type,
|
|
uint32_t size,
|
|
- const void *data,
|
|
+ void *data,
|
|
bool update);
|
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(QemuClipboardInfo, qemu_clipboard_info_unref)
|
|
diff --git a/ui/clipboard.c b/ui/clipboard.c
|
|
index 9079ef829b..6b9ed59e1b 100644
|
|
--- a/ui/clipboard.c
|
|
+++ b/ui/clipboard.c
|
|
@@ -140,7 +140,7 @@ void qemu_clipboard_set_data(QemuClipboardPeer *peer,
|
|
QemuClipboardInfo *info,
|
|
QemuClipboardType type,
|
|
uint32_t size,
|
|
- const void *data,
|
|
+ void *data,
|
|
bool update)
|
|
{
|
|
if (!info ||
|
|
diff --git a/ui/cocoa.m b/ui/cocoa.m
|
|
index 5a8bd5dd84..79ed6d043f 100644
|
|
--- a/ui/cocoa.m
|
|
+++ b/ui/cocoa.m
|
|
@@ -29,7 +29,6 @@
|
|
|
|
#include "qemu/help-texts.h"
|
|
#include "qemu-main.h"
|
|
-#include "ui/clipboard.h"
|
|
#include "ui/console.h"
|
|
#include "ui/input.h"
|
|
#include "ui/kbd-state.h"
|
|
@@ -109,10 +108,6 @@ static void cocoa_switch(DisplayChangeListener *dcl,
|
|
static QemuSemaphore app_started_sem;
|
|
static bool allow_events;
|
|
|
|
-static NSInteger cbchangecount = -1;
|
|
-static QemuClipboardInfo *cbinfo;
|
|
-static QemuEvent cbevent;
|
|
-
|
|
// Utility functions to run specified code block with iothread lock held
|
|
typedef void (^CodeBlock)(void);
|
|
typedef bool (^BoolCodeBlock)(void);
|
|
@@ -1815,107 +1810,6 @@ static void addRemovableDevicesMenuItems(void)
|
|
qapi_free_BlockInfoList(pointerToFree);
|
|
}
|
|
|
|
-@interface QemuCocoaPasteboardTypeOwner : NSObject<NSPasteboardTypeOwner>
|
|
-@end
|
|
-
|
|
-@implementation QemuCocoaPasteboardTypeOwner
|
|
-
|
|
-- (void)pasteboard:(NSPasteboard *)sender provideDataForType:(NSPasteboardType)type
|
|
-{
|
|
- if (type != NSPasteboardTypeString) {
|
|
- return;
|
|
- }
|
|
-
|
|
- with_iothread_lock(^{
|
|
- QemuClipboardInfo *info = qemu_clipboard_info_ref(cbinfo);
|
|
- qemu_event_reset(&cbevent);
|
|
- qemu_clipboard_request(info, QEMU_CLIPBOARD_TYPE_TEXT);
|
|
-
|
|
- while (info == cbinfo &&
|
|
- info->types[QEMU_CLIPBOARD_TYPE_TEXT].available &&
|
|
- info->types[QEMU_CLIPBOARD_TYPE_TEXT].data == NULL) {
|
|
- qemu_mutex_unlock_iothread();
|
|
- qemu_event_wait(&cbevent);
|
|
- qemu_mutex_lock_iothread();
|
|
- }
|
|
-
|
|
- if (info == cbinfo) {
|
|
- NSData *data = [[NSData alloc] initWithBytes:info->types[QEMU_CLIPBOARD_TYPE_TEXT].data
|
|
- length:info->types[QEMU_CLIPBOARD_TYPE_TEXT].size];
|
|
- [sender setData:data forType:NSPasteboardTypeString];
|
|
- [data release];
|
|
- }
|
|
-
|
|
- qemu_clipboard_info_unref(info);
|
|
- });
|
|
-}
|
|
-
|
|
-@end
|
|
-
|
|
-static QemuCocoaPasteboardTypeOwner *cbowner;
|
|
-
|
|
-static void cocoa_clipboard_notify(Notifier *notifier, void *data);
|
|
-static void cocoa_clipboard_request(QemuClipboardInfo *info,
|
|
- QemuClipboardType type);
|
|
-
|
|
-static QemuClipboardPeer cbpeer = {
|
|
- .name = "cocoa",
|
|
- .notifier = { .notify = cocoa_clipboard_notify },
|
|
- .request = cocoa_clipboard_request
|
|
-};
|
|
-
|
|
-static void cocoa_clipboard_update_info(QemuClipboardInfo *info)
|
|
-{
|
|
- if (info->owner == &cbpeer || info->selection != QEMU_CLIPBOARD_SELECTION_CLIPBOARD) {
|
|
- return;
|
|
- }
|
|
-
|
|
- if (info != cbinfo) {
|
|
- NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
|
|
- qemu_clipboard_info_unref(cbinfo);
|
|
- cbinfo = qemu_clipboard_info_ref(info);
|
|
- cbchangecount = [[NSPasteboard generalPasteboard] declareTypes:@[NSPasteboardTypeString] owner:cbowner];
|
|
- [pool release];
|
|
- }
|
|
-
|
|
- qemu_event_set(&cbevent);
|
|
-}
|
|
-
|
|
-static void cocoa_clipboard_notify(Notifier *notifier, void *data)
|
|
-{
|
|
- QemuClipboardNotify *notify = data;
|
|
-
|
|
- switch (notify->type) {
|
|
- case QEMU_CLIPBOARD_UPDATE_INFO:
|
|
- cocoa_clipboard_update_info(notify->info);
|
|
- return;
|
|
- case QEMU_CLIPBOARD_RESET_SERIAL:
|
|
- /* ignore */
|
|
- return;
|
|
- }
|
|
-}
|
|
-
|
|
-static void cocoa_clipboard_request(QemuClipboardInfo *info,
|
|
- QemuClipboardType type)
|
|
-{
|
|
- NSAutoreleasePool *pool;
|
|
- NSData *text;
|
|
-
|
|
- switch (type) {
|
|
- case QEMU_CLIPBOARD_TYPE_TEXT:
|
|
- pool = [[NSAutoreleasePool alloc] init];
|
|
- text = [[NSPasteboard generalPasteboard] dataForType:NSPasteboardTypeString];
|
|
- if (text) {
|
|
- qemu_clipboard_set_data(&cbpeer, info, type,
|
|
- [text length], [text bytes], true);
|
|
- }
|
|
- [pool release];
|
|
- break;
|
|
- default:
|
|
- break;
|
|
- }
|
|
-}
|
|
-
|
|
/*
|
|
* The startup process for the OSX/Cocoa UI is complicated, because
|
|
* OSX insists that the UI runs on the initial main thread, and so we
|
|
@@ -1950,7 +1844,6 @@ static void cocoa_clipboard_request(QemuClipboardInfo *info,
|
|
COCOA_DEBUG("Second thread: calling qemu_main()\n");
|
|
status = qemu_main(gArgc, gArgv, *_NSGetEnviron());
|
|
COCOA_DEBUG("Second thread: qemu_main() returned, exiting\n");
|
|
- [cbowner release];
|
|
exit(status);
|
|
}
|
|
|
|
@@ -2066,18 +1959,6 @@ static void cocoa_refresh(DisplayChangeListener *dcl)
|
|
[cocoaView setAbsoluteEnabled:YES];
|
|
});
|
|
}
|
|
-
|
|
- if (cbchangecount != [[NSPasteboard generalPasteboard] changeCount]) {
|
|
- qemu_clipboard_info_unref(cbinfo);
|
|
- cbinfo = qemu_clipboard_info_new(&cbpeer, QEMU_CLIPBOARD_SELECTION_CLIPBOARD);
|
|
- if ([[NSPasteboard generalPasteboard] availableTypeFromArray:@[NSPasteboardTypeString]]) {
|
|
- cbinfo->types[QEMU_CLIPBOARD_TYPE_TEXT].available = true;
|
|
- }
|
|
- qemu_clipboard_update(cbinfo);
|
|
- cbchangecount = [[NSPasteboard generalPasteboard] changeCount];
|
|
- qemu_event_set(&cbevent);
|
|
- }
|
|
-
|
|
[pool release];
|
|
}
|
|
|
|
@@ -2117,10 +1998,6 @@ static void cocoa_display_init(DisplayState *ds, DisplayOptions *opts)
|
|
|
|
// register vga output callbacks
|
|
register_displaychangelistener(&dcl);
|
|
-
|
|
- qemu_event_init(&cbevent, false);
|
|
- cbowner = [[QemuCocoaPasteboardTypeOwner alloc] init];
|
|
- qemu_clipboard_peer_register(&cbpeer);
|
|
}
|
|
|
|
static QemuDisplay qemu_display_cocoa = {
|
|
--
|
|
2.35.1
|
|
|