From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: Eli Zaretskii Newsgroups: gmane.emacs.devel Subject: Re: Context menus and mouse-3 Date: Wed, 14 Jul 2021 00:30:54 -0400 Message-ID: References: <20200914061111.3trmuzhdvv7nwdcc@Ergus> <87y2acv2tw.fsf@mail.linkov.net> <83zguragqj.fsf@gnu.org> <87pmvnuyug.fsf@mail.linkov.net> <83zguq8n5o.fsf@gnu.org> <87im1dydhx.fsf@mail.linkov.net> Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214"; logging-data="20816"; mail-complaints-to="usenet@ciao.gmane.io" Cc: philipk@posteo.net, rms@gnu.org, spacibba@aol.com, emacs-devel@gnu.org, monnier@iro.umontreal.ca, arthur.miller@live.com, dgutov@yandex.ru, ghe@sdf.org, drew.adams@oracle.com To: Juri Linkov Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Wed Jul 14 06:32:51 2021 Return-path: Envelope-to: ged-emacs-devel@m.gmane-mx.org Original-Received: from lists.gnu.org ([209.51.188.17]) by ciao.gmane.io with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1m3WZn-0005Gl-R5 for ged-emacs-devel@m.gmane-mx.org; Wed, 14 Jul 2021 06:32:51 +0200 Original-Received: from localhost ([::1]:35452 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1m3WZm-0006Yr-4e for ged-emacs-devel@m.gmane-mx.org; Wed, 14 Jul 2021 00:32:50 -0400 Original-Received: from eggs.gnu.org ([2001:470:142:3::10]:42008) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1m3WY8-0003DA-Gm for emacs-devel@gnu.org; Wed, 14 Jul 2021 00:31:08 -0400 Original-Received: from fencepost.gnu.org ([2001:470:142:3::e]:57366) by eggs.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1m3WY3-00065F-TO; Wed, 14 Jul 2021 00:31:03 -0400 Original-Received: from eliz by fencepost.gnu.org with local (Exim 4.90_1) (envelope-from ) id 1m3WXu-00089Y-A2; Wed, 14 Jul 2021 00:30:54 -0400 In-Reply-To: <87im1dydhx.fsf@mail.linkov.net> (message from Juri Linkov on Wed, 14 Jul 2021 02:46:27 +0300) X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Original-Sender: "Emacs-devel" Xref: news.gmane.io gmane.emacs.devel:271209 Archived-At: > From: Juri Linkov > Cc: monnier@iro.umontreal.ca, philipk@posteo.net, rms@gnu.org, > spacibba@aol.com, emacs-devel@gnu.org, arthur.miller@live.com, > dgutov@yandex.ru, ghe@sdf.org, drew.adams@oracle.com > Date: Wed, 14 Jul 2021 02:46:27 +0300 > > > Can't we decide which effect is TRT based on where the user clicks? > > Context menus are available only in special places, and it would seem > > that setting the region in those places doesn't make sense, by and > > large. > > Context menus are useful everywhere, not just in special places. > For example, selecting "Paste" from the context menu makes sense > everywhere. Where in Emacs do we have context menus which include "Paste"? I thought we were talking about existing menus popped by mouse-2 that you'd like to pop up with mouse-3. If this isn't the case, then what menus are we talking about here? In particular, if you want to _add_ menus which currently don't exist in contexts where we currently don't offer menus, that could be an entirely new minor mode, and then the conflict with current bindings of mouse-3 could be resolved as part of that mode. > > And if sometimes we cannot dwim there, how about making the defcustom > > you introduced to allow the users to express their preferences in > > these problematic cases? > > In the previous patch, the defcustom is named mouse-3-down-context-menu. > When it's customized to nil, then only the current behavior is available > with mouse-save-then-kill. When customized to t, then the context menu > pops up immediately. I was thinking about something more flexible than an all-or-nothing setting. A delay is not really intelligent enough, since it again is a global value. I was thinking about something sensitive to the context. > > If the above makes sense, I think it's a better solution than forcing > > this feature on everyone. I would be surprised if holding the mouse > > button for several hundreds of milliseconds would suddenly produce an > > entirely different and unrelated effect, and I'd probably be annoyed > > by the need to hold the button when I _know_ I want the context menu. > > So it sounds like this implementation is sub-optimal from the get-go, > > and we should try looking for a better one. > > We can add as many options as necessary to cater for all needs, > but the question is about the default behavior. The proposed delay is > a middle ground before the user decides which behavior is more preferable. The default you suggest strikes me as inappropriate. It is definitely backward incompatible and confusing. > > We could also consider an even more radical solution: an option to > > swap mouse-2 and mouse-3. Because isn't it true that people who > > expect context menus to pop up when mouse-3 is pressed generally don't > > expect and don't use region-related mouse clicks at all? (We have > > such a "swap-buttons" variable specific to MS-Windows, and I've been > > using it for eons, because clicking mouse-2 on a wheeled mouse is very > > inconvenient.) > > This is not backward-compatibile change of the default behavior. An opt-in behavior is by definition always backward-compatible.