GNU bug report logs -
#46859
28.0.50; [PATCH]: Add option to truncate long lines in xref.el
Previous Next
Reported by: Theodor Thornhill <theo <at> thornhill.no>
Date: Mon, 1 Mar 2021 20:42:01 UTC
Severity: normal
Tags: patch
Found in version 28.0.50
Fixed in version 28.1
Done: Dmitry Gutov <dgutov <at> yandex.ru>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
On 07.03.2021 00:26, Dmitry Gutov wrote:
> - What do you think about making an effort to actually retain all the
> matches in the output? That would mean interpreting the
> xref-truncate-line-to value (or however the var could be renamed) as the
> maximum number of chars to render on the line *per match*. And if there
> is too much text between them, those parts can become "(truncated...)".
> Your current implementation can cut off valid matches, and we probably
> want to preserve them if feasible. OTOH, the default value could go down
> to 200 with this approach.
Please try out the attached preparation patch.
It improves the performance of the "very long line" case drastically
over here, while not doing any truncation yet. Looks like we regressed
that case when we added rendering of multiple matches on the same line.
We can add the truncation feature on top of it.
Probably also in xref--collect-matches-1 (truncating the value of
SUMMARY just before the xref-make-match call).
Alternatively, we could experiment with hiding parts of the long line
using some display/visibility features (except the truncate-lines
variable, that one keeps things slow). That could be done in
xref--insert-xrefs or somewhere nearby. That is trickier, though, given
that we'll probably want to unhide it (wholly or partially) when
iterating over matches inside.
[xref-insert-xrefs-sparingly.diff (text/x-patch, attachment)]
This bug report was last modified 4 years and 89 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.