GNU bug report logs -
#55230
CC Mode 5.35.1 (C++//l); Cache inconsistency
Previous Next
Full log
Message #11 received at 55230 <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Hello again, Michael.
On Tue, May 03, 2022 at 18:10:36 +0000, Alan Mackenzie wrote:
> On Mon, May 02, 2022 at 15:30:09 -0400, Michael Welsh Duggan wrote:
> > Package: cc-mode
> > From emacs -Q:
> > C-x C-f /tmp/foo.cpp RET
> > M-x c-toggle-parse-state-debug RET
> > "{}
> > After typing the close brace, I get the following:
> > c-parse-state inconsistency at 3: using cache: (2), from scratch: nil. POINT-MIN: 1
> > Old state:
> > (setq c-state-cache '(2) c-state-cache-good-pos 1 c-state-nonlit-pos-cache nil c-state-nonlit-pos-cache-limit 0 c-state-brace-pair-desert nil c-state-point-min 1 c-state-point-min-lit-type nil c-state-point-min-lit-start nil c-state-min-scan-pos 1 c-state-old-cpp-beg nil c-state-old-cpp-end nil c-parse-state-point 3)
> > I have not noticed any indentation errors due to this, but any cache
> > inconsistency might lead to errors down the line, hence this report.
> Many thanks for the bug report.
> This time it is not the cache mechanism itself which is at fault.
> Instead, it is the first character ", which since it is unbalanced by
> another ", has had its syntax is temporarily "commented out" by giving
> it a syntax-table property of "punctuation". The parse-state cache was
> generated whilst in this state, but used when it no longer was, hence
> the inconsistency.
> There are somewhere between 10 and 20 occurrences of c-parse-state in
> the source code which will need to be "protected" against this fault. I
> hope to be able to finish this work in the next two or three days, when
> I'll get back to you again.
There were actually 32 such occurrences, and they have generated a rather
large patch which I am taking the liberty of just sending to you. The
vast bulk of this patch is just putting (c-with-string-fences ....)
around these functions, reindenting them.
I've attached the patch as a separate file because it is so big. It
should apply cleanly to the CC Mode in the Emacs savannah master version.
Would you please apply it and try it out a bit, and let me know how well
it works. Thanks!
> > Emacs : GNU Emacs 29.0.50 (build 1, x86_64-pc-linux-gnu, X toolkit, cairo version 1.16.0)
> > of 2022-04-09
> > Package: CC Mode 5.35.1 (C++//l)
> > Buffer Style: gnu
> > c-emacs-features: (pps-extended-state col-0-paren posix-char-classes gen-string-delim gen-comment-delim syntax-properties 1-bit)
> > --
> > Michael Welsh Duggan
> > (md5i <at> md5i.com)
--
Alan Mackenzie (Nuremberg, Germany).
[diff.20220517.diff (text/plain, attachment)]
This bug report was last modified 2 years and 363 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.