unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Alan Mackenzie <acm@muc.de>
To: Eli Zaretskii <eliz@gnu.org>
Cc: gregory@heytings.org, larsi@gnus.org, emacs-devel@gnu.org
Subject: Re: New optimisations for long raw strings in C++ Mode.
Date: Thu, 11 Aug 2022 16:54:47 +0000	[thread overview]
Message-ID: <YvU0V1tFE6hBROqB@ACM> (raw)
In-Reply-To: <834jykq9m6.fsf@gnu.org>

Hello, Eli.

On Wed, Aug 10, 2022 at 20:41:37 +0300, Eli Zaretskii wrote:
> > Date: Wed, 10 Aug 2022 17:32:46 +0000
> > Cc: gregory@heytings.org, larsi@gnus.org, emacs-devel@gnu.org
> > From: Alan Mackenzie <acm@muc.de>

> > > > > You seem to disagree with a major idea of the design of the Emacs
> > > > > display engine.

> > > > I don't think I do.  I think you mean the idea of lazy fontification,
> > > > though you haven't been specific.

> > > No, I mean the idea that redisplay processes only a small amount of
> > > buffer text around the window.

> > I don't think such an idea is coherent, due to the lack of precision of
> > the word "processes".  I understand that redisplay _fontifies_ only a
> > small amount of buffer text.  However, it can get better results if it is
> > free to _look_ at text anywhere in the buffer.

> Think about the _idea_ of that: we want to process as little as
> absolutely necessary for display.  It follows that every code we
> invoke as part of that job should strive to do the same.

I suppose the problem here is differing notions of "absolute necessity".

> > You seem to be conflating "fontifying" with "looking at".  I don't think
> > that's helpful.

> I'm not talking about "looking at", I'm taking about processing.
> fontification-functions rarely go to far places because they just want
> to "look", they go there because they want to process text there,
> possibly process all the text from there to window start.

OK, I think I see what you mean, now.

But I still think it's useful to make a distinction between looking at
(for example, the 17 ns per character that parse-partial-sexp takes) and
something like the fontification of a C declaration by
c-font-lock-declarations, which takes much, much longer.

> > > > This is absolutely necessary correctly to fontify (long) strings and
> > > > comments, for example.

> > > Only if you assume the most simplistic processing.

> > If you open a file in its middle (e.g., by desktop), and there's an open
> > block comment there, you've got to look arbitrarily far back to detect
> > that state.

> Really?  Then please tell me how is it that we the humans can detect
> incorrect fontifications even when shown partial strings and comments?

I can't really see how that question follows on from the premiss, but
human brains are wired to detect patterns at a single glance in a way
that computers aren't, at least not yet.

> We know that fontifications are incorrect, and where strings or
> comments start or end immediately, just after a single glance.  We
> never need to go to BOB to find that out.

Before the days of font-locking in editors, a standard problem was when a
comment didn't end where the user thought it did, for lack of a comment
ender.  There was a particular problem in Pascal (whose precise details
aren't that important) where an unclosed comment on the THEN branch of an
IF statement would swallow up the ELSE branch completely, leaving no
visible trace or syntactic error.

It's worth while being careful about strings and comments.

-- 
Alan Mackenzie (Nuremberg, Germany).



  parent reply	other threads:[~2022-08-11 16:54 UTC|newest]

Thread overview: 45+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-08-06 21:29 New optimisations for long raw strings in C++ Mode Alan Mackenzie
2022-08-07 12:49 ` Lars Ingebrigtsen
2022-08-07 13:25   ` Alan Mackenzie
2022-08-07 13:34     ` Lars Ingebrigtsen
2022-08-07 14:40       ` Alan Mackenzie
2022-08-07 14:41         ` Lars Ingebrigtsen
2022-08-07 14:54         ` Lars Ingebrigtsen
2022-08-07 16:13           ` Alan Mackenzie
2022-08-07 16:17             ` Eli Zaretskii
2022-08-09 11:00               ` Alan Mackenzie
2022-08-09 15:35                 ` Lars Ingebrigtsen
2022-08-09 15:38                   ` Lars Ingebrigtsen
2022-08-09 16:05                     ` Alan Mackenzie
2022-08-09 16:34                       ` Eli Zaretskii
2022-08-09 20:39                         ` Gregory Heytings
2022-08-09 21:43                           ` Alan Mackenzie
2022-08-09 23:05                             ` Stefan Monnier
2022-08-10  2:43                               ` Eli Zaretskii
2022-08-10  7:42                             ` Gregory Heytings
2022-08-10 13:28                             ` Eli Zaretskii
2022-08-10 16:23                               ` Alan Mackenzie
2022-08-10 16:35                                 ` Eli Zaretskii
2022-08-10 16:50                                   ` Alan Mackenzie
2022-08-10 16:58                                     ` Eli Zaretskii
2022-08-10 17:32                                       ` Alan Mackenzie
2022-08-10 17:41                                         ` Eli Zaretskii
2022-08-10 22:31                                           ` Stefan Monnier
2022-08-11  6:21                                             ` Eli Zaretskii
2022-08-11  7:37                                               ` Stefan Monnier
2022-08-11  6:27                                             ` Immanuel Litzroth
2022-08-11 16:54                                           ` Alan Mackenzie [this message]
2022-08-11 17:15                                             ` Eli Zaretskii
2022-08-12 13:05                                           ` Lynn Winebarger
2022-08-12 13:18                                             ` Eli Zaretskii
2022-08-11 15:47                                         ` Yuri Khan
2022-08-11 16:04                                           ` Eli Zaretskii
2022-08-10 17:19                                 ` Gregory Heytings
2022-08-10 17:21                                   ` Eli Zaretskii
2022-08-10 19:45                                   ` Alan Mackenzie
2022-08-14 20:15                                     ` Alan Mackenzie
2022-08-15  8:00                                       ` Gregory Heytings
2022-08-10 13:25                     ` Eli Zaretskii
2022-08-12 12:44                       ` Lars Ingebrigtsen
2022-08-12 12:52                         ` Eli Zaretskii
2022-08-07 15:00         ` Eli Zaretskii

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=YvU0V1tFE6hBROqB@ACM \
    --to=acm@muc.de \
    --cc=eliz@gnu.org \
    --cc=emacs-devel@gnu.org \
    --cc=gregory@heytings.org \
    --cc=larsi@gnus.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).