* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
@ 2024-12-24 5:43 Len Trigg
2024-12-25 11:54 ` Eli Zaretskii
2024-12-27 6:04 ` Gerd Möllmann
0 siblings, 2 replies; 21+ messages in thread
From: Len Trigg @ 2024-12-24 5:43 UTC (permalink / raw)
To: 75056
[-- Attachment #1.1: Type: text/plain, Size: 5385 bytes --]
tty-child-frames does not seem to play well with multiple clients. When we
run server-start and allow emacs to have multiple clients (e.g. an initial
"emacs -nw" and an
"emacsclient -nw"), using a function that utilizes tty-child-frame (such as
M-x when vertico-posframe is loaded) in one frame leads the other client to
be locked up.
Steps to reproduce:
mkdir ~/emacs-test
Copy the attached init.el into ~/emacs-test/
emacs -nw --init-directory=~/emacs-test (the first time will result in
packages being installed by elpaca)
(in another terminal) emacsclient -nw
Do something to invoke the child frame pop up (e.g. C-x b and select a
buffer)
Switch back to the original emacs
Do something to invoke the child frame pop up (e.g. C-x b and select a
buffer)
Swap to the other terminal, and note that at some point one client will
stop responding
to user input. (It may take a couple of tries, perhaps with other regular
commands interspersed).
When one client is locked, swap back to the other terminal and exit the
client - the original
client will now accept user input.
When a client is locked it *does* accept some input (e.g. C-x C-c will exit
the client)
It's possible this is vertico-posframe related, as I can't trigger similar
behaviour using transient-posframe.
In GNU Emacs 31.0.50 (build 1, x86_64-pc-linux-gnu, GTK+ Version
3.24.41, cairo version 1.18.0) of 2024-12-24 built on kaka
Repository revision: 6ac38396898e6324d4c6dddb2ad05d1ad0dc5e7c
Repository branch: master
System Description: Ubuntu 24.04.1 LTS
Configured using:
'configure --prefix=/home/len/.local --with-rsvg --with-cairo
--with-native-compilation --with-tree-sitter --with-modules'
Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
LCMS2 LIBOTF LIBSELINUX LIBSYSTEMD LIBXML2 M17N_FLT MODULES NATIVE_COMP
NOTIFY INOTIFY PDUMPER PNG RSVG SECCOMP SOUND SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS TREE_SITTER WEBP X11 XDBE XIM XINPUT2 XPM GTK3 ZLIB
Important settings:
value of $LC_MONETARY: en_AU.UTF-8
value of $LC_NUMERIC: en_AU.UTF-8
value of $LC_TIME: en_AU.UTF-8
value of $LANG: en_US.UTF-8
value of $XMODIFIERS: @im=ibus
locale-coding-system: utf-8-unix
Major mode: Fundamental
Minor modes in effect:
xterm-mouse-mode: t
server-mode: t
vertico-posframe-mode: t
vertico-mode: t
elpaca-use-package-mode: t
override-global-mode: t
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
global-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 compile comint ansi-osc ansi-color ring comp-run
comp-common rx emacsbug message yank-media puny dired dired-loaddefs
rfc822 mml mml-sec epa derived epg rfc6068 epg-config gnus-util
text-property-search time-date mm-decode mm-bodies mm-encode mail-parse
rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047 rfc2045
ietf-drums mm-util mail-prsvr mail-utils xt-mouse term/xterm xterm
server vertico-posframe vertico-multiform vertico compat posframe
vertico-posframe-autoloads vertico-autoloads posframe-autoloads cl-extra
help-mode elpaca-use-package use-package use-package-ensure
use-package-delight use-package-diminish use-package-bind-key bind-key
easy-mmode use-package-core elpaca-use-package-autoloads elpaca-log
elpaca-ui elpaca-menu-elpa elpaca-menu-melpa url url-proxy url-privacy
url-expand url-methods url-history url-cookie generate-lisp-file
url-domsuf url-util url-parse auth-source cl-seq eieio eieio-core
cl-macs password-cache json subr-x map byte-opt gv bytecomp byte-compile
url-vars mailcap elpaca-menu-org elpaca warnings icons elpaca-process
cl-loaddefs cl-lib elpaca-autoloads rmc iso-transl tooltip cconv eldoc
paren electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode
mwheel term/x-win x-win term/common-win x-dnd touch-screen 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 lcms2
dynamic-setting system-font-setting font-render-setting cairo gtk
x-toolkit xinput2 x multi-tty move-toolbar make-network-process
tty-child-frames native-compile emacs)
Memory information:
((conses 16 396223 19518) (symbols 48 15669 0)
(strings 32 187599 3392) (string-bytes 1 2901786) (vectors 16 17588)
(vector-slots 8 194405 8250) (floats 8 78 41) (intervals 56 346 0)
(buffers 992 19))
[-- Attachment #1.2: Type: text/html, Size: 5923 bytes --]
[-- Attachment #2: init.el --]
[-- Type: text/x-emacs-lisp, Size: 3630 bytes --]
;;; init.el --- Emacs initialization
;;; Code:
;; elpaca boilerplate ;;
(setq package-enable-at-startup nil)
;; Use elpaca rather than package.el, it gives better control over package versions
(defvar elpaca-installer-version 0.8)
(defvar elpaca-directory (expand-file-name "elpaca/" user-emacs-directory))
(defvar elpaca-builds-directory (expand-file-name "builds/" elpaca-directory))
(defvar elpaca-repos-directory (expand-file-name "repos/" elpaca-directory))
(defvar elpaca-order '(elpaca :repo "https://github.com/progfolio/elpaca.git"
:ref nil :depth 1
:files (:defaults "elpaca-test.el" (:exclude "extensions"))
:build (:not elpaca--activate-package)))
(let* ((repo (expand-file-name "elpaca/" elpaca-repos-directory))
(build (expand-file-name "elpaca/" elpaca-builds-directory))
(order (cdr elpaca-order))
(default-directory repo))
(add-to-list 'load-path (if (file-exists-p build) build repo))
(unless (file-exists-p repo)
(make-directory repo t)
(when (< emacs-major-version 28) (require 'subr-x))
(condition-case-unless-debug err
(if-let* ((buffer (pop-to-buffer-same-window "*elpaca-bootstrap*"))
((zerop (apply #'call-process `("git" nil ,buffer t "clone"
,@(when-let* ((depth (plist-get order :depth)))
(list (format "--depth=%d" depth) "--no-single-branch"))
,(plist-get order :repo) ,repo))))
((zerop (call-process "git" nil buffer t "checkout"
(or (plist-get order :ref) "--"))))
(emacs (concat invocation-directory invocation-name))
((zerop (call-process emacs nil buffer nil "-Q" "-L" "." "--batch"
"--eval" "(byte-recompile-directory \".\" 0 'force)")))
((require 'elpaca))
((elpaca-generate-autoloads "elpaca" repo)))
(progn (message "%s" (buffer-string)) (kill-buffer buffer))
(error "%s" (with-current-buffer buffer (buffer-string))))
((error) (warn "%s" err) (delete-directory repo 'recursive))))
(unless (require 'elpaca-autoloads nil t)
(require 'elpaca)
(elpaca-generate-autoloads "elpaca" repo)
(load "./elpaca-autoloads")))
(add-hook 'after-init-hook #'elpaca-process-queues)
(elpaca `(,@elpaca-order))
;; Install use-package support
(elpaca elpaca-use-package
;; Enable :elpaca use-package keyword.
(elpaca-use-package-mode)
;; Assume :elpaca t unless otherwise specified.
(setq elpaca-use-package-by-default t))
;; Block until current queue processed.
(elpaca-wait)
;; (setq custom-file (expand-file-name "custom.el" user-emacs-directory))
;; (add-hook 'elpaca-after-init-hook (lambda () (load custom-file 'noerror)))
(use-package posframe
;;:config
;;(setq posframe-mouse-banish nil)
)
(use-package vertico-posframe
:after posframe vertico
:config
(push '(tty-non-selected-cursor . t) vertico-posframe-parameters)
(push '(background-color . "black") vertico-posframe-parameters)
(push '(undecorated . nil) vertico-posframe-parameters)
(vertico-posframe-mode))
(use-package vertico
:init
(vertico-mode)
;;(advice-add #'tmm-add-prompt :after #'minibuffer-hide-completions)
;; (setq
;; vertico-resize nil
;; vertico-cycle t)
)
(use-package server
:ensure nil
:hook (elpaca-after-init . server-start))
;;; init.el ends here
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-24 5:43 bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs Len Trigg
@ 2024-12-25 11:54 ` Eli Zaretskii
2024-12-25 11:59 ` Gerd Möllmann
2024-12-27 6:04 ` Gerd Möllmann
1 sibling, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-25 11:54 UTC (permalink / raw)
To: Len Trigg, Gerd Möllmann; +Cc: 75056
> From: Len Trigg <lenbok@gmail.com>
> Date: Tue, 24 Dec 2024 18:43:29 +1300
>
> tty-child-frames does not seem to play well with multiple clients. When we run server-start and allow emacs to
> have multiple clients (e.g. an initial "emacs -nw" and an
> "emacsclient -nw"), using a function that utilizes tty-child-frame (such as M-x when vertico-posframe is
> loaded) in one frame leads the other client to be locked up.
>
> Steps to reproduce:
>
> mkdir ~/emacs-test
> Copy the attached init.el into ~/emacs-test/
> emacs -nw --init-directory=~/emacs-test (the first time will result in packages being installed by elpaca)
> (in another terminal) emacsclient -nw
> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
> Switch back to the original emacs
> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
> Swap to the other terminal, and note that at some point one client will stop responding
> to user input. (It may take a couple of tries, perhaps with other regular commands interspersed).
> When one client is locked, swap back to the other terminal and exit the client - the original
> client will now accept user input.
>
> When a client is locked it *does* accept some input (e.g. C-x C-c will exit the client)
>
> It's possible this is vertico-posframe related, as I can't trigger similar behaviour using transient-posframe.
Gerd, could you perhaps look into this?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-25 11:54 ` Eli Zaretskii
@ 2024-12-25 11:59 ` Gerd Möllmann
0 siblings, 0 replies; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-25 11:59 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Len Trigg, 75056
Eli Zaretskii <eliz@gnu.org> writes:
>> From: Len Trigg <lenbok@gmail.com>
>> Date: Tue, 24 Dec 2024 18:43:29 +1300
>>
>> tty-child-frames does not seem to play well with multiple clients. When we run server-start and allow emacs to
>> have multiple clients (e.g. an initial "emacs -nw" and an
>> "emacsclient -nw"), using a function that utilizes tty-child-frame (such as M-x when vertico-posframe is
>> loaded) in one frame leads the other client to be locked up.
>>
>> Steps to reproduce:
>>
>> mkdir ~/emacs-test
>> Copy the attached init.el into ~/emacs-test/
>> emacs -nw --init-directory=~/emacs-test (the first time will result in packages being installed by elpaca)
>> (in another terminal) emacsclient -nw
>> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
>> Switch back to the original emacs
>> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
>> Swap to the other terminal, and note that at some point one client will stop responding
>> to user input. (It may take a couple of tries, perhaps with other regular commands interspersed).
>> When one client is locked, swap back to the other terminal and exit the client - the original
>> client will now accept user input.
>>
>> When a client is locked it *does* accept some input (e.g. C-x C-c will exit the client)
>>
>> It's possible this is vertico-posframe related, as I can't trigger similar behaviour using transient-posframe.
>
> Gerd, could you perhaps look into this?
Thanks. Will come back to this after the holidays.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-24 5:43 bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs Len Trigg
2024-12-25 11:54 ` Eli Zaretskii
@ 2024-12-27 6:04 ` Gerd Möllmann
2024-12-27 8:18 ` Eli Zaretskii
1 sibling, 1 reply; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 6:04 UTC (permalink / raw)
To: Len Trigg; +Cc: 75056
Len Trigg <lenbok@gmail.com> writes:
> tty-child-frames does not seem to play well with multiple clients. When we run server-start and allow emacs to have
> multiple clients (e.g. an initial "emacs -nw" and an
> "emacsclient -nw"), using a function that utilizes tty-child-frame (such as M-x when vertico-posframe is loaded) in one
> frame leads the other client to be locked up.
>
> Steps to reproduce:
>
> mkdir ~/emacs-test
> Copy the attached init.el into ~/emacs-test/
> emacs -nw --init-directory=~/emacs-test (the first time will result in packages being installed by elpaca)
> (in another terminal) emacsclient -nw
> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
> Switch back to the original emacs
> Do something to invoke the child frame pop up (e.g. C-x b and select a buffer)
> Swap to the other terminal, and note that at some point one client will stop responding
> to user input. (It may take a couple of tries, perhaps with other regular commands interspersed).
> When one client is locked, swap back to the other terminal and exit the client - the original
> client will now accept user input.
>
> When a client is locked it *does* accept some input (e.g. C-x C-c will exit the client)
>
> It's possible this is vertico-posframe related, as I can't trigger similar behaviour using transient-posframe.
>
Hi Len, and thanks for the nice reproducer!
I can reproduce what you describe, I think, but I must admit that I'm a
bit at a loss at the moment. Something similar happens BTW if the server
is a GUI Emacs. Pretty weird.
And then I found this in admin/notes/multi-tty, under known problems:
* The single-kboard mode.
If your multi-tty Emacs session seems to be frozen, you
probably have a recursive editing session or a pending
minibuffer prompt (which is a kind of recursive editing) on
another display. To unfreeze your session, switch to that
display and complete the recursive edit, for example by
pressing C-] ('abort-recursive-edit').
I am sorry to say that currently there is no way to break
out of this "single-kboard mode" from a frozen display. If
you are unable to switch to the display that locks the
others (for example because it is on a remote computer),
then you can use emacsclient to break out of all recursive
editing sessions:
emacsclient -e '(top-level)'
Note that this (perhaps) unintuitive behavior is by design.
Single-kboard mode is required because of an intrinsic Emacs
limitation that is very hard to eliminate. (This limitation
is related to the single-threaded nature of Emacs.)
I plan to implement better user notification and support for
breaking out of single-kboard mode from locked displays.
Also see the long list of things to do in the same file, which makes me
a bit wary.
@Eli: I think we should invoke a multi-tty expert who can tell if what
we see here can be kind of expected with the current state of multi-tty or
not. And maybe can tell how up-to-date admin/notes/multi-tty is in the
first place.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 6:04 ` Gerd Möllmann
@ 2024-12-27 8:18 ` Eli Zaretskii
2024-12-27 8:46 ` Gerd Möllmann
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-27 8:18 UTC (permalink / raw)
To: Gerd Möllmann; +Cc: lenbok, 75056
> Cc: 75056@debbugs.gnu.org
> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> Date: Fri, 27 Dec 2024 07:04:54 +0100
>
> I can reproduce what you describe, I think, but I must admit that I'm a
> bit at a loss at the moment. Something similar happens BTW if the server
> is a GUI Emacs. Pretty weird.
>
> And then I found this in admin/notes/multi-tty, under known problems:
>
> * The single-kboard mode.
>
> If your multi-tty Emacs session seems to be frozen, you
> probably have a recursive editing session or a pending
> minibuffer prompt (which is a kind of recursive editing) on
> another display. To unfreeze your session, switch to that
> display and complete the recursive edit, for example by
> pressing C-] ('abort-recursive-edit').
>
> I am sorry to say that currently there is no way to break
> out of this "single-kboard mode" from a frozen display. If
> you are unable to switch to the display that locks the
> others (for example because it is on a remote computer),
> then you can use emacsclient to break out of all recursive
> editing sessions:
>
> emacsclient -e '(top-level)'
>
> Note that this (perhaps) unintuitive behavior is by design.
> Single-kboard mode is required because of an intrinsic Emacs
> limitation that is very hard to eliminate. (This limitation
> is related to the single-threaded nature of Emacs.)
>
> I plan to implement better user notification and support for
> breaking out of single-kboard mode from locked displays.
>
> Also see the long list of things to do in the same file, which makes me
> a bit wary.
Can you explain how the above limitation causes the problem reported
in this bug? That is, how do child frames trigger the bug? Because
"normal" frames don't, AFAIU, right? That is, one could have two or
more client TTY frames on several displays in the same Emacs session,
without having any of them stop being responsive, right? Also, what
is the role of vertico-posframe in this scenario?
IOW, I don't yet have a clear picture of what happens, although the
limitations you found in that admin file are known to me. AFAIK, the
single-kboard situation is still with us, search keyboard.c for
"single_kboard".
> @Eli: I think we should invoke a multi-tty expert who can tell if what
> we see here can be kind of expected with the current state of multi-tty or
> not. And maybe can tell how up-to-date admin/notes/multi-tty is in the
> first place.
We don't have such an expert on board, sadly, not for a long while.
We are on our own.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 8:18 ` Eli Zaretskii
@ 2024-12-27 8:46 ` Gerd Möllmann
2024-12-27 8:54 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 8:46 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: lenbok, 75056
Eli Zaretskii <eliz@gnu.org> writes:
> Can you explain how the above limitation causes the problem reported
> in this bug? That is, how do child frames trigger the bug? Because
> "normal" frames don't, AFAIU, right? That is, one could have two or
> more client TTY frames on several displays in the same Emacs session,
> without having any of them stop being responsive, right? Also, what
> is the role of vertico-posframe in this scenario?
The hint I see is here
>> If your multi-tty Emacs session seems to be frozen, you
>> probably have a recursive editing session or a pending
>> minibuffer prompt (which is a kind of recursive editing) on
>> another display.
Emacs in our case is kind of frozen, and Vertico is a minibuffer
interaction, where Posframe simply displays the minibuffer differently,
in a child frame.
Not an explanation of course, but it smells a lot like what's happening.
What the real reason behind all this is in the code, and what would need
to be fixed, I can't figure out from notes/multi-tty. Maybe come
combination of open things mentioned there, no idea.
>
> IOW, I don't yet have a clear picture of what happens, although the
> limitations you found in that admin file are known to me. AFAIK, the
> single-kboard situation is still with us, search keyboard.c for
> "single_kboard".
>
>> @Eli: I think we should invoke a multi-tty expert who can tell if what
>> we see here can be kind of expected with the current state of multi-tty or
>> not. And maybe can tell how up-to-date admin/notes/multi-tty is in the
>> first place.
>
> We don't have such an expert on board, sadly, not for a long while.
> We are on our own.
That's indeed more than suboptimal :-(.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 8:46 ` Gerd Möllmann
@ 2024-12-27 8:54 ` Eli Zaretskii
2024-12-27 9:04 ` Gerd Möllmann
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-27 8:54 UTC (permalink / raw)
To: Gerd Möllmann; +Cc: lenbok, 75056
> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> Date: Fri, 27 Dec 2024 09:46:48 +0100
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> > Can you explain how the above limitation causes the problem reported
> > in this bug? That is, how do child frames trigger the bug? Because
> > "normal" frames don't, AFAIU, right? That is, one could have two or
> > more client TTY frames on several displays in the same Emacs session,
> > without having any of them stop being responsive, right? Also, what
> > is the role of vertico-posframe in this scenario?
>
> The hint I see is here
>
> >> If your multi-tty Emacs session seems to be frozen, you
> >> probably have a recursive editing session or a pending
> >> minibuffer prompt (which is a kind of recursive editing) on
> >> another display.
>
> Emacs in our case is kind of frozen, and Vertico is a minibuffer
> interaction, where Posframe simply displays the minibuffer differently,
> in a child frame.
Yes, but where is that recursive editing in this scenario?
I guess I'd love to see a C backtrace from that situation.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 8:54 ` Eli Zaretskii
@ 2024-12-27 9:04 ` Gerd Möllmann
2024-12-27 12:28 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 9:04 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: lenbok, 75056
Eli Zaretskii <eliz@gnu.org> writes:
>> From: Gerd Möllmann <gerd.moellmann@gmail.com>
>> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
>> Date: Fri, 27 Dec 2024 09:46:48 +0100
>>
>> Eli Zaretskii <eliz@gnu.org> writes:
>>
>> > Can you explain how the above limitation causes the problem reported
>> > in this bug? That is, how do child frames trigger the bug? Because
>> > "normal" frames don't, AFAIU, right? That is, one could have two or
>> > more client TTY frames on several displays in the same Emacs session,
>> > without having any of them stop being responsive, right? Also, what
>> > is the role of vertico-posframe in this scenario?
>>
>> The hint I see is here
>>
>> >> If your multi-tty Emacs session seems to be frozen, you
>> >> probably have a recursive editing session or a pending
>> >> minibuffer prompt (which is a kind of recursive editing) on
>> >> another display.
>>
>> Emacs in our case is kind of frozen, and Vertico is a minibuffer
>> interaction, where Posframe simply displays the minibuffer differently,
>> in a child frame.
>
> Yes, but where is that recursive editing in this scenario?
We're switching frames while being in the minibuffer in the other frame.
> I guess I'd love to see a C backtrace from that situation.
Too difficult for me. Emacs is not frozen in the sense that it is
completely stuck somewhere. For example, C-x C-c apparently always
works. C-g seems to work sometimes too, sometimes not. It's more like
the keyboard input doesn't land where it is supposed to. Or something
like that.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 9:04 ` Gerd Möllmann
@ 2024-12-27 12:28 ` Eli Zaretskii
2024-12-27 12:47 ` Gerd Möllmann
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-27 12:28 UTC (permalink / raw)
To: Gerd Möllmann; +Cc: lenbok, 75056
> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> Date: Fri, 27 Dec 2024 10:04:29 +0100
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> >> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> >> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> >> Date: Fri, 27 Dec 2024 09:46:48 +0100
> >>
> >> Eli Zaretskii <eliz@gnu.org> writes:
> >>
> >> > Can you explain how the above limitation causes the problem reported
> >> > in this bug? That is, how do child frames trigger the bug? Because
> >> > "normal" frames don't, AFAIU, right? That is, one could have two or
> >> > more client TTY frames on several displays in the same Emacs session,
> >> > without having any of them stop being responsive, right? Also, what
> >> > is the role of vertico-posframe in this scenario?
> >>
> >> The hint I see is here
> >>
> >> >> If your multi-tty Emacs session seems to be frozen, you
> >> >> probably have a recursive editing session or a pending
> >> >> minibuffer prompt (which is a kind of recursive editing) on
> >> >> another display.
> >>
> >> Emacs in our case is kind of frozen, and Vertico is a minibuffer
> >> interaction, where Posframe simply displays the minibuffer differently,
> >> in a child frame.
> >
> > Yes, but where is that recursive editing in this scenario?
>
> We're switching frames while being in the minibuffer in the other frame.
>
> > I guess I'd love to see a C backtrace from that situation.
>
> Too difficult for me. Emacs is not frozen in the sense that it is
> completely stuck somewhere. For example, C-x C-c apparently always
> works. C-g seems to work sometimes too, sometimes not. It's more like
> the keyboard input doesn't land where it is supposed to. Or something
> like that.
Then why is this a bug?
When a frame is in a minibuffer, it means Emacs asks the user about
something, and in that situation, the user must respond to the prompt,
or exit the minibuffer in some other way. That's normal in my book.
What am I missing?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 12:28 ` Eli Zaretskii
@ 2024-12-27 12:47 ` Gerd Möllmann
2024-12-27 13:02 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 12:47 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: lenbok, 75056
Eli Zaretskii <eliz@gnu.org> writes:
> Then why is this a bug?
>
> When a frame is in a minibuffer, it means Emacs asks the user about
> something, and in that situation, the user must respond to the prompt,
> or exit the minibuffer in some other way. That's normal in my book.
> What am I missing?
Emacs doesn't say anything. The user is just typing into the void, and
it's not easy get out of this state again, except C-x C-c. That's not
normal.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 12:47 ` Gerd Möllmann
@ 2024-12-27 13:02 ` Eli Zaretskii
2024-12-27 13:17 ` Gerd Möllmann
` (2 more replies)
0 siblings, 3 replies; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-27 13:02 UTC (permalink / raw)
To: Gerd Möllmann; +Cc: lenbok, 75056
> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> Date: Fri, 27 Dec 2024 13:47:09 +0100
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> > Then why is this a bug?
> >
> > When a frame is in a minibuffer, it means Emacs asks the user about
> > something, and in that situation, the user must respond to the prompt,
> > or exit the minibuffer in some other way. That's normal in my book.
> > What am I missing?
>
> Emacs doesn't say anything.
It does: on the frame where you are in the minibuffer.
> The user is just typing into the void, and it's not easy get out of
> this state again, except C-x C-c. That's not normal.
My point is that this happens in many other, "simpler" situations.
AFAIK, it isn't limited to TTY frames, either. So if that's the only
thing that happens here, i.e. some other frame is parked at the
minibuffer prompt, there's nothing new here that we didn't have before
child frames became supported on TTY displays. Changing that would
need to have per-frame input queues in Emacs, AFAIU, and some way of
multiplexing between them.
But I'm not yet sure this is what we see in this case, which is why I
asked for a C backtrace. Producing it should be easy: just reproduce
the problem, then attach a debugger and produce the backtrace.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 13:02 ` Eli Zaretskii
@ 2024-12-27 13:17 ` Gerd Möllmann
2024-12-27 14:53 ` Eli Zaretskii
2024-12-27 18:13 ` Len Trigg
[not found] ` <CAOGVwenNt8a0HmSXTnqu5_FKkxEVMDw0hmak-MLk7Sn6up_wtg@mail.gmail.com>
2 siblings, 1 reply; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 13:17 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: lenbok, 75056
Eli Zaretskii <eliz@gnu.org> writes:
> But I'm not yet sure this is what we see in this case, which is why I
> asked for a C backtrace. Producing it should be easy: just reproduce
> the problem, then attach a debugger and produce the backtrace.
See below. AFAICS, Emacs is waiting for input, and when we have some,
the wrong things will happen. Please note that this is not a full debug
build.
bt
* thread #1, queue = 'com.apple.main-thread', stop reason = signal SIGSTOP
frame #0: 0x0000000190be51a8 libsystem_kernel.dylib`__pselect + 8
frame #1: 0x0000000190be5080 libsystem_kernel.dylib`pselect$DARWIN_EXTSN + 64
frame #2: 0x00000001047181d4 emacs`really_call_select(arg=0x000000016b8d44e0) at thread.c:620:16 [opt]
frame #3: 0x0000000104718148 emacs`thread_select [inlined] flush_stack_call_func(func=<unavailable>, arg=0x000000016b8d44e0) at lisp.h:4842:3 [opt]
frame #4: 0x0000000104718138 emacs`thread_select(func=<unavailable>, max_fds=<unavailable>, rfds=<unavailable>, wfds=<unavailable>, efds=<unavailable>, timeout=<unavailable>, sigmask=<unavailable>) at thread.c:652:3 [opt]
frame #5: 0x000000010473ef04 emacs`ns_select_1(nfds=<unavailable>, readfds=<unavailable>, writefds=<unavailable>, exceptfds=<unavailable>, timeout=<unavailable>, sigmask=<unavailable>, run_loop_only=<unavailable>) at nsterm.m:4873:12 [opt] [artificial]
frame #6: 0x000000010473ed14 emacs`ns_select(nfds=<unavailable>, readfds=<unavailable>, writefds=<unavailable>, exceptfds=<unavailable>, timeout=<unavailable>, sigmask=<unavailable>) at nsterm.m:5006:10 [opt] [artificial]
frame #7: 0x00000001046e72c0 emacs`wait_reading_process_output(time_limit=<unavailable>, nsecs=<unavailable>, read_kbd=<unavailable>, do_display=true, wait_for_cell=<unavailable>, wait_proc=<unavailable>, just_wait_proc=<unavailable>) at process.c:5766:18 [opt]
frame #8: 0x000000010460d4b4 emacs`read_char [inlined] kbd_buffer_get_event(kbp=<unavailable>, used_mouse_menu=0x000000016b8d4f67, end_time=0x0000000000000000) at keyboard.c:0 [opt]
!gud 0::/Users/gerd/emacs/github/cl-packages/src/keyboard.c
frame #9: 0x000000010460d294 emacs`read_char [inlined] read_event_from_main_queue(end_time=0x0000000000000000, local_getcjmp=0x000000016b8d4c00, used_mouse_menu=0x000000016b8d4f67) at keyboard.c:2336:7 [opt]
frame #10: 0x000000010460d134 emacs`read_char [inlined] read_decoded_event_from_main_queue(end_time=0x0000000000000000, local_getcjmp=0x000000016b8d4c00, prev_event=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0, used_mouse_menu=0x000000016b8d4f67) at keyboard.c:2400:11 [opt]
frame #11: 0x000000010460d114 emacs`read_char(commandflag=1, map=(struct Lisp_Cons *) $8 = 0x000000010abc8280, prev_event=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0, used_mouse_menu=0x000000016b8d4f67, end_time=0x0000000000000000) at keyboard.c:3031:11 [opt]
frame #12: 0x000000010460992c emacs`read_key_sequence(keybuf=<unavailable>, prompt=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0, dont_downcase_last=false, can_return_switch_frame=true, fix_current_buffer=true, prevent_redisplay=<unavailable>, disable_text_conversion_p=<unavailable>) at keyboard.c:10762:12 [opt]
frame #13: 0x0000000104607d9c emacs`command_loop_1 at keyboard.c:1435:15 [opt]
frame #14: 0x000000010468eeb0 emacs`internal_condition_case(bfun=(emacs`command_loop_1 at keyboard.c:1330), handlers=(struct Lisp_Symbol *) $10 = 0x0000000104e06188, hfun=(emacs`cmd_error at keyboard.c:976)) at eval.c:1669:25 [opt]
frame #15: 0x0000000104607a50 emacs`command_loop_2(handlers=(struct Lisp_Symbol *) $10 = 0x0000000104e06188) at keyboard.c:1174:11 [opt]
!gud 1174:11:/Users/gerd/emacs/github/cl-packages/src/keyboard.c
frame #16: 0x000000010468e504 emacs`internal_catch(tag=(struct Lisp_Symbol *) $13 = 0x0000000104e0f108, func=(emacs`command_loop_2 at keyboard.c:1170), arg=(struct Lisp_Symbol *) $10 = 0x0000000104e06188) at eval.c:1348:25 [opt]
frame #17: 0x000000010460714c emacs`command_loop at keyboard.c:1144:13 [opt]
frame #18: 0x0000000104607008 emacs`recursive_edit_1 at keyboard.c:760:9 [opt]
frame #19: 0x000000010463e660 emacs`Fread_from_minibuffer [inlined] read_minibuf(map=<unavailable>, initial=<unavailable>, prompt=(struct Lisp_String *) $15 = 0x000000010aba19a8, expflag=<unavailable>, histvar=<unavailable>, histpos=(EMACS_INT) $17 = 0, defalt=<unavailable>, allow_props=<unavailable>, inherit_input_method=<unavailable>) at minibuf.c:905:3 [opt]
!gud 905:3:/Users/gerd/emacs/github/cl-packages/src/minibuf.c
frame #20: 0x000000010463de28 emacs`Fread_from_minibuffer(prompt=(struct Lisp_String *) $15 = 0x000000010aba19a8, initial_contents=<unavailable>, keymap=(struct Lisp_Cons *) $18 = 0x0000000108f15eb0, read=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0, hist=<unavailable>, default_value=(struct Lisp_String *) $19 = 0x000000010893a840, inherit_input_method=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0) at minibuf.c:1398:9 [opt]
frame #21: 0x0000000104691b70 emacs`funcall_subr(subr=0x0000000104da0e70, numargs=7, args=<unavailable>) at eval.c:3237:15 [opt]
frame #22: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
frame #23: 0x0000000104691d0c emacs`funcall_lambda(fun=<unavailable>, nargs=<unavailable>, arg_vector=<unavailable>) at eval.c:3316:9 [opt] [artificial]
frame #24: 0x0000000104691a40 emacs`funcall_general(fun=<unavailable>, numargs=<unavailable>, args=<unavailable>) at eval.c:3108:12 [opt] [artificial]
frame #25: 0x000000010468c3f8 emacs`Ffuncall(nargs=9, args=(struct Lisp_Symbol *) $21 = 0x00000002706db770) at eval.c:3157:21 [opt]
frame #26: 0x0000000104690cac emacs`Fapply(nargs=1, args=(struct Lisp_Symbol *) $25 = 0x0000000244e0e360) at eval.c:2822:24 [opt]
frame #27: 0x0000000104691ac8 emacs`funcall_subr(subr=0x0000000104da72b0, numargs=1, args=<unavailable>) at eval.c:0 [opt]
frame #28: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
frame #29: 0x0000000104691d0c emacs`funcall_lambda(fun=<unavailable>, nargs=<unavailable>, arg_vector=<unavailable>) at eval.c:3316:9 [opt] [artificial]
frame #30: 0x0000000104691a40 emacs`funcall_general(fun=<unavailable>, numargs=<unavailable>, args=<unavailable>) at eval.c:3108:12 [opt] [artificial]
frame #31: 0x000000010468c3f8 emacs`Ffuncall(nargs=10, args=(struct Lisp_Symbol *) $29 = 0x00000002706db9d0) at eval.c:3157:21 [opt]
frame #32: 0x0000000104690cac emacs`Fapply(nargs=2, args=(struct Lisp_Symbol *) $32 = 0x0000000244e0e2d0) at eval.c:2822:24 [opt]
frame #33: 0x0000000104691ac8 emacs`funcall_subr(subr=0x0000000104da72b0, numargs=2, args=<unavailable>) at eval.c:0 [opt]
frame #34: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
frame #35: 0x0000000104691d0c emacs`funcall_lambda(fun=<unavailable>, nargs=<unavailable>, arg_vector=<unavailable>) at eval.c:3316:9 [opt] [artificial]
frame #36: 0x0000000104691a40 emacs`funcall_general(fun=<unavailable>, numargs=<unavailable>, args=<unavailable>) at eval.c:3108:12 [opt] [artificial]
frame #37: 0x000000010468c3f8 emacs`Ffuncall(nargs=10, args=(struct Lisp_Symbol *) $35 = 0x00000002706dbc30) at eval.c:3157:21 [opt]
frame #38: 0x0000000104690cac emacs`Fapply(nargs=3, args=(struct Lisp_Symbol *) $39 = 0x0000000244e0e280) at eval.c:2822:24 [opt]
frame #39: 0x0000000104691ac8 emacs`funcall_subr(subr=0x0000000104da72b0, numargs=3, args=<unavailable>) at eval.c:0 [opt]
frame #40: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
frame #41: 0x0000000104691d0c emacs`funcall_lambda(fun=<unavailable>, nargs=<unavailable>, arg_vector=<unavailable>) at eval.c:3316:9 [opt] [artificial]
frame #42: 0x0000000104691a40 emacs`funcall_general(fun=<unavailable>, numargs=<unavailable>, args=<unavailable>) at eval.c:3108:12 [opt] [artificial]
!gud 3108:12:/Users/gerd/emacs/github/cl-packages/src/eval.c
frame #43: 0x000000010468c3f8 emacs`Ffuncall(nargs=<unavailable>, args=(struct Lisp_Symbol *) $42 = 0x00000002706dbef0) at eval.c:3157:21 [opt]
frame #44: 0x000000010463f3c8 emacs`Fread_buffer(prompt=(struct Lisp_String *) $15 = 0x000000010aba19a8, def=(struct Lisp_String *) $19 = 0x000000010893a840, require_match=(struct Lisp_Symbol *) $45 = 0x00000001084b4d58, predicate=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0) at minibuf.c:0 [opt]
frame #45: 0x0000000104691bdc emacs`funcall_subr(subr=0x0000000104da0fb0, numargs=3, args=<unavailable>) at eval.c:3231:15 [opt]
frame #46: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
!gud 828:14:/Users/gerd/emacs/github/cl-packages/src/bytecode.c
frame #47: 0x00000001046dd188 emacs`Fbyte_code(bytestr=<unavailable>, vector=(struct Lisp_Vector *) $48 = 0x00000001084b4808, maxdepth=(EMACS_INT) $50 = 4) at bytecode.c:325:10 [opt]
frame #48: 0x000000010468b8e8 emacs`eval_sub(form=(struct Lisp_Cons *) $51 = 0x00000001084b47a8) at eval.c:2661:15 [opt]
frame #49: 0x0000000104690798 emacs`Feval(form=<unavailable>, lexical=<unavailable>) at eval.c:2514:28 [opt]
frame #50: 0x0000000104688d84 emacs`Fcall_interactively(function=<unavailable>, record_flag=(struct Lisp_Symbol *) $4 = 0x0000000104e060e0, keys=(struct Lisp_Vector *) $52 = 0x000000010ab9ee88) at callint.c:325:15 [opt]
frame #51: 0x0000000104691c1c emacs`funcall_subr(subr=0x0000000104da68f0, numargs=3, args=<unavailable>) at eval.c:3229:15 [opt]
frame #52: 0x00000001046de5f0 emacs`exec_byte_code(fun=<unavailable>, args_template=<unavailable>, nargs=<unavailable>, args=<unavailable>) at bytecode.c:828:14 [opt]
frame #53: 0x0000000104691d0c emacs`funcall_lambda(fun=<unavailable>, nargs=<unavailable>, arg_vector=<unavailable>) at eval.c:3316:9 [opt] [artificial]
frame #54: 0x0000000104691a40 emacs`funcall_general(fun=<unavailable>, numargs=<unavailable>, args=<unavailable>) at eval.c:3108:12 [opt] [artificial]
frame #55: 0x000000010468c3f8 emacs`Ffuncall(nargs=2, args=(struct Lisp_Symbol *) $54 = 0x00000002706dc610) at eval.c:3157:21 [opt]
frame #56: 0x0000000104607fb0 emacs`command_loop_1 at keyboard.c:1556:13 [opt]
frame #57: 0x000000010468eeb0 emacs`internal_condition_case(bfun=(emacs`command_loop_1 at keyboard.c:1330), handlers=(struct Lisp_Symbol *) $10 = 0x0000000104e06188, hfun=(emacs`cmd_error at keyboard.c:976)) at eval.c:1669:25 [opt]
frame #58: 0x0000000104607a50 emacs`command_loop_2(handlers=(struct Lisp_Symbol *) $10 = 0x0000000104e06188) at keyboard.c:1174:11 [opt]
frame #59: 0x000000010468e504 emacs`internal_catch(tag=(struct Lisp_Symbol *) $58 = 0x0000000104e1aba0, func=(emacs`command_loop_2 at keyboard.c:1170), arg=(struct Lisp_Symbol *) $10 = 0x0000000104e06188) at eval.c:1348:25 [opt]
frame #60: 0x00000001046071c8 emacs`command_loop at keyboard.c:1152:2 [opt]
!gud 1152:2:/Users/gerd/emacs/github/cl-packages/src/keyboard.c
frame #61: 0x0000000104607008 emacs`recursive_edit_1 at keyboard.c:760:9 [opt]
frame #62: 0x000000010460740c emacs`Frecursive_edit at keyboard.c:843:3 [opt]
frame #63: 0x0000000104606134 emacs`main(argc=<unavailable>, argv=0x000000016b8d6c30) at emacs.c:2655:3 [opt]
frame #64: 0x00000001908a0274 dyld`start + 2840
(lldb)
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 13:17 ` Gerd Möllmann
@ 2024-12-27 14:53 ` Eli Zaretskii
2024-12-27 15:56 ` Gerd Möllmann
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-27 14:53 UTC (permalink / raw)
To: Gerd Möllmann; +Cc: lenbok, 75056
> From: Gerd Möllmann <gerd.moellmann@gmail.com>
> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> Date: Fri, 27 Dec 2024 14:17:11 +0100
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> > But I'm not yet sure this is what we see in this case, which is why I
> > asked for a C backtrace. Producing it should be easy: just reproduce
> > the problem, then attach a debugger and produce the backtrace.
>
> See below. AFAICS, Emacs is waiting for input, and when we have some,
> the wrong things will happen. Please note that this is not a full debug
> build.
Thanks. This lacks the equivalent of "xbacktrace", so a bit hard to
interpret, but I see read-from-minibuffer which called recursive-edit.
What is the recipe for this, starting from "emacs -Q", please? Can
this be reproduced without posframe?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 14:53 ` Eli Zaretskii
@ 2024-12-27 15:56 ` Gerd Möllmann
0 siblings, 0 replies; 21+ messages in thread
From: Gerd Möllmann @ 2024-12-27 15:56 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: lenbok, 75056
Eli Zaretskii <eliz@gnu.org> writes:
>> From: Gerd Möllmann <gerd.moellmann@gmail.com>
>> Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
>> Date: Fri, 27 Dec 2024 14:17:11 +0100
>>
>> Eli Zaretskii <eliz@gnu.org> writes:
>>
>> > But I'm not yet sure this is what we see in this case, which is why I
>> > asked for a C backtrace. Producing it should be easy: just reproduce
>> > the problem, then attach a debugger and produce the backtrace.
>>
>> See below. AFAICS, Emacs is waiting for input, and when we have some,
>> the wrong things will happen. Please note that this is not a full debug
>> build.
>
> Thanks. This lacks the equivalent of "xbacktrace", so a bit hard to
> interpret, but I see read-from-minibuffer which called recursive-edit.
>
> What is the recipe for this, starting from "emacs -Q", please?
The one the OP gave is good.
> Can this be reproduced without posframe?
No idea.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 13:02 ` Eli Zaretskii
2024-12-27 13:17 ` Gerd Möllmann
@ 2024-12-27 18:13 ` Len Trigg
2024-12-27 18:23 ` Len Trigg
[not found] ` <CAOGVwenNt8a0HmSXTnqu5_FKkxEVMDw0hmak-MLk7Sn6up_wtg@mail.gmail.com>
2 siblings, 1 reply; 21+ messages in thread
From: Len Trigg @ 2024-12-27 18:13 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Gerd Möllmann, 75056
[-- Attachment #1: Type: text/plain, Size: 990 bytes --]
(Sorry Eli for the dup email, I initially used Reply rather than Reply-All)
On Sat, 28 Dec 2024 at 02:02, Eli Zaretskii <eliz@gnu.org> wrote:
> > From: Gerd Möllmann <gerd.moellmann@gmail.com>
> > Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> > Date: Fri, 27 Dec 2024 13:47:09 +0100
> >
> > Eli Zaretskii <eliz@gnu.org> writes:
> >
> > > Then why is this a bug?
> > >
> > > When a frame is in a minibuffer, it means Emacs asks the user about
> > > something, and in that situation, the user must respond to the prompt,
> > > or exit the minibuffer in some other way. That's normal in my book.
> > > What am I missing?
> >
> > Emacs doesn't say anything.
>
> It does: on the frame where you are in the minibuffer.
>
Hmmm, the repro scenario I gave doesn't involve either emacs client being
still in the minibuffer AFAIK - the "working" client is just in a regular
buffer (e.g. having been chosen via C-x b and selected), and the "hung"
client is, well, hung.
[-- Attachment #2: Type: text/html, Size: 1705 bytes --]
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 18:13 ` Len Trigg
@ 2024-12-27 18:23 ` Len Trigg
2024-12-28 7:52 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Len Trigg @ 2024-12-27 18:23 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Gerd Möllmann, 75056
[-- Attachment #1: Type: text/plain, Size: 830 bytes --]
On Sat, 28 Dec 2024 at 07:13, Len Trigg <lenbok@gmail.com> wrote:
> Hmmm, the repro scenario I gave doesn't involve either emacs client being
> still in the minibuffer AFAIK - the "working" client is just in a regular
> buffer (e.g. having been chosen via C-x b and selected), and the "hung"
> client is, well, hung.
>
To elaborate my steps:
emacs -nw --init-directory=~/emacs-test (the first time will result in
packages being installed by elpaca)
(in another terminal) emacsclient -nw
Then invoke the child frame pop up: (e.g. C-x b and C-n to select
*Messages* and RET). Now we're no longer in a minibuffer.
Switch back to the original emacs
Invoke the child frame pop up (e.g. C-x b and C-n to select *Messages* and
RET). Now we're no longer in a minibuffer.
Swap to the other terminal, and note that the client is "hung".
[-- Attachment #2: Type: text/html, Size: 1320 bytes --]
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
[not found] ` <CAOGVwenNt8a0HmSXTnqu5_FKkxEVMDw0hmak-MLk7Sn6up_wtg@mail.gmail.com>
@ 2024-12-28 7:44 ` Eli Zaretskii
0 siblings, 0 replies; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-28 7:44 UTC (permalink / raw)
To: Len Trigg; +Cc: Gerd Möllmann, 75056
> From: Len Trigg <lenbok@gmail.com>
> Date: Sat, 28 Dec 2024 07:11:35 +1300
>
> On Sat, 28 Dec 2024 at 02:02, Eli Zaretskii <eliz@gnu.org> wrote:
>
> > From: Gerd Möllmann <gerd.moellmann@gmail.com>
> > Cc: lenbok@gmail.com, 75056@debbugs.gnu.org
> > Date: Fri, 27 Dec 2024 13:47:09 +0100
> >
> > Eli Zaretskii <eliz@gnu.org> writes:
> >
> > > Then why is this a bug?
> > >
> > > When a frame is in a minibuffer, it means Emacs asks the user about
> > > something, and in that situation, the user must respond to the prompt,
> > > or exit the minibuffer in some other way. That's normal in my book.
> > > What am I missing?
> >
> > Emacs doesn't say anything.
>
> It does: on the frame where you are in the minibuffer.
>
> Hmmm, the repro scenario I gave doesn't involve either emacs client being still in the minibuffer AFAIK - the
> "working" client is just in a regular buffer (e.g. having been chosen via C-x b and selected), and the "hung"
> client is, well, hung.
Maybe you switched out of the minibuffer window, leaving the
minibuffer active? In which case switching back to the mini-window
and exiting the minibuffer prompt (with RET or C-g or some other way)
should "unhang" the other client. Is this indeed so?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-27 18:23 ` Len Trigg
@ 2024-12-28 7:52 ` Eli Zaretskii
2024-12-28 19:55 ` Len Trigg
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-28 7:52 UTC (permalink / raw)
To: Len Trigg; +Cc: gerd.moellmann, 75056
> From: Len Trigg <lenbok@gmail.com>
> Date: Sat, 28 Dec 2024 07:23:52 +1300
> Cc: Gerd Möllmann <gerd.moellmann@gmail.com>,
> 75056@debbugs.gnu.org
>
> On Sat, 28 Dec 2024 at 07:13, Len Trigg <lenbok@gmail.com> wrote:
>
> Hmmm, the repro scenario I gave doesn't involve either emacs client being still in the minibuffer AFAIK -
> the "working" client is just in a regular buffer (e.g. having been chosen via C-x b and selected), and the
> "hung" client is, well, hung.
>
> To elaborate my steps:
> emacs -nw --init-directory=~/emacs-test (the first time will result in packages being installed by elpaca)
> (in another terminal) emacsclient -nw
> Then invoke the child frame pop up: (e.g. C-x b and C-n to select *Messages* and RET). Now we're no
> longer in a minibuffer.
> Switch back to the original emacs
> Invoke the child frame pop up (e.g. C-x b and C-n to select *Messages* and RET). Now we're no longer in a
> minibuffer.
> Swap to the other terminal, and note that the client is "hung".
Could you please extend your recipe so it starts from "emacs -nw -Q"?
See, I don't have posframe or elpaca installed and don't use them, and
don't want to install them just to reproduce and debug this problem.
What I can do is download the packages needed to reproduce this,
unpack them into some temporary directory, and manually load them
(with commands like "M-x load-file") into Emacs started with -Q.
Could you please provide a recipe like this which I could follow? And
please specify specific commands in the recipe, not "e.g.", so I could
make sure I'm following exactly the correct steps, and nothing else.
It is otherwise very hard for me to spend time on such bug reports,
because I first need to understand what packages are involved and how
to activate them, and that can take a lot of time for packages I never
used.
TIA
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-28 7:52 ` Eli Zaretskii
@ 2024-12-28 19:55 ` Len Trigg
2025-01-05 16:41 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Len Trigg @ 2024-12-28 19:55 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: gerd.moellmann, 75056
[-- Attachment #1.1: Type: text/plain, Size: 1674 bytes --]
On Sat, 28 Dec 2024 at 20:52, Eli Zaretskii <eliz@gnu.org> wrote:
> Could you please extend your recipe so it starts from "emacs -nw -Q"?
> See, I don't have posframe or elpaca installed and don't use them, and
> don't want to install them just to reproduce and debug this problem.
>
Unless there's something I'm missing, the init file and startup command I
provided did the installation of those files for you into a temporary
directory, so I thought that was the easiest self-contained path to
reproducing. Let me assume you've run it once that way initially in order
to fetch the packages (otherwise you can manually download the files if you
want and adjust the paths in the below command line, but be aware that you
need new enough versions of posframe that understands tty child frame).
Then to get a "emacs -nw -Q" initialization you can use the attached
test.el to do:
emacs -nw -Q --init-directory=~/emacs-test -l
~/emacs-test/elpaca/repos/vertico/vertico.el -l
~/emacs-test/elpaca/repos/vertico/extensions/vertico-multiform.el -l
~/emacs-test/elpaca/repos/posframe/posframe.el -l
~/emacs-test/elpaca/repos/vertico-posframe/vertico-posframe.el test.el
Then manually "eval" the remaining commands in test.el
(in another terminal) emacsclient -nw
Then invoke the child frame pop up: (C-x b and C-n to select *Messages* and
RET). Now we're no longer in a minibuffer.
Switch back to the original emacs terminal
Invoke the child frame pop up: (C-x b and C-n to select *Messages* and
RET). Now we're no longer in a minibuffer.
Swap to the emacsclient terminal, and note that the client is "hung".
I think this gives a specific enough recipe to minimally reproduce.
[-- Attachment #1.2: Type: text/html, Size: 2286 bytes --]
[-- Attachment #2: test.el --]
[-- Type: text/x-emacs-lisp, Size: 178 bytes --]
(vertico-mode)
(push '(tty-non-selected-cursor . t) vertico-posframe-parameters)
(push '(undecorated . nil) vertico-posframe-parameters)
(vertico-posframe-mode)
(server-start)
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2024-12-28 19:55 ` Len Trigg
@ 2025-01-05 16:41 ` Eli Zaretskii
2025-01-07 18:04 ` Len Trigg
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2025-01-05 16:41 UTC (permalink / raw)
To: Len Trigg; +Cc: gerd.moellmann, 75056
> From: Len Trigg <lenbok@gmail.com>
> Date: Sun, 29 Dec 2024 08:55:51 +1300
> Cc: gerd.moellmann@gmail.com, 75056@debbugs.gnu.org
>
> On Sat, 28 Dec 2024 at 20:52, Eli Zaretskii <eliz@gnu.org> wrote:
>
> Could you please extend your recipe so it starts from "emacs -nw -Q"?
> See, I don't have posframe or elpaca installed and don't use them, and
> don't want to install them just to reproduce and debug this problem.
>
> Unless there's something I'm missing, the init file and startup command I provided did the installation of those
> files for you into a temporary directory, so I thought that was the easiest self-contained path to reproducing.
> Let me assume you've run it once that way initially in order to fetch the packages (otherwise you can
> manually download the files if you want and adjust the paths in the below command line, but be aware that
> you need new enough versions of posframe that understands tty child frame). Then to get a "emacs -nw -Q"
> initialization you can use the attached test.el to do:
>
> emacs -nw -Q --init-directory=~/emacs-test -l ~/emacs-test/elpaca/repos/vertico/vertico.el -l ~
> /emacs-test/elpaca/repos/vertico/extensions/vertico-multiform.el -l ~
> /emacs-test/elpaca/repos/posframe/posframe.el -l ~
> /emacs-test/elpaca/repos/vertico-posframe/vertico-posframe.el test.el
>
> Then manually "eval" the remaining commands in test.el
> (in another terminal) emacsclient -nw
> Then invoke the child frame pop up: (C-x b and C-n to select *Messages* and RET). Now we're no longer in
> a minibuffer.
> Switch back to the original emacs terminal
> Invoke the child frame pop up: (C-x b and C-n to select *Messages* and RET). Now we're no longer in a
> minibuffer.
> Swap to the emacsclient terminal, and note that the client is "hung".
>
> I think this gives a specific enough recipe to minimally reproduce.
>
> (vertico-mode)
>
> (push '(tty-non-selected-cursor . t) vertico-posframe-parameters)
> (push '(undecorated . nil) vertico-posframe-parameters)
> (vertico-posframe-mode)
>
> (server-start)
I tried this now, but I don't think I see the problem you describe.
I donwloaded vertico, posframe, and vertico-posframe packages from GNU
ELPA -- are the versions available there new enough to reproduce the
problem? If not, where should I download these packages from?
Anyway, I can only observe a "hung" client if I forcibly switch from
an active minibuffer. That is, after "C-x b" I don't select a buffer,
I simply type "C-x o" to switch out of the mini-window. Then only the
client where I switched out of the mini-window can accept keyboard
input, the other one is "hung".
However, I can see the same situation even without these two packages:
if I start emacsclient, type "C-x b" there, and then "C-x o" to switch
away from the mini-window, Emacs on the other frame will stop responding
to keyboard input. This is expected: when Emacs has an active
minibuffer on some display, Emacs temporarily switches to the
"single-keyboard mode".
But I suspect this is not what you see, so I wonder what did I not do
to reproduce the problem you see.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs
2025-01-05 16:41 ` Eli Zaretskii
@ 2025-01-07 18:04 ` Len Trigg
0 siblings, 0 replies; 21+ messages in thread
From: Len Trigg @ 2025-01-07 18:04 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: gerd.moellmann, 75056
[-- Attachment #1: Type: text/plain, Size: 4006 bytes --]
Please excuse the top reply, I am traveling and my phone email client is limited.
Eli, thanks for taking another look. AFAIK, posframe needs to be newer than what is released in ELPA. You can get the latest from <https://github.com/tumashu/posframe>
I also think that if you had the older version you would not have seen a tty-child-frame at all and so not have triggered the bug I see - In your test did C-x b bring up a tty child frame in the center of the window, or a regular minibuffer at the bottom of the screen?
(You are correct that I did not switch away from the selector in my repro steps, I selected the buffer and exited normally with RET).
Cheers,
Len.
On 5 January 2025 6:41:15 pm GMT+02:00, Eli Zaretskii <eliz@gnu.org> wrote:
>> From: Len Trigg <lenbok@gmail.com>
>> Date: Sun, 29 Dec 2024 08:55:51 +1300
>> Cc: gerd.moellmann@gmail.com, 75056@debbugs.gnu.org
>>
>> On Sat, 28 Dec 2024 at 20:52, Eli Zaretskii <eliz@gnu.org> wrote:
>>
>> Could you please extend your recipe so it starts from "emacs -nw -Q"?
>> See, I don't have posframe or elpaca installed and don't use them, and
>> don't want to install them just to reproduce and debug this problem.
>>
>> Unless there's something I'm missing, the init file and startup command I provided did the installation of those
>> files for you into a temporary directory, so I thought that was the easiest self-contained path to reproducing.
>> Let me assume you've run it once that way initially in order to fetch the packages (otherwise you can
>> manually download the files if you want and adjust the paths in the below command line, but be aware that
>> you need new enough versions of posframe that understands tty child frame). Then to get a "emacs -nw -Q"
>> initialization you can use the attached test.el to do:
>>
>> emacs -nw -Q --init-directory=~/emacs-test -l ~/emacs-test/elpaca/repos/vertico/vertico.el -l ~
>> /emacs-test/elpaca/repos/vertico/extensions/vertico-multiform.el -l ~
>> /emacs-test/elpaca/repos/posframe/posframe.el -l ~
>> /emacs-test/elpaca/repos/vertico-posframe/vertico-posframe.el test.el
>>
>> Then manually "eval" the remaining commands in test.el
>> (in another terminal) emacsclient -nw
>> Then invoke the child frame pop up: (C-x b and C-n to select *Messages* and RET). Now we're no longer in
>> a minibuffer.
>> Switch back to the original emacs terminal
>> Invoke the child frame pop up: (C-x b and C-n to select *Messages* and RET). Now we're no longer in a
>> minibuffer.
>> Swap to the emacsclient terminal, and note that the client is "hung".
>>
>> I think this gives a specific enough recipe to minimally reproduce.
>>
>> (vertico-mode)
>>
>> (push '(tty-non-selected-cursor . t) vertico-posframe-parameters)
>> (push '(undecorated . nil) vertico-posframe-parameters)
>> (vertico-posframe-mode)
>>
>> (server-start)
>
>I tried this now, but I don't think I see the problem you describe.
>
>I donwloaded vertico, posframe, and vertico-posframe packages from GNU
>ELPA -- are the versions available there new enough to reproduce the
>problem? If not, where should I download these packages from?
>
>Anyway, I can only observe a "hung" client if I forcibly switch from
>an active minibuffer. That is, after "C-x b" I don't select a buffer,
>I simply type "C-x o" to switch out of the mini-window. Then only the
>client where I switched out of the mini-window can accept keyboard
>input, the other one is "hung".
>
>However, I can see the same situation even without these two packages:
>if I start emacsclient, type "C-x b" there, and then "C-x o" to switch
>away from the mini-window, Emacs on the other frame will stop responding
>to keyboard input. This is expected: when Emacs has an active
>minibuffer on some display, Emacs temporarily switches to the
>"single-keyboard mode".
>
>But I suspect this is not what you see, so I wonder what did I not do
>to reproduce the problem you see.
>
[-- Attachment #2: Type: text/html, Size: 4544 bytes --]
^ permalink raw reply [flat|nested] 21+ messages in thread
end of thread, other threads:[~2025-01-07 18:04 UTC | newest]
Thread overview: 21+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-24 5:43 bug#75056: 31.0.50; tty-child-frames with server / multiple clients possible hangs Len Trigg
2024-12-25 11:54 ` Eli Zaretskii
2024-12-25 11:59 ` Gerd Möllmann
2024-12-27 6:04 ` Gerd Möllmann
2024-12-27 8:18 ` Eli Zaretskii
2024-12-27 8:46 ` Gerd Möllmann
2024-12-27 8:54 ` Eli Zaretskii
2024-12-27 9:04 ` Gerd Möllmann
2024-12-27 12:28 ` Eli Zaretskii
2024-12-27 12:47 ` Gerd Möllmann
2024-12-27 13:02 ` Eli Zaretskii
2024-12-27 13:17 ` Gerd Möllmann
2024-12-27 14:53 ` Eli Zaretskii
2024-12-27 15:56 ` Gerd Möllmann
2024-12-27 18:13 ` Len Trigg
2024-12-27 18:23 ` Len Trigg
2024-12-28 7:52 ` Eli Zaretskii
2024-12-28 19:55 ` Len Trigg
2025-01-05 16:41 ` Eli Zaretskii
2025-01-07 18:04 ` Len Trigg
[not found] ` <CAOGVwenNt8a0HmSXTnqu5_FKkxEVMDw0hmak-MLk7Sn6up_wtg@mail.gmail.com>
2024-12-28 7:44 ` Eli Zaretskii
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).