* Re: feature/android a496509ced 1/2: Update Android port [not found] ` <20230119142043.05B19C00613@vcs2.savannah.gnu.org> @ 2023-08-16 12:12 ` Stefan Monnier 2023-08-16 12:21 ` Po Lu 0 siblings, 1 reply; 9+ messages in thread From: Stefan Monnier @ 2023-08-16 12:12 UTC (permalink / raw) To: Po Lu; +Cc: emacs-devel Hi Po Lu, Po Lu via Mailing list for Emacs changes [2023-01-19 09:20:42] wrote: > branch: feature/android > commit a496509cedb17109d0e6297a74e2ff8ed526333c > Author: Po Lu <luangruo@yahoo.com> > Commit: Po Lu <luangruo@yahoo.com> > > Update Android port [...] > * lisp/subr.el (event-start): > (event-end): Handle touchscreen events. > * lisp/touch-screen.el (touch-screen-handle-timeout): > (touch-screen-handle-point-update): > (touch-screen-handle-point-up): > (touch-screen-track-tap): > (touch-screen-track-drag): > (touch-screen-drag-mode-line-1): > (touch-screen-drag-mode-line): New functions. > ([mode-line touchscreen-begin]): > ([bottom-divider touchscreen-begin]): Bind new events. > > * lisp/wid-edit.el (widget-event-point): > (widget-keymap): > (widget-event-start): > (widget-button--check-and-call-button): > (widget-button-click): Improve touchscreen support. [...] > diff --git a/lisp/subr.el b/lisp/subr.el > index f909b63aab..345816dbd2 100644 > --- a/lisp/subr.el > +++ b/lisp/subr.el > @@ -1636,7 +1636,13 @@ nil or (STRING . POSITION)'. > `posn-timestamp': The time the event occurred, in milliseconds. > > For more information, see Info node `(elisp)Click Events'." > - (or (and (consp event) (nth 1 event)) > + (or (and (consp event) > + ;; Ignore touchscreen events. They store the posn in a > + ;; different format, and can have multiple posns. > + (not (memq (car event) '(touchscreen-begin > + touchscreen-update > + touchscreen-end))) > + (nth 1 event)) > (event--posn-at-point))) > > (defun event-end (event) > @@ -1644,7 +1650,11 @@ For more information, see Info node `(elisp)Click Events'." > EVENT should be a click, drag, or key press event. > > See `event-start' for a description of the value returned." > - (or (and (consp event) (nth (if (consp (nth 2 event)) 2 1) event)) > + (or (and (consp event) > + (not (memq (car event) '(touchscreen-begin > + touchscreen-update > + touchscreen-end))) > + (nth (if (consp (nth 2 event)) 2 1) event)) > (event--posn-at-point))) > > (defsubst event-click-count (event) [...] > diff --git a/lisp/wid-edit.el b/lisp/wid-edit.el > index 60bd2baa6f..4c52d82798 100644 > --- a/lisp/wid-edit.el > +++ b/lisp/wid-edit.el > @@ -65,8 +65,11 @@ > ;;; Compatibility. > > (defun widget-event-point (event) > - "Character position of the end of event if that exists, or nil." > - (posn-point (event-end event))) > + "Character position of the end of event if that exists, or nil. > +EVENT can either be a mouse event or a touch screen event." > + (if (eq (car-safe event) 'touchscreen-begin) > + (posn-point (cdadr event)) > + (posn-point (event-end event)))) > > (defun widget-button-release-event-p (event) > "Non-nil if EVENT is a mouse-button-release event object." [...] > @@ -1072,8 +1076,18 @@ Note that such modes will need to require wid-edit.") > "If non-nil, `widget-button-click' moves point to a button after invoking it. > If nil, point returns to its original position after invoking a button.") > > +(defun widget-event-start (event) > + "Return the start of EVENT. > +If EVENT is not a touchscreen event, simply return its > +`event-start'. Otherwise, it is a touchscreen event, so return > +the posn of its touchpoint." > + (if (eq (car event) 'touchscreen-begin) > + (cdadr event) > + (event-start event))) Could you explain why for touchscreen events you made `event-end` and `event-start` return "posn-at-point" (which seems positively useless), forcing you in turn to add ad-hoc handling in `widget-event-point` and to introduce a new `widget-event-start`? I understand that touchscreen events may have multiple posns, but it seems that making `event-end` and `event-start` do what `widget-event-point` and `widget-event-start` do would be better than what we have now, no? Stefan ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 12:12 ` feature/android a496509ced 1/2: Update Android port Stefan Monnier @ 2023-08-16 12:21 ` Po Lu 2023-08-16 12:35 ` Stefan Monnier 0 siblings, 1 reply; 9+ messages in thread From: Po Lu @ 2023-08-16 12:21 UTC (permalink / raw) To: Stefan Monnier; +Cc: emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: > Could you explain why for touchscreen events you made `event-end` and > `event-start` return "posn-at-point" (which seems positively useless), > forcing you in turn to add ad-hoc handling in `widget-event-point` and > to introduce a new `widget-event-start`? Actually, the cdadr of a touchscreen-begin or touchscreen-end event is its mouse position list. > I understand that touchscreen events may have multiple posns, but it > seems that making `event-end` and `event-start` do what > `widget-event-point` and `widget-event-start` do would be better than > what we have now, no? I recall moving the code for processing touch screen events from widget.el to subr.el. I probably neglected to remove the old code from widget.el in the process. Thanks. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 12:21 ` Po Lu @ 2023-08-16 12:35 ` Stefan Monnier 2023-08-16 12:41 ` Po Lu 0 siblings, 1 reply; 9+ messages in thread From: Stefan Monnier @ 2023-08-16 12:35 UTC (permalink / raw) To: Po Lu; +Cc: emacs-devel Po Lu [2023-08-16 20:21:33] wrote: > Stefan Monnier <monnier@iro.umontreal.ca> writes: >> Could you explain why for touchscreen events you made `event-end` and >> `event-start` return "posn-at-point" (which seems positively useless), >> forcing you in turn to add ad-hoc handling in `widget-event-point` and >> to introduce a new `widget-event-start`? > > Actually, the cdadr of a touchscreen-begin or touchscreen-end event is > its mouse position list. Does that mean that `widget-event-start` doesn't always return a `posn`? If so, could you add some comments explaining what's going on and why it's done this way? >> I understand that touchscreen events may have multiple posns, but it >> seems that making `event-end` and `event-start` do what >> `widget-event-point` and `widget-event-start` do would be better than >> what we have now, no? > I recall moving the code for processing touch screen events from > widget.el to subr.el. AFAICT the code for `event-start/end` in `master` has not been changed since the above commit. Stefan ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 12:35 ` Stefan Monnier @ 2023-08-16 12:41 ` Po Lu 2023-08-16 13:44 ` Stefan Monnier 0 siblings, 1 reply; 9+ messages in thread From: Po Lu @ 2023-08-16 12:41 UTC (permalink / raw) To: Stefan Monnier; +Cc: emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: > Does that mean that `widget-event-start` doesn't always return a `posn`? > If so, could you add some comments explaining what's going on and why > it's done this way? Oh no, I meant that touchscreen-begin events actually appear like so: (touchscreen-begin (NUM . EVENT-START)) where the cdadr, EVENT-START, is the mouse position list, and NUM is the touch identification number. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 12:41 ` Po Lu @ 2023-08-16 13:44 ` Stefan Monnier 2023-08-16 14:15 ` Po Lu 0 siblings, 1 reply; 9+ messages in thread From: Stefan Monnier @ 2023-08-16 13:44 UTC (permalink / raw) To: Po Lu; +Cc: emacs-devel >> Does that mean that `widget-event-start` doesn't always return a `posn`? >> If so, could you add some comments explaining what's going on and why >> it's done this way? > > Oh no, I meant that touchscreen-begin events actually appear like so: > > (touchscreen-begin (NUM . EVENT-START)) > > where the cdadr, EVENT-START, is the mouse position list, and NUM is the > touch identification number. I don't really understand how this answers my question. Is "the mouse position list" an "posn"? If yes, then why doesn't `event-start/end` return it? Stefan ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 13:44 ` Stefan Monnier @ 2023-08-16 14:15 ` Po Lu 2023-08-16 15:03 ` Stefan Monnier 0 siblings, 1 reply; 9+ messages in thread From: Po Lu @ 2023-08-16 14:15 UTC (permalink / raw) To: Stefan Monnier; +Cc: emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: > I don't really understand how this answers my question. > Is "the mouse position list" an "posn"? Yes. We refer to "posns" as mouse position lists. > If yes, then why doesn't `event-start/end` return it? It does, so I've removed the redundant code from widget.el. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 14:15 ` Po Lu @ 2023-08-16 15:03 ` Stefan Monnier 2023-08-17 0:30 ` Po Lu 0 siblings, 1 reply; 9+ messages in thread From: Stefan Monnier @ 2023-08-16 15:03 UTC (permalink / raw) To: Po Lu; +Cc: emacs-devel >> I don't really understand how this answers my question. >> Is "the mouse position list" an "posn"? > Yes. We refer to "posns" as mouse position lists. Ah, great, thanks. >> If yes, then why doesn't `event-start/end` return it? > It does, so I've removed the redundant code from widget.el. Where? The code I see on `master` is: (defun event-end (event) "Return the ending position of EVENT. EVENT should be a click, drag, or key press event. See `event-start' for a description of the value returned." (declare (side-effect-free t)) (or (and (consp event) (not (memq (car event) '(touchscreen-begin touchscreen-update touchscreen-end))) (nth (if (consp (nth 2 event)) 2 1) event)) (event--posn-at-point))) so for `touchscreen-begin` we return (event--posn-at-point). What am I missing? Stefan ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-16 15:03 ` Stefan Monnier @ 2023-08-17 0:30 ` Po Lu 2023-08-17 3:02 ` Stefan Monnier 0 siblings, 1 reply; 9+ messages in thread From: Po Lu @ 2023-08-17 0:30 UTC (permalink / raw) To: Stefan Monnier; +Cc: emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: >>> I don't really understand how this answers my question. >>> Is "the mouse position list" an "posn"? >> Yes. We refer to "posns" as mouse position lists. > > Ah, great, thanks. > >>> If yes, then why doesn't `event-start/end` return it? >> It does, so I've removed the redundant code from widget.el. > > Where? > > The code I see on `master` is: > > (defun event-end (event) > "Return the ending position of EVENT. > EVENT should be a click, drag, or key press event. > > See `event-start' for a description of the value returned." > (declare (side-effect-free t)) > (or (and (consp event) > (not (memq (car event) '(touchscreen-begin > touchscreen-update > touchscreen-end))) > (nth (if (consp (nth 2 event)) 2 1) event)) > (event--posn-at-point))) > > so for `touchscreen-begin` we return (event--posn-at-point). > What am I missing? > > > Stefan That's simply an omission on my fault, which I apologize for. I'll fix it ASAP. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: feature/android a496509ced 1/2: Update Android port 2023-08-17 0:30 ` Po Lu @ 2023-08-17 3:02 ` Stefan Monnier 0 siblings, 0 replies; 9+ messages in thread From: Stefan Monnier @ 2023-08-17 3:02 UTC (permalink / raw) To: Po Lu; +Cc: emacs-devel > That's simply an omission on my fault, Ah, good. > which I apologize for. No harm. > I'll fix it ASAP. Thanks, Stefan ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2023-08-17 3:02 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- [not found] <167413804086.19235.17391196197706660128@vcs2.savannah.gnu.org> [not found] ` <20230119142043.05B19C00613@vcs2.savannah.gnu.org> 2023-08-16 12:12 ` feature/android a496509ced 1/2: Update Android port Stefan Monnier 2023-08-16 12:21 ` Po Lu 2023-08-16 12:35 ` Stefan Monnier 2023-08-16 12:41 ` Po Lu 2023-08-16 13:44 ` Stefan Monnier 2023-08-16 14:15 ` Po Lu 2023-08-16 15:03 ` Stefan Monnier 2023-08-17 0:30 ` Po Lu 2023-08-17 3:02 ` Stefan Monnier
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).