[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#59738: c-ts-mode is slow with large buffers.
From: |
Alan Mackenzie |
Subject: |
bug#59738: c-ts-mode is slow with large buffers. |
Date: |
Thu, 1 Dec 2022 11:50:05 +0000 |
Hello, Emacs.
In an up to date (2022-11-30) master started as $ emacs --no-desktop:
The file .../drivers/gpu/drm/amd/include/asic_reg/dce/dce_12_0_sh_mask.h
in the Linux source tree is 6.8 MB big, consisting of a large number of
#defines and comments, but nothing else.
To scroll through it in c-ts-mode takes a little over 26 minutes on my
system. By comparison, in C Mode it takes 31 seconds. There would
appear to be a need for some optimisation in c-ts-mode, here.
The file
https://gitlab.com/wireshark/wireshark/-/raw/master/epan/dissectors/packet-rrc.c
(see bug #45248) (10 MB) takes 578 seconds to scroll in c-ts-mode. It
scrolls through the first 83% of the buffer rapidly, then chokes on a big
brace block initialisation. Also, the font-locking fails part way
through this brace block (without any apparent speed up).
For comparison, the scrolling takes 30 seconds in C Mode. There seems to
be a need for optimisation of c-ts-mode in this case, too.
For completeness, I used M-: (time-scroll) in the following for the
timings:
(defmacro time-it (&rest forms)
"Time the running of a sequence of forms using `float-time'.
Call like this: \"M-: (time-it (foo ...) (bar ...) ...)\"."
`(let ((start (float-time)))
,@forms
(- (float-time) start)))
(defun time-scroll (&optional arg)
(interactive "P")
(message "%s"
(time-it
(condition-case nil
(while t
(if arg (scroll-down) (scroll-up))
(sit-for 0))
(error nil)))))
--
Alan Mackenzie (Nuremberg, Germany).
- bug#59738: c-ts-mode is slow with large buffers.,
Alan Mackenzie <=
- bug#59738: c-ts-mode is slow with large buffers., Yuan Fu, 2022/12/03
- bug#59738: c-ts-mode is slow with large buffers., Yuan Fu, 2022/12/06
- bug#59738: c-ts-mode is slow with large buffers., Eli Zaretskii, 2022/12/07
- bug#59738: c-ts-mode is slow with large buffers., Yuan Fu, 2022/12/07
- bug#59738: c-ts-mode is slow with large buffers., Eli Zaretskii, 2022/12/08
- bug#59738: c-ts-mode is slow with large buffers., Alan Mackenzie, 2022/12/10
- bug#59738: c-ts-mode is slow with large buffers., Yuan Fu, 2022/12/10
- bug#59738: c-ts-mode is slow with large buffers., Eli Zaretskii, 2022/12/11
- bug#59738: c-ts-mode is slow with large buffers., Alan Mackenzie, 2022/12/11
- bug#59738: c-ts-mode is slow with large buffers., Dmitry Gutov, 2022/12/11