GNU bug report logs - #66669
30.0.50; [EGLOT] Emacs freezes when server sends a ton of progress notifications

Previous Next

Package: emacs;

Reported by: Yuan Fu <casouri <at> gmail.com>

Date: Sat, 21 Oct 2023 19:12:02 UTC

Severity: normal

Found in version 30.0.50

Done: Yuan Fu <casouri <at> gmail.com>

Bug is archived. No further changes may be made.

Full log


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

From: João Távora <joaotavora <at> gmail.com>
To: Yuan Fu <casouri <at> gmail.com>
Cc: 66669 <at> debbugs.gnu.org
Subject: Re: bug#66669: 30.0.50; [EGLOT] Emacs freezes when server sends a ton
 of progress notifications
Date: Sat, 21 Oct 2023 22:01:50 +0100
On Sat, Oct 21, 2023 at 8:11 PM Yuan Fu <casouri <at> gmail.com> wrote:
>
> X-Debbugs-CC: joaotavora <at> gmail.com
>
> I use rust’s language server (rust-analyzer) with eglot. And
> whenever I turn eglot on for a project, Emacs freezes for a good
> 30 seconds, busy updating the eglot progress indicator, before I
> can do anything. I think the reason is that the rust language server
> sends a ton of progress notifications, which completely blocks Emacs
> before it’s done.

hi Yuan,

Two things:

* Would be nice to have a reproduction recipe.  I have rust-analyzer but
  one project where I try it regularly, the "bevy" graphics engine [1]
  Seems to work OK there.  You say "a project", but for bevy
  it starts up fast (maybe not even half a second) and works quite well.

  No Emacs freeze at all.  Tried removing the cache with git clean -fdx and
  I get all the notifications cleanly with no slowdown.

  So please include Emacs versions (master preferred, should be trivial
  for you), Eglot version, rust-analyzer version and preferably an Emacs
  -Q invocation with the simplest Rust project you can share that
  exhibits this behaviour.

* Have you profiled?  Have you tried setting eglot-events-buffer-size
  to 0 (and restart Eglot) as suggested in the Eglot manual?  Many
  performance problems are due to JSON objects being pretty printed in
  the Eglot events buffer (BTW some users ask me to  turn it to 0 by
  default, but the pros don't outweigh the cons, which in this case is
  we would lose a valuable tool for newbie users with exotic servers to
  send me their debug data easily)

João

[1] https://github.com/bevyengine/bevy




This bug report was last modified 1 year and 267 days ago.

Previous Next


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