* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
@ 2019-06-28 19:01 Ergus
2019-07-02 13:36 ` Alan Mackenzie
0 siblings, 1 reply; 6+ messages in thread
From: Ergus @ 2019-06-28 19:01 UTC (permalink / raw)
To: 36423
In electric-pair-mode there are some files where inserting one " does
not insert the pair ". But on the other hand when I try to insert a
second " it inserts a pair for it so it ends with """.
It does not happen when the file is empty but for me it happens with
this file content.
---------------------------------------
#ifndef _SparseMatrix_functions_hpp_
#define _SparseMatrix_functions_hpp_
#endif
---------------------------------------
The behavior changes sometimes inserting a new line instead of the first
", or just not inserting any pair at all. This looks like an issue in a
backward search for a pair or something. Because it changes if withing
the define region or not.
When a region is active there is not issue and the quotes are inserted
in pairs around the region as expected.
This was reproduced with:
emacs -Q file.hpp
M-x electric-pair-modes
In GNU Emacs 27.0.50 (build 4, x86_64-pc-linux-gnu, GTK+ Version 3.24.9)
of 2019-06-28 built on Ergus
Repository revision: cb182ce6f8d2fa6e1509252fecc2b0e504e36d63
Repository branch: master
System Description: Arch Linux
Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.
main.hpp has auto save data; consider M-x recover-this-file
Electric-Pair mode enabled
funcall-interactively: End of buffer [3 times]
C-x <up> is undefined
user-error: End of history; no default available
Configured using:
'configure --prefix=/home/ergo/PhD/emacs/emacs.install_arch
--with-mailutils --with-x-toolkit=gtk3 --with-xft --with-modules'
Configured features:
XPM JPEG TIFF GIF PNG RSVG SOUND GPM DBUS GSETTINGS GLIB NOTIFY INOTIFY
ACL LIBSELINUX GNUTLS LIBXML2 FREETYPE HARFBUZZ M17N_FLT LIBOTF XFT ZLIB
TOOLKIT_SCROLL_BARS GTK3 X11 XDBE XIM MODULES THREADS LIBSYSTEMD JSON
PDUMPER LCMS2 GMP
Important settings:
value of $LC_CTYPE: en_US.UTF-8
value of $LANG: en_US.UTF-8
locale-coding-system: utf-8-unix
Major mode: C++//l
Minor modes in effect:
electric-pair-mode: t
tooltip-mode: t
global-eldoc-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
line-number-mode: t
transient-mark-mode: t
abbrev-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
format-spec rfc822 mml mml-sec password-cache epa derived epg epg-config
gnus-util rmail rmail-loaddefs text-property-search time-date seq
byte-opt gv bytecomp byte-compile cconv mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums mm-util mail-prsvr mail-utils cus-start cus-load
cc-mode cc-fonts easymenu cc-guess cc-menus cc-cmds cc-styles cc-align
cc-engine cc-vars cc-defs cl-loaddefs cl-lib term/tmux term/xterm xterm
elec-pair mule-util tooltip eldoc electric uniquify ediff-hook vc-hooks
lisp-float-type mwheel term/x-win x-win term/common-win x-dnd tool-bar
dnd fontset image regexp-opt fringe tabulated-list replace newcomment
text-mode elisp-mode lisp-mode prog-mode register page menu-bar
rfn-eshadow isearch timer select scroll-bar mouse jit-lock font-lock
syntax facemenu font-core term/tty-colors frame cl-generic cham georgian
utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao korean
japanese eucjp-ms cp51932 hebrew greek romanian slovak czech european
ethiopic indian cyrillic chinese composite charscript charprop
case-table epa-hook jka-cmpr-hook help simple abbrev obarray minibuffer
cl-preloaded nadvice loaddefs button faces cus-face macroexp files
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget hashtable-print-readable backquote threads dbusbind
inotify lcms2 dynamic-setting system-font-setting font-render-setting
move-toolbar gtk x-toolkit x multi-tty make-network-process emacs)
Memory information:
((conses 16 77664 8509)
(symbols 48 9388 1)
(strings 32 23186 1893)
(string-bytes 1 836866)
(vectors 16 10470)
(vector-slots 8 105810 5838)
(floats 8 25 245)
(intervals 56 215 0)
(buffers 992 12))
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
2019-06-28 19:01 bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content Ergus
@ 2019-07-02 13:36 ` Alan Mackenzie
2019-07-03 19:32 ` Ergus
0 siblings, 1 reply; 6+ messages in thread
From: Alan Mackenzie @ 2019-07-02 13:36 UTC (permalink / raw)
To: Ergus; +Cc: 36423
Hello, Ergus.
On Fri, Jun 28, 2019 at 21:01:31 +0200, Ergus wrote:
> In electric-pair-mode there are some files where inserting one " does
> not insert the pair ". But on the other hand when I try to insert a
> second " it inserts a pair for it so it ends with """.
> It does not happen when the file is empty but for me it happens with
> this file content.
> ---------------------------------------
> #ifndef _SparseMatrix_functions_hpp_
> #define _SparseMatrix_functions_hpp_
> #endif
> ---------------------------------------
I've just committed a fix to master which fixes some of the problem.
(For the rest of the problem, see bug #36474.)
> The behavior changes sometimes inserting a new line instead of the first
> ", or just not inserting any pair at all. This looks like an issue in a
> backward search for a pair or something. Because it changes if withing
> the define region or not.
Yes.
> When a region is active there is not issue and the quotes are inserted
> in pairs around the region as expected.
Also yes.
> This was reproduced with:
> emacs -Q file.hpp
> M-x electric-pair-modes
> In GNU Emacs 27.0.50 (build 4, x86_64-pc-linux-gnu, GTK+ Version 3.24.9)
> of 2019-06-28 built on Ergus
> Repository revision: cb182ce6f8d2fa6e1509252fecc2b0e504e36d63
> Repository branch: master
> System Description: Arch Linux
Thanks for taking the trouble to report this. It should be somewhat
better, now. Just a small point: it would have been helpful if you'd
mentioned C++ Mode in the Subject: (or even explicitly in the message).
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
2019-07-02 13:36 ` Alan Mackenzie
@ 2019-07-03 19:32 ` Ergus
2019-07-04 14:14 ` Alan Mackenzie
2019-07-08 9:48 ` Alan Mackenzie
0 siblings, 2 replies; 6+ messages in thread
From: Ergus @ 2019-07-03 19:32 UTC (permalink / raw)
To: Alan Mackenzie; +Cc: 36423
[-- Attachment #1: Type: text/plain, Size: 2402 bytes --]
Hi Alan:
Sorry for the bother again. After the fix you did, the "" issue is
better, but now there are new issues with the {} when I use pragmas for
example.
I attached you a picture (because this is the easier way to explain it)
As you can see it does not recognize the pairs correctly in one
case. And in the other it does not recognize the () at all. (Maybe the
second is not exactly the same issue)
The main problem is that because of this the automatic indentation is
affected.
An interesting thing is that in the line 136 out(vout[0; size]) it works
correctly. Maybe it has to do with the \ in the pragmas?
Thanks for the previous patch and in advance for the next ;)
Ergus
On Tue, Jul 02, 2019 at 01:36:41PM +0000, Alan Mackenzie wrote:
>Hello, Ergus.
>
>On Fri, Jun 28, 2019 at 21:01:31 +0200, Ergus wrote:
>> In electric-pair-mode there are some files where inserting one " does
>> not insert the pair ". But on the other hand when I try to insert a
>> second " it inserts a pair for it so it ends with """.
>
>> It does not happen when the file is empty but for me it happens with
>> this file content.
>
>> ---------------------------------------
>> #ifndef _SparseMatrix_functions_hpp_
>> #define _SparseMatrix_functions_hpp_
>
>
>
>> #endif
>> ---------------------------------------
>
>I've just committed a fix to master which fixes some of the problem.
>(For the rest of the problem, see bug #36474.)
>
>> The behavior changes sometimes inserting a new line instead of the first
>> ", or just not inserting any pair at all. This looks like an issue in a
>> backward search for a pair or something. Because it changes if withing
>> the define region or not.
>
>Yes.
>
>> When a region is active there is not issue and the quotes are inserted
>> in pairs around the region as expected.
>
>Also yes.
>
>> This was reproduced with:
>
>> emacs -Q file.hpp
>> M-x electric-pair-modes
>
>> In GNU Emacs 27.0.50 (build 4, x86_64-pc-linux-gnu, GTK+ Version 3.24.9)
>> of 2019-06-28 built on Ergus
>> Repository revision: cb182ce6f8d2fa6e1509252fecc2b0e504e36d63
>> Repository branch: master
>> System Description: Arch Linux
>
>Thanks for taking the trouble to report this. It should be somewhat
>better, now. Just a small point: it would have been helpful if you'd
>mentioned C++ Mode in the Subject: (or even explicitly in the message).
>
>--
>Alan Mackenzie (Nuremberg, Germany).
[-- Attachment #2: Screenshot_2019-07-03_21-14-59.png --]
[-- Type: image/png, Size: 25173 bytes --]
[-- Attachment #3: Screenshot_2019-07-03_21-22-52.png --]
[-- Type: image/png, Size: 20684 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
2019-07-03 19:32 ` Ergus
@ 2019-07-04 14:14 ` Alan Mackenzie
2019-07-08 9:48 ` Alan Mackenzie
1 sibling, 0 replies; 6+ messages in thread
From: Alan Mackenzie @ 2019-07-04 14:14 UTC (permalink / raw)
To: Ergus; +Cc: 36423
Hello, Ergus.
On Wed, Jul 03, 2019 at 21:32:00 +0200, Ergus wrote:
> Hi Alan:
> Sorry for the bother again.
No bother!
> After the fix you did, the "" issue is better, but now there are new
> issues with the {} when I use pragmas for example.
> I attached you a picture (because this is the easier way to explain it)
Nevertheless, is there any chance you could send me a copy of the code,
so that I don't have to type it in myself from the screenshots?
> As you can see it does not recognize the pairs correctly in one
> case. And in the other it does not recognize the () at all. (Maybe the
> second is not exactly the same issue)
That, indeed, needs looking at.
> The main problem is that because of this the automatic indentation is
> affected.
> An interesting thing is that in the line 136 out(vout[0; size]) it works
> correctly. Maybe it has to do with the \ in the pragmas?
> Thanks for the previous patch and in advance for the next ;)
> Ergus
Let's look forward to that!
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
2019-07-03 19:32 ` Ergus
2019-07-04 14:14 ` Alan Mackenzie
@ 2019-07-08 9:48 ` Alan Mackenzie
2019-07-08 10:29 ` Alan Mackenzie
1 sibling, 1 reply; 6+ messages in thread
From: Alan Mackenzie @ 2019-07-08 9:48 UTC (permalink / raw)
To: Ergus; +Cc: 36423-done
Hello, Ergus.
On Wed, Jul 03, 2019 at 21:32:00 +0200, Ergus wrote:
> Hi Alan:
> Sorry for the bother again. After the fix you did, the "" issue is
> better, but now there are new issues with the {} when I use pragmas for
> example.
OK, thanks! I've corrected a further problem with " in
electric-pair-mode, and I'm taking the liberty of closing your bug. ;-)
> I attached you a picture (because this is the easier way to explain it)
This is actually a different bug. If you haven't done so already, could
you please raise this as a bug in its own right. Thanks.
Just as a matter of interest, please enclose a copy of the C++ file (or
even better, just the relevant part of it) so as to save me the bother of
having to type it in. Thanks!
> As you can see it does not recognize the pairs correctly in one
> case. And in the other it does not recognize the () at all. (Maybe the
> second is not exactly the same issue)
> The main problem is that because of this the automatic indentation is
> affected.
> An interesting thing is that in the line 136 out(vout[0; size]) it works
> correctly. Maybe it has to do with the \ in the pragmas?
> Thanks for the previous patch and in advance for the next ;)
> Ergus
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content.
2019-07-08 9:48 ` Alan Mackenzie
@ 2019-07-08 10:29 ` Alan Mackenzie
0 siblings, 0 replies; 6+ messages in thread
From: Alan Mackenzie @ 2019-07-08 10:29 UTC (permalink / raw)
To: Ergus; +Cc: 36423-done
Hello again, Ergus.
On Mon, Jul 08, 2019 at 09:48:01 +0000, Alan Mackenzie wrote:
> On Wed, Jul 03, 2019 at 21:32:00 +0200, Ergus wrote:
> > Hi Alan:
> > Sorry for the bother again. After the fix you did, the "" issue is
> > better, but now there are new issues with the {} when I use pragmas for
> > example.
> OK, thanks! I've corrected a further problem with " in
> electric-pair-mode, and I'm taking the liberty of closing your bug. ;-)
> > I attached you a picture (because this is the easier way to explain it)
> This is actually a different bug. If you haven't done so already, could
> you please raise this as a bug in its own right. Thanks.
Actually, there's no need for this, I understand what's happening now
and it's "not a bug" - sort of.
In the lines:
1. printf ("Hello
2. world");
, there is an invalid string on L1, extending from " to the end of the
line. There is also an invalid string on L2, starting at the ", which
encloses the ). Thus this ), being inside a string, can't match the (
on L1.
Sorry I hadn't realised this half an hour ago.
Due to insistent complaints, I'm looking at modifying this "invalid
string" mechanism so that although it would fontify as it does now, it
would allow things like these two parentheses to match up.
[ .... ]
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2019-07-08 10:29 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-06-28 19:01 bug#36423: 27.0.50; electric-pair-mode not working properly depending of file content Ergus
2019-07-02 13:36 ` Alan Mackenzie
2019-07-03 19:32 ` Ergus
2019-07-04 14:14 ` Alan Mackenzie
2019-07-08 9:48 ` Alan Mackenzie
2019-07-08 10:29 ` Alan Mackenzie
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).