From patchwork Tue Jun 19 01:58:32 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Programmingkid X-Patchwork-Id: 10472981 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 015F160244 for ; Tue, 19 Jun 2018 02:58:40 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id E9FDA285FB for ; Tue, 19 Jun 2018 02:58:39 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id DE4C2285FF; Tue, 19 Jun 2018 02:58:39 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-7.8 required=2.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED, DKIM_SIGNED, FREEMAIL_FROM, MAILING_LIST_MULTI, RCVD_IN_DNSWL_HI, T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) (using TLSv1 with cipher AES256-SHA (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 7CB2C285FB for ; Tue, 19 Jun 2018 02:58:39 +0000 (UTC) Received: from localhost ([::1]:38810 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1fV6qs-0008BZ-LH for patchwork-qemu-devel@patchwork.kernel.org; Mon, 18 Jun 2018 22:58:38 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:49493) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1fV5v1-0003K3-Kq for qemu-devel@nongnu.org; Mon, 18 Jun 2018 21:58:52 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1fV5ux-0005lc-PT for qemu-devel@nongnu.org; Mon, 18 Jun 2018 21:58:51 -0400 Received: from mail-it0-x244.google.com ([2607:f8b0:4001:c0b::244]:54968) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1fV5ux-0005lH-K7 for qemu-devel@nongnu.org; Mon, 18 Jun 2018 21:58:47 -0400 Received: by mail-it0-x244.google.com with SMTP id 76-v6so14949846itx.4 for ; Mon, 18 Jun 2018 18:58:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=s8l4GvO+eAVsnjCXJrvqr4SQNzn6Kendmb1zEHX7wHw=; b=QQItlYJhXICAmun1EJUyQzvb3qUd92zC+UDtWbIPHmDBNYkeu5bSZHbnAfxiwhQz9e G7ca8KeMtwpfvbtMQk4xTh2g94TNNoq6c9+BPSLSuTeBKvtsMiIpkuFjhdrjg9sIaW3/ CXib0UuMhPYhiS3jcAVBNBfBGNv7CZIo8f8RC9ScyP2xUvRBBOmQr8p7VSmIBuTXfwvp L0AT/nRBSxVuVtN3WZRYDJInktk3CLTmMaHMcEO15l1IxANA1EMQraxBW8lQZF7B1BPK 4ulLkFfwWaUUIWFhxLmFKYN+yaw/1+k1BwLJsupmyvADMD78Rblh+ufE1mBoRlTY/AJ+ j76w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=s8l4GvO+eAVsnjCXJrvqr4SQNzn6Kendmb1zEHX7wHw=; b=o5yMwzlBMMD2/+Kek7AfjqHUzi3zm6mcdFZSfZonp8QzOblKYMjKbsQ+bW8+xd8p0Z OFEoNPjMJHklLhZULcpAj1I9I79AX1KypU4GDnw3IotUPVqNUZvBsxJLgZbtO7tgi7fM aRB+0fBj79jjL58+pk+A3AOpkGv6aiBjbU7yc6wLr1HQsMFDXHi/Fbkeesk837oYW/dH Xy7v8SOTyttSzyzEdBIxxoKiF9Qlyu0msdL0KE8FB5fGHkf995xED9WAbz49LbNsn07r 8is21O6ROfKuVTQhTuazonw+lXshjJYC+o+bIQCI4udpAmVPSa3k+F6LuUYdOz+AL3Ui QlIA== X-Gm-Message-State: APt69E3AybT6BxJjWErQ29bLNEnP2Q/xEt9IhHbeIQAfJCe5Wf+TFiG0 rYz9/+nyAvyUG6mgujsfIdo= X-Google-Smtp-Source: ADUXVKJzEil0LbutA3QaIbujLUYde5S7AkcigOZbRD57+DSj7PyMnYrkLQdv0OkaY4sr/v3dNXFGTg== X-Received: by 2002:a24:3c8:: with SMTP id e191-v6mr12321771ite.70.1529373526887; Mon, 18 Jun 2018 18:58:46 -0700 (PDT) Received: from localhost.localdomain ([69.14.184.20]) by smtp.gmail.com with ESMTPSA id g17-v6sm4331494iti.1.2018.06.18.18.58.45 (version=TLS1 cipher=AES128-SHA bits=128/128); Mon, 18 Jun 2018 18:58:46 -0700 (PDT) From: John Arbuckle To: peter.maydell@linaro.org, qemu-devel@nongnu.org Date: Mon, 18 Jun 2018 21:58:32 -0400 Message-Id: <20180619015832.7398-1-programmingkidx@gmail.com> X-Mailer: git-send-email 2.14.3 (Apple Git-98) X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2607:f8b0:4001:c0b::244 Subject: [Qemu-devel] [PATCH] ui/cocoa.m: prevent stuck command key when going into full screen mode X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: John Arbuckle Errors-To: qemu-devel-bounces+patchwork-qemu-devel=patchwork.kernel.org@nongnu.org Sender: "Qemu-devel" X-Virus-Scanned: ClamAV using ClamSMTP When the user pushes Command-F in QEMU while the mouse is ungrabbed, QEMU goes into full screen mode. When the user finally releases the command key, it is sent to the guest as an event. The makes the guest operating system think the command key is down when it is really up. To prevent this situation from happening, we simply drop the first command key event after the user has gone into full screen mode using Command-F. Signed-off-by: John Arbuckle --- ui/cocoa.m | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/ui/cocoa.m b/ui/cocoa.m index 2991ed4..024aba2 100644 --- a/ui/cocoa.m +++ b/ui/cocoa.m @@ -287,6 +287,7 @@ static void handleAnyDeviceErrors(Error * err) BOOL isFullscreen; BOOL isAbsoluteEnabled; BOOL isMouseDeassociated; + BOOL prevent_stuck_command_key; } - (void) switchSurface:(DisplaySurface *)surface; - (void) grabMouse; @@ -330,7 +331,7 @@ QemuCocoaView *cocoaView; screen.bitsPerPixel = 32; screen.width = frameRect.size.width; screen.height = frameRect.size.height; - + prevent_stuck_command_key = NO; } return self; } @@ -552,6 +553,14 @@ QemuCocoaView *cocoaView; } - (void) toggleModifier: (int)keycode { + + /* Prevents the command key from being sent to the guest */ + if ((keycode == Q_KEY_CODE_META_L || keycode == Q_KEY_CODE_META_R) && + prevent_stuck_command_key == YES) { + prevent_stuck_command_key = NO; + return; + } + // Toggle the stored state. modifiers_state[keycode] = !modifiers_state[keycode]; // Send a keyup or keydown depending on the state. @@ -691,6 +700,13 @@ QemuCocoaView *cocoaView; // forward command key combos to the host UI unless the mouse is grabbed if (!isMouseGrabbed && ([event modifierFlags] & NSEventModifierFlagCommand)) { + /* + * Prevent the command key from being stuck down in the guest + * when using Command-F for full screen mode + */ + if (keycode == Q_KEY_CODE_F) { + prevent_stuck_command_key = YES; + } [NSApp sendEvent:event]; return; }