bug-gnu-emacs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#66669: 30.0.50; [EGLOT] Emacs freezes when server sends a ton of pro


From: Yuan Fu
Subject: bug#66669: 30.0.50; [EGLOT] Emacs freezes when server sends a ton of progress notifications
Date: Sun, 22 Oct 2023 17:39:42 -0700


> On Oct 22, 2023, at 7:52 AM, João Távora <joaotavora@gmail.com> wrote:
> 
> On Sun, Oct 22, 2023 at 5:50 AM Eli Zaretskii <eliz@gnu.org> wrote:
>> 
>>> Cc: joaotavora@gmail.com
>>> From: Yuan Fu <casouri@gmail.com>
>>> Date: Sat, 21 Oct 2023 12:10:49 -0700
>>> 
>>> 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.
>>> 
>>> Setting eglot-report-progress to nil doesn’t help me, presumably because 
>>> eglot still needs to process the notifications.
>> 
>> Can't this information be processed in chunks, not in one go?
> 
> Maybe, depending on what that means. I think it's important to
> get to the bottom of Yuan's "presumably" first, preferably by
> reproducing his problem.

Apologize for doubting eglot's ability to process messages :-) When trying to 
reproduce the problem, I eventually found out that it was project-files that 
was blocking. And project-files was blocking because I used a custom project 
method, which doesn’t properly ignore the build directory, which contains a ton 
of small files.

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

I do have eglot-events-buffer-size set to 0. I observed the freeze, reset it to 
some large value, and saw a bunch of notifications, so I assumed that was the 
problem. That turns out to be very wrong :-)

Personally I also think the default value should be 0. (I wonder if disabling 
pp would improve it enough?) Eglot is really borderline non-usable when the 
value is non-0 and the language server is chatty (eg, rust, typescript). I 
certainly don’t want people to try out eglot, see the lag, and conclude that 
“Emacs is slow”.

Maybe providing a simple command like M-x eglot-enable-logging, and tell new 
users to turn this on and restart eglot, is good enough. But I’m not the one 
that dealt with eglot bug reports, maybe restarting eglot can’t reproduce the 
error in many cases?

Yuan




reply via email to

[Prev in Thread] Current Thread [Next in Thread]