unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection
@ 2024-06-25 20:50 Sean Devlin
  2024-06-26  4:45 ` Jim Porter
  0 siblings, 1 reply; 5+ messages in thread
From: Sean Devlin @ 2024-06-25 20:50 UTC (permalink / raw)
  To: 71778

Hi folks,

I've found it is possible to Eshell in the middle of a command. Here's a
recipe:

1. Emacs -Q
2. M-x eshell
3. In Eshell:

$ for x in 1 2 3 4 5 { echo hello ; sleep 2 } > #<buffer test>

4. While the above command is running, C-x b test
5. C-x b *eshell*

Observe that the loop will never finish and the Eshell buffer becomes
unresponsive. For example, pressing RET does nothing. Pressing C-c C-c
will terminate the command, but Eshell no longer accepts new commands.

Please let me know if I can provide additional information.

Thanks!

In GNU Emacs 30.0.60
Repository revision: fb11294d4156a4be45080ff286a8ee0d5a3ede9b
Repository branch: HEAD
Windowing system distributor 'Apple'
System Description:  macOS

Configured using:
'configure --with-ns'

Configured features:
ACL DBUS GLIB GNUTLS LCMS2 LIBXML2 MODULES NOTIFY KQUEUE NS PDUMPER PNG
RSVG SQLITE3 THREADS TOOLKIT_SCROLL_BARS TREE_SITTER WEBP XIM ZLIB

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

Major mode: Lisp Interaction

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  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
  font-lock-mode: t
  blink-cursor-mode: t
  minibuffer-regexp-mode: 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
cl-loaddefs cl-lib sendmail rfc2047 rfc2045 ietf-drums mm-util
mail-prsvr mail-utils rmc iso-transl tooltip cconv eldoc paren electric
uniquify ediff-hook vc-hooks lisp-float-type elisp-mode mwheel
term/ns-win ns-win ucs-normalize mule-util term/common-win 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 kqueue cocoa ns
lcms2 multi-tty make-network-process emacs)

Memory information:
((conses 16 38769 9073) (symbols 48 5298 0) (strings 32 12476 2590)
(string-bytes 1 307951) (vectors 16 9391)
(vector-slots 8 114340 8902) (floats 8 21 3) (intervals 56 224 6)
(buffers 992 10))





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection
  2024-06-25 20:50 bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection Sean Devlin
@ 2024-06-26  4:45 ` Jim Porter
  2024-06-26 13:01   ` Eli Zaretskii
  2024-06-26 14:06   ` Sean Devlin
  0 siblings, 2 replies; 5+ messages in thread
From: Jim Porter @ 2024-06-26  4:45 UTC (permalink / raw)
  To: Sean Devlin, 71778-done

Version: 30.1

On 6/25/2024 1:50 PM, Sean Devlin wrote:
> I've found it is possible to Eshell in the middle of a command. Here's a
> recipe:
[snip]
> $ for x in 1 2 3 4 5 { echo hello ; sleep 2 } > #<buffer test>
> 
> 4. While the above command is running, C-x b test
> 5. C-x b *eshell*

Tricky! But thankfully it was an easy fix. We just needed to make sure 
that when cleaning up in a timer after 'eshell-sentinel', we always do 
it from the Eshell buffer.

Fixed on both the master branch and the release branch, with a 
regression test.





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection
  2024-06-26  4:45 ` Jim Porter
@ 2024-06-26 13:01   ` Eli Zaretskii
  2024-06-26 15:57     ` Jim Porter
  2024-06-26 14:06   ` Sean Devlin
  1 sibling, 1 reply; 5+ messages in thread
From: Eli Zaretskii @ 2024-06-26 13:01 UTC (permalink / raw)
  To: Jim Porter; +Cc: jporterbugs, 71778, spd

> Date: Tue, 25 Jun 2024 21:45:56 -0700
> From: Jim Porter <jporterbugs@gmail.com>
> 
> Fixed on both the master branch and the release branch, with a 
> regression test.

Thanks.  But in the future, please install bugfix changes for Emacs 30
on the release branch; they will be merged to master when one of us
does such merges (which happens every few days as a matter of
routine).  The "install-on-master-then-cherry-pick" method should be
reserved for the rare cases where a change is installed on master
either by mistake or because the author believed it was not
appropriate for the release branch.





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection
  2024-06-26  4:45 ` Jim Porter
  2024-06-26 13:01   ` Eli Zaretskii
@ 2024-06-26 14:06   ` Sean Devlin
  1 sibling, 0 replies; 5+ messages in thread
From: Sean Devlin @ 2024-06-26 14:06 UTC (permalink / raw)
  To: Jim Porter; +Cc: 71778-done

> On Jun 26, 2024, at 12:45 AM, Jim Porter <jporterbugs@gmail.com> wrote:
> 
> Version: 30.1
> 
> On 6/25/2024 1:50 PM, Sean Devlin wrote:
>> I've found it is possible to Eshell in the middle of a command. Here's a
>> recipe:
> [snip]
>> $ for x in 1 2 3 4 5 { echo hello ; sleep 2 } > #<buffer test>
>> 4. While the above command is running, C-x b test
>> 5. C-x b *eshell*
> 
> Tricky! But thankfully it was an easy fix. We just needed to make sure that when cleaning up in a timer after 'eshell-sentinel', we always do it from the Eshell buffer.
> 
> Fixed on both the master branch and the release branch, with a regression test.

Thanks, verified!




^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection
  2024-06-26 13:01   ` Eli Zaretskii
@ 2024-06-26 15:57     ` Jim Porter
  0 siblings, 0 replies; 5+ messages in thread
From: Jim Porter @ 2024-06-26 15:57 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: spd, 71778

On 6/26/2024 6:01 AM, Eli Zaretskii wrote:
> Thanks.  But in the future, please install bugfix changes for Emacs 30
> on the release branch; they will be merged to master when one of us
> does such merges (which happens every few days as a matter of
> routine).  The "install-on-master-then-cherry-pick" method should be
> reserved for the rare cases where a change is installed on master
> either by mistake or because the author believed it was not
> appropriate for the release branch.

Sorry about that. I'd accidentally merged to master first, so had to fix 
things up by cherry-picking.





^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2024-06-26 15:57 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-25 20:50 bug#71778: 30.0.60; Eshell hangs when switching buffers during output redirection Sean Devlin
2024-06-26  4:45 ` Jim Porter
2024-06-26 13:01   ` Eli Zaretskii
2024-06-26 15:57     ` Jim Porter
2024-06-26 14:06   ` Sean Devlin

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).