GNU bug report logs - #79032
30.1; Stylus (Wacom Pen) Support under Wayland

Previous Next

Package: emacs;

Reported by: Justus-dev <at> Piater.name

Date: Wed, 16 Jul 2025 15:50:02 UTC

Severity: normal

Found in version 30.1

Full log


Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):

From: Justus-dev <at> Piater.name
To: bug-gnu-emacs <at> gnu.org
Subject: 30.1; Stylus (Wacom Pen) Support under Wayland
Date: Wed, 16 Jul 2025 17:48:58 +0200
In a text-mode buffer I'd generally expect the stylus to behave like the
mouse-1 button (press-drag-release highlights a text region), but it
does not. In the following, "cursor" refers to Emacs' text cursor, and
"pointer" refers to the graphical pointer controlled by the mouse and
the stylus.

1. Start emacs -Q in a Wayland session. In the *scratch* buffer:

2. Use the mouse to move the pointer over a text character (without
   pressing a button).

3. Tap a different character with the stylus (pen-down).

   Expected effect: The cursor is placed at the pen-down location.

   Actual effect: The cursor is placed at the location where the pointer
   was before pen-down, and the region of text between cursor and
   pointer (now at the pen-down location) is highlighted.

4. Drag the stylus.

   Expected effect: Pointer and cursor follow the stylus, and the region
   between pen-down and cursor is highlighted.

   Actual effect: Pointer follows stylus, but cursor and highlighted
   region remain unchanged.

5. Lift the stylus (pen-up).

   Expected and actual effect: The cursor is located at the pen-up
   location, and the region between pen-down and pen-up is highlighted.

6. Iterate Steps 3-5. The above description always holds. In particular,
   at Step 3, "the location where the pointer was before pen-down" is

   if the mouse was moved since the preceding pen-up (as in Step 2):
     the pointer location where the mouse left it before pen-down,

   otherwise:
     the preceding pen-up location.

   Both are, of course, unexpected behavior.

After Steps 1-5, C-h l gives me the following:

 <help-echo> <down-mouse-1> ;; mouse-drag-region
 <mouse-movement>	    ;; anonymous-command
 ... [repeats many times]
 <mouse-movement>	    ;; anonymous-command
 <drag-mouse-1>		    ;; mouse-set-region
 C-h l			    ;; view-lossage

This behavior makes it impossible to use the stylus for drawing inside
Emacs, e.g. using artist-mode or el-easydraw
(https://github.com/misohena/el-easydraw/issues/40).

This behavior appears to be specific to Wayland, perhaps even to my
compositor (swaywm). In particular, X (by default) appears to treat the
stylus like the mouse:

- xev (running under Xwayland) reports stylus interactions as mouse
  events, but wev reports stylus interactions as "zwp_tablet_tool_v2"
  events.

- If I run Emacs under Xwayland (GDK_BACKEND=X11 emacs -Q), the stylus
  behaves identically to the mouse.

Thus, for starters, it would be interesting if other Wayland users,
using the same or different compositors, observe the same behavior.


In GNU Emacs 30.1 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.24.49,
cairo version 1.18.4)
System Description: Arch Linux

Configured using:
 'configure --with-pgtk --sysconfdir=/etc --prefix=/usr
 --libexecdir=/usr/lib --localstatedir=/var --disable-build-details
 --with-cairo --with-harfbuzz --with-libsystemd --with-modules
 --with-native-compilation=aot --with-tree-sitter 'CFLAGS=-march=x86-64
 -mtune=generic -O2 -pipe -fno-plt -fexceptions -Wp,-D_FORTIFY_SOURCE=3
 -Wformat -Werror=format-security -fstack-clash-protection
 -fcf-protection -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer -g
 -ffile-prefix-map=/build/emacs/src=/usr/src/debug/emacs -flto=auto'
 'LDFLAGS=-Wl,-O1 -Wl,--sort-common -Wl,--as-needed -Wl,-z,relro
 -Wl,-z,now -Wl,-z,pack-relative-relocs -flto=auto'
 'CXXFLAGS=-march=x86-64 -mtune=generic -O2 -pipe -fno-plt -fexceptions
 -Wp,-D_FORTIFY_SOURCE=3 -Wformat -Werror=format-security
 -fstack-clash-protection -fcf-protection -fno-omit-frame-pointer
 -mno-omit-leaf-frame-pointer -Wp,-D_GLIBCXX_ASSERTIONS -g
 -ffile-prefix-map=/build/emacs/src=/usr/src/debug/emacs -flto=auto''

Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
LCMS2 LIBOTF LIBSYSTEMD LIBXML2 MODULES NATIVE_COMP NOTIFY INOTIFY
PDUMPER PGTK PNG RSVG SECCOMP SOUND SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS TREE_SITTER WEBP XIM GTK3 ZLIB

Important settings:
  value of $LC_COLLATE: de_AT.UTF-8
  value of $LC_MONETARY: de_AT.UTF-8
  value of $LC_TIME: de_AT.UTF-8
  value of $LANG: en_US.UTF-8
  locale-coding-system: utf-8-unix

Major mode: Help

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  show-paren-mode: t
  electric-indent-mode: t
  mouse-wheel-mode: t
  tool-bar-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  isearch-fold-quotes-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  minibuffer-regexp-mode: t
  buffer-read-only: t
  line-number-mode: t
  indent-tabs-mode: t
  transient-mark-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message mailcap yank-media puny dired
dired-loaddefs rfc822 mml mml-sec password-cache epa derived epg rfc6068
epg-config gnus-util text-property-search time-date subr-x mm-decode
mm-bodies mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader
sendmail rfc2047 rfc2045 ietf-drums mm-util mail-prsvr mail-utils
help-mode cl-loaddefs cl-lib rmc iso-transl tooltip cconv eldoc paren
electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode mwheel
term/pgtk-win pgtk-win term/common-win touch-screen pgtk-dnd tool-bar
dnd fontset image regexp-opt fringe tabulated-list replace newcomment
text-mode lisp-mode prog-mode register page tab-bar menu-bar rfn-eshadow
isearch easymenu timer select scroll-bar mouse jit-lock font-lock syntax
font-core term/tty-colors frame minibuffer nadvice seq simple cl-generic
indonesian philippine cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew greek
romanian slovak czech european ethiopic indian cyrillic chinese
composite emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button loaddefs
theme-loaddefs faces cus-face macroexp files window text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget keymap
hashtable-print-readable backquote threads dbusbind inotify
dynamic-setting system-font-setting font-render-setting cairo gtk pgtk
lcms2 multi-tty move-toolbar make-network-process native-compile emacs)

Memory information:
((conses 16 53221 8904) (symbols 48 5611 0) (strings 32 14333 3337)
 (string-bytes 1 471846) (vectors 16 9250)
 (vector-slots 8 128560 7593) (floats 8 26 35) (intervals 56 286 4)
 (buffers 992 12))




This bug report was last modified today.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.