From: haj@posteo.de (Harald Jörg)
To: Stefan Monnier <monnier@iro.umontreal.ca>
Cc: 37127@debbugs.gnu.org
Subject: bug#37127: [PATCH] cperl-mode: Suppress a misleading message
Date: Fri, 30 Oct 2020 21:19:41 +0100 [thread overview]
Message-ID: <87zh43cvqa.fsf@hajtower> (raw)
In-Reply-To: <jwvpn4zaj1j.fsf-monnier+emacs@gnu.org> (Stefan Monnier's message of "Fri, 30 Oct 2020 10:30:04 -0400")
Stefan Monnier <monnier@iro.umontreal.ca> writes:
>> +(ert-deftest cperl-bug37127 ()
> [...]
>> + ;; part two: Regex terminator missing -> message
>> + (ert-with-message-capture collected-messages
>> + (with-temp-buffer
>> + (insert "$_ =~ /(..;")
>> + (goto-char (point-min))
>> + (cperl-mode)
>> + (search-forward ".")
>> + (let ((last-command-event ?\)))
>> + (cperl-electric-rparen 1)
>> + (cperl-find-pods-heres (point-min) (point-max) t)))
>> + (should (string-match "^End of .* string/RE"
>> + collected-messages)))))
>
> Why is this behavior desirable?
> I mean, I don't necessarily mind it, but as a user I find it odd that
> typing a `)` which has a matching `(` nearby (which can be found without
> crossing any string/RE boundary) should emit a warning about some
> "unrelated" surrounding entity like the RE in which it is located.
In an unterminated RE, the message will appear for every single
character you type, until the RE is terminated. I'd find it odd if the
`)` was the only character where the message didn't appear :)
> Emacs usually doesn't emit any such warning when editing within an
> unclosed string.
That's true. However, unclosed strings are rather simple constructs
when compared to Perl's quote-like operators. Often, in particular with
the /x modifier, they span several lines. The message contains
information about which operator is currently being processed, and also
what terminator is used. In Perl, almost any non-whitespace character
can be used as a delimiter, including letters, quotes, comment starters,
and colons. So, I think the warning is ok as a real-time syntax check.
> I don't think we should necessarily change CPerl's behavior in this
> regard, but that we shouldn't consider it a feature and thus shouldn't
> enforce it in our tests.
I see now that at least this test should be skipped in Perl mode, which
I failed to do. Again. Sorry for that. In general, handling of REs
with non-standard delimiters is one of the areas where Perl mode has
significant deficiencies.
But of course, I'm also fine with just deleting this test case. I wrote
it more out of a habit to check that the fix doesn't change the behavior
in other situations.
--
Cheers,
haj
next prev parent reply other threads:[~2020-10-30 20:19 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-08-21 12:17 bug#37127: 27.0.50; in cperl mode, scan-error Unbalanced parentheses Vincent Lefevre
2019-10-03 23:02 ` Stefan Kangas
2020-10-29 21:11 ` bug#37127: [PATCH] cperl-mode: Suppress a misleading message Harald Jörg
2020-10-30 12:24 ` Lars Ingebrigtsen
2020-10-30 14:30 ` Stefan Monnier
2020-10-30 20:19 ` Harald Jörg [this message]
2020-10-30 22:12 ` Stefan Monnier
2020-10-31 1:09 ` Harald Jörg
2020-11-02 22:52 ` bug#37127: [PATCH] A final tweak: Skip the test for older Emacsen Harald Jörg
2020-11-02 23:13 ` Stefan Kangas
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=87zh43cvqa.fsf@hajtower \
--to=haj@posteo.de \
--cc=37127@debbugs.gnu.org \
--cc=monnier@iro.umontreal.ca \
/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).