unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
@ 2024-03-29 11:31 Philip Kaludercic
  2024-03-30  6:57 ` Eli Zaretskii
  2024-04-03  9:35 ` Mattias Engdegård
  0 siblings, 2 replies; 19+ messages in thread
From: Philip Kaludercic @ 2024-03-29 11:31 UTC (permalink / raw)
  To: 70068

[-- Attachment #1: Type: text/plain, Size: 113 bytes --]

The main intention here is to avoid underlining the first line in the
*scratch* buffer when flymake is enabled:


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: [PATCH] Don't warn about lexical binding in lisp-interaction-mode --]
[-- Type: text/x-patch, Size: 1130 bytes --]

From 714cba0f576566e39b7ffeb77b8f9b80bb3003ff Mon Sep 17 00:00:00 2001
From: Philip Kaludercic <philipk@posteo.net>
Date: Fri, 29 Mar 2024 12:30:59 +0100
Subject: [PATCH] Don't warn about lexical binding in lisp-interaction-mode

* lisp/emacs-lisp/bytecomp.el (byte-compile-file): Suppress
warning in 'lisp-interaction-mode' buffers like the *scratch*
buffer.
---
 lisp/emacs-lisp/bytecomp.el | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/lisp/emacs-lisp/bytecomp.el b/lisp/emacs-lisp/bytecomp.el
index 7af568cfe34..e04df8f9ade 100644
--- a/lisp/emacs-lisp/bytecomp.el
+++ b/lisp/emacs-lisp/bytecomp.el
@@ -2234,7 +2234,8 @@ byte-compile-file
         (setq buffer-read-only nil
               filename buffer-file-name))
       ;; Don't inherit lexical-binding from caller (bug#12938).
-      (unless (local-variable-p 'lexical-binding)
+      (unless (or (local-variable-p 'lexical-binding)
+                  (derived-mode-p 'lisp-interaction-mode))
         (let ((byte-compile-current-buffer (current-buffer)))
           (displaying-byte-compile-warnings
            (byte-compile-warn-x
-- 
2.44.0


[-- Attachment #3: Type: text/plain, Size: 37 bytes --]


-- 
	Philip Kaludercic on peregrine

^ permalink raw reply related	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-03-29 11:31 bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode Philip Kaludercic
@ 2024-03-30  6:57 ` Eli Zaretskii
  2024-03-30 11:07   ` Philip Kaludercic
  2024-04-03  9:35 ` Mattias Engdegård
  1 sibling, 1 reply; 19+ messages in thread
From: Eli Zaretskii @ 2024-03-30  6:57 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: 70068

> From: Philip Kaludercic <philipk@posteo.net>
> Date: Fri, 29 Mar 2024 11:31:49 +0000
> 
> The main intention here is to avoid underlining the first line in the
> *scratch* buffer when flymake is enabled:

If this is the goal, why such a general change?  Wouldn't it be better
to special-case *scratch* in Flymake instead?  Making such
generalizations runs the risk of unintended consequences.





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-03-30  6:57 ` Eli Zaretskii
@ 2024-03-30 11:07   ` Philip Kaludercic
  2024-03-30 12:54     ` Eli Zaretskii
  0 siblings, 1 reply; 19+ messages in thread
From: Philip Kaludercic @ 2024-03-30 11:07 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 70068

Eli Zaretskii <eliz@gnu.org> writes:

>> From: Philip Kaludercic <philipk@posteo.net>
>> Date: Fri, 29 Mar 2024 11:31:49 +0000
>> 
>> The main intention here is to avoid underlining the first line in the
>> *scratch* buffer when flymake is enabled:
>
> If this is the goal, why such a general change?  Wouldn't it be better
> to special-case *scratch* in Flymake instead?  Making such
> generalizations runs the risk of unintended consequences.

My thinking was that one never needs to set the variable anyway, since
`lisp-interaction-mode' sets `lexical-binding' anyway.  Alternatively,
one could also modify the patch to check if `lexical-binding' is non-nil?

-- 
	Philip Kaludercic on peregrine





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-03-30 11:07   ` Philip Kaludercic
@ 2024-03-30 12:54     ` Eli Zaretskii
  2024-04-01  5:27       ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 1 reply; 19+ messages in thread
From: Eli Zaretskii @ 2024-03-30 12:54 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: Stefan Monnier, 70068

> From: Philip Kaludercic <philipk@posteo.net>
> Cc: 70068@debbugs.gnu.org
> Date: Sat, 30 Mar 2024 11:07:00 +0000
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> >> From: Philip Kaludercic <philipk@posteo.net>
> >> Date: Fri, 29 Mar 2024 11:31:49 +0000
> >> 
> >> The main intention here is to avoid underlining the first line in the
> >> *scratch* buffer when flymake is enabled:
> >
> > If this is the goal, why such a general change?  Wouldn't it be better
> > to special-case *scratch* in Flymake instead?  Making such
> > generalizations runs the risk of unintended consequences.
> 
> My thinking was that one never needs to set the variable anyway, since
> `lisp-interaction-mode' sets `lexical-binding' anyway.  Alternatively,
> one could also modify the patch to check if `lexical-binding' is non-nil?

The latter possibility would be better, I think.  Stefan, WDYT?





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-03-30 12:54     ` Eli Zaretskii
@ 2024-04-01  5:27       ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-04-03  8:52         ` Philip Kaludercic
  0 siblings, 1 reply; 19+ messages in thread
From: Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-04-01  5:27 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: Philip Kaludercic, 70068

>> My thinking was that one never needs to set the variable anyway, since
>> `lisp-interaction-mode' sets `lexical-binding' anyway.  Alternatively,
>> one could also modify the patch to check if `lexical-binding' is non-nil?
>
> The latter possibility would be better, I think.  Stefan, WDYT?

Testing `lexical-binding` sounds good: the purpose is to encourage people
to activate `lexical-binding`, rather than encourage them to add a magic cookie.


        Stefan






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-01  5:27       ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-04-03  8:52         ` Philip Kaludercic
  0 siblings, 0 replies; 19+ messages in thread
From: Philip Kaludercic @ 2024-04-03  8:52 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: Eli Zaretskii, 70068-done

Stefan Monnier <monnier@iro.umontreal.ca> writes:

>>> My thinking was that one never needs to set the variable anyway, since
>>> `lisp-interaction-mode' sets `lexical-binding' anyway.  Alternatively,
>>> one could also modify the patch to check if `lexical-binding' is non-nil?
>>
>> The latter possibility would be better, I think.  Stefan, WDYT?
>
> Testing `lexical-binding` sounds good: the purpose is to encourage people
> to activate `lexical-binding`, rather than encourage them to add a magic cookie.

OK, I have modified by patch and pushed it to master (0197db7b).

>
>         Stefan
>

-- 
	Philip Kaludercic on peregrine





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-03-29 11:31 bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode Philip Kaludercic
  2024-03-30  6:57 ` Eli Zaretskii
@ 2024-04-03  9:35 ` Mattias Engdegård
  2024-04-03 18:17   ` Philip Kaludercic
  1 sibling, 1 reply; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-03  9:35 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: Eli Zaretskii, Stefan Monnier, 70068

> -      (unless (local-variable-p 'lexical-binding)
> +      (unless (or (local-variable-p 'lexical-binding)
> +                  (null lexical-binding))

That logic doesn't make sense to me, and it clearly doesn't work so I reverted it.
(For some reason the test didn't catch it, but it's now been made more robust.)






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-03  9:35 ` Mattias Engdegård
@ 2024-04-03 18:17   ` Philip Kaludercic
  2024-04-03 19:07     ` Mattias Engdegård
  0 siblings, 1 reply; 19+ messages in thread
From: Philip Kaludercic @ 2024-04-03 18:17 UTC (permalink / raw)
  To: Mattias Engdegård; +Cc: Eli Zaretskii, Stefan Monnier, 70068

Mattias Engdegård <mattias.engdegard@gmail.com> writes:

>> -      (unless (local-variable-p 'lexical-binding)
>> +      (unless (or (local-variable-p 'lexical-binding)
>> +                  (null lexical-binding))
>
> That logic doesn't make sense to me, and it clearly doesn't work so I reverted it.
> (For some reason the test didn't catch it, but it's now been made more robust.)

You are right, I made a mistake; What I want to say is this:

--8<---------------cut here---------------start------------->8---
diff --git a/lisp/emacs-lisp/bytecomp.el b/lisp/emacs-lisp/bytecomp.el
index 5cff86784f0..a1194f2dc70 100644
--- a/lisp/emacs-lisp/bytecomp.el
+++ b/lisp/emacs-lisp/bytecomp.el
@@ -2234,7 +2234,8 @@ byte-compile-file
         (setq buffer-read-only nil
               filename buffer-file-name))
       ;; Don't inherit lexical-binding from caller (bug#12938).
-      (unless (local-variable-p 'lexical-binding)
+      (when (or (not (local-variable-p 'lexical-binding))
+                (null lexical-binding))
         (let ((byte-compile-current-buffer (current-buffer)))
           (displaying-byte-compile-warnings
            (byte-compile-warn-x
--8<---------------cut here---------------end--------------->8---

What makes me uncertain is that you say it makes "no sense", so I  want
to make sure I am not misunderstanding something completely.

-- 
	Philip Kaludercic on peregrine





^ permalink raw reply related	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-03 18:17   ` Philip Kaludercic
@ 2024-04-03 19:07     ` Mattias Engdegård
  2024-04-06 10:14       ` Mattias Engdegård
  0 siblings, 1 reply; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-03 19:07 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: Eli Zaretskii, Stefan Monnier, 70068

3 apr. 2024 kl. 20.17 skrev Philip Kaludercic <philipk@posteo.net>:

> You are right, I made a mistake; What I want to say is this:

> -      (unless (local-variable-p 'lexical-binding)
> +      (when (or (not (local-variable-p 'lexical-binding))
> +                (null lexical-binding))

Are you sure that you didn't mean

    (unless (or (local-variable-p 'lexical-binding)
                lexical-binding)

a.k.a.

    (when (and (not (local-variable-p 'lexical-binding)
               (not lexical-binding))

which may or may not make more sense? But how would either of these work, given that flymake runs a byte-compilation in a spawned Emacs and, as far as I can tell, propagates neither the buffer mode nor the lexical-binding value to that process?






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-03 19:07     ` Mattias Engdegård
@ 2024-04-06 10:14       ` Mattias Engdegård
  2024-04-08  7:21         ` Philip Kaludercic
  0 siblings, 1 reply; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-06 10:14 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: Eli Zaretskii, Stefan Monnier, 70068

[-- Attachment #1: Type: text/plain, Size: 276 bytes --]

If we want to do something about this, here are some options.

1. Add -*-lexical-binding:t-*- to initial-scratch-message.

2. It will sort itself out eventually as lexical-binding becomes the default. Sit and wait (a few years).

3. Something like the attached hack.


[-- Attachment #2: lexbind-warning-supp.diff --]
[-- Type: application/octet-stream, Size: 2788 bytes --]

diff --git a/lisp/emacs-lisp/bytecomp.el b/lisp/emacs-lisp/bytecomp.el
index 5cff86784f0..fb3278c08ab 100644
--- a/lisp/emacs-lisp/bytecomp.el
+++ b/lisp/emacs-lisp/bytecomp.el
@@ -2149,6 +2149,8 @@ byte-write-target-file
                 (cons tempfile target-file))
         (rename-file tempfile target-file t)))))
 
+(defvar bytecomp--inhibit-lexical-cookie-warning nil)
+
 ;;;###autoload
 (defun byte-compile-file (filename &optional load)
   "Compile a file of Lisp code named FILENAME into a file of byte code.
@@ -2234,7 +2236,8 @@ byte-compile-file
         (setq buffer-read-only nil
               filename buffer-file-name))
       ;; Don't inherit lexical-binding from caller (bug#12938).
-      (unless (local-variable-p 'lexical-binding)
+      (unless (or (local-variable-p 'lexical-binding)
+                  bytecomp--inhibit-lexical-cookie-warning)
         (let ((byte-compile-current-buffer (current-buffer)))
           (displaying-byte-compile-warnings
            (byte-compile-warn-x
diff --git a/lisp/progmodes/elisp-mode.el b/lisp/progmodes/elisp-mode.el
index 8a713bd19a2..6bba1199aec 100644
--- a/lisp/progmodes/elisp-mode.el
+++ b/lisp/progmodes/elisp-mode.el
@@ -2169,6 +2169,8 @@ elisp-flymake-byte-compile-load-path
                                   (dolist (path x t) (unless (stringp path)
                                                        (throw 'tag nil)))))))
 
+(defvar bytecomp--inhibit-lexical-cookie-warning)
+
 ;;;###autoload
 (defun elisp-flymake-byte-compile (report-fn &rest _args)
   "A Flymake backend for elisp byte compilation.
@@ -2184,7 +2186,14 @@ elisp-flymake-byte-compile
     (save-restriction
       (widen)
       (write-region (point-min) (point-max) temp-file nil 'nomessage))
-    (let* ((output-buffer (generate-new-buffer " *elisp-flymake-byte-compile*")))
+    (let* ((output-buffer (generate-new-buffer " *elisp-flymake-byte-compile*"))
+           ;; Hack: suppress warning about missing lexical cookie if the
+           ;; buffer has `lexical-binding' set, so that we don't
+           ;; complain about *scratch* buffers.
+           (warning-suppression-opt
+            (and lexical-binding
+                 '("--eval"
+                   "(setq bytecomp--inhibit-lexical-cookie-warning t)"))))
       (setq
        elisp-flymake--byte-compile-process
        (make-process
@@ -2196,6 +2205,7 @@ elisp-flymake-byte-compile
                    ;; "--eval" "(setq load-prefer-newer t)" ; for testing
                    ,@(mapcan (lambda (path) (list "-L" path))
                              elisp-flymake-byte-compile-load-path)
+                   ,@warning-suppression-opt
                    "-f" "elisp-flymake--batch-compile-for-flymake"
                    ,temp-file)
         :connection-type 'pipe

^ permalink raw reply related	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-06 10:14       ` Mattias Engdegård
@ 2024-04-08  7:21         ` Philip Kaludercic
  2024-04-08 11:41           ` Eli Zaretskii
  0 siblings, 1 reply; 19+ messages in thread
From: Philip Kaludercic @ 2024-04-08  7:21 UTC (permalink / raw)
  To: Mattias Engdegård; +Cc: Eli Zaretskii, Stefan Monnier, 70068

Mattias Engdegård <mattias.engdegard@gmail.com> writes:

> If we want to do something about this, here are some options.
>
> 1. Add -*-lexical-binding:t-*- to initial-scratch-message.
>
> 2. It will sort itself out eventually as lexical-binding becomes the default. Sit and wait (a few years).
>
> 3. Something like the attached hack.

I like the third option.

-- 
	Philip Kaludercic on peregrine





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-08  7:21         ` Philip Kaludercic
@ 2024-04-08 11:41           ` Eli Zaretskii
  2024-04-08 12:02             ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 1 reply; 19+ messages in thread
From: Eli Zaretskii @ 2024-04-08 11:41 UTC (permalink / raw)
  To: Philip Kaludercic; +Cc: mattias.engdegard, monnier, 70068

> From: Philip Kaludercic <philipk@posteo.net>
> Cc: Stefan Monnier <monnier@iro.umontreal.ca>,  Eli Zaretskii
>  <eliz@gnu.org>,  70068@debbugs.gnu.org
> Date: Mon, 08 Apr 2024 07:21:43 +0000
> 
> Mattias Engdegård <mattias.engdegard@gmail.com> writes:
> 
> > If we want to do something about this, here are some options.
> >
> > 1. Add -*-lexical-binding:t-*- to initial-scratch-message.
> >
> > 2. It will sort itself out eventually as lexical-binding becomes the default. Sit and wait (a few years).
> >
> > 3. Something like the attached hack.
> 
> I like the third option.

Agreed.

Stefan?





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-08 11:41           ` Eli Zaretskii
@ 2024-04-08 12:02             ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-04-09  8:57               ` Mattias Engdegård
  0 siblings, 1 reply; 19+ messages in thread
From: Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-04-08 12:02 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: Philip Kaludercic, mattias.engdegard, 70068

>> > If we want to do something about this, here are some options.
>> >
>> > 1. Add -*-lexical-binding:t-*- to initial-scratch-message.
>> >
>> > 2. It will sort itself out eventually as lexical-binding becomes the
>> > default. Sit and wait (a few years).
>> >
>> > 3. Something like the attached hack.
>> 
>> I like the third option.
>
> Agreed.
>
> Stefan?

I vote against 1, and I'm fine with both 2 and 3.


        Stefan






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-08 12:02             ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-04-09  8:57               ` Mattias Engdegård
  2024-04-09  9:51                 ` Eli Zaretskii
  0 siblings, 1 reply; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-09  8:57 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: Eli Zaretskii, Philip Kaludercic, 70068

8 apr. 2024 kl. 14.02 skrev Stefan Monnier <monnier@iro.umontreal.ca>:

>>> I like the third option.
>> 
>> Agreed.
> 
> I vote against 1, and I'm fine with both 2 and 3.

Looks like option 3 won. Actually I implemented option 3' which is like 3 but checks the mode instead of lexical-binding, on the grounds that a user who damages his lexical cookie by mistake wants to be reminded of it as soon as possible.






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-09  8:57               ` Mattias Engdegård
@ 2024-04-09  9:51                 ` Eli Zaretskii
  2024-04-09 10:45                   ` Mattias Engdegård
  0 siblings, 1 reply; 19+ messages in thread
From: Eli Zaretskii @ 2024-04-09  9:51 UTC (permalink / raw)
  To: Mattias Engdegård; +Cc: philipk, monnier, 70068

> From: Mattias Engdegård <mattias.engdegard@gmail.com>
> Date: Tue, 9 Apr 2024 10:57:40 +0200
> Cc: Eli Zaretskii <eliz@gnu.org>,
>  Philip Kaludercic <philipk@posteo.net>,
>  70068@debbugs.gnu.org
> 
> 8 apr. 2024 kl. 14.02 skrev Stefan Monnier <monnier@iro.umontreal.ca>:
> 
> >>> I like the third option.
> >> 
> >> Agreed.
> > 
> > I vote against 1, and I'm fine with both 2 and 3.
> 
> Looks like option 3 won. Actually I implemented option 3' which is like 3 but checks the mode instead of lexical-binding, on the grounds that a user who damages his lexical cookie by mistake wants to be reminded of it as soon as possible.

That's not what I see in the changes you installed on master.

But if you want to check the mode, against what would you compare it?





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-09  9:51                 ` Eli Zaretskii
@ 2024-04-09 10:45                   ` Mattias Engdegård
  2024-04-09 11:24                     ` Eli Zaretskii
  2024-04-09 13:35                     ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 2 replies; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-09 10:45 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: philipk, monnier, 70068

9 apr. 2024 kl. 11.51 skrev Eli Zaretskii <eliz@gnu.org>:

>> Looks like option 3 won. Actually I implemented option 3' which is like 3 but checks the mode instead of lexical-binding, on the grounds that a user who damages his lexical cookie by mistake wants to be reminded of it as soon as possible.
> 
> That's not what I see in the changes you installed on master.

Then I made a mistake, but I don't see where. The intent is to have flymake add the argument

  --eval (setq bytecomp--inhibit-lexical-cookie-warning t)

if (derived-mode-p 'lisp-interaction-mode) is true, and then make the warning conditional on that variable. Doesn't it work?

What I can see is an unrelated bug in flymake: if the first line of a buffer (of an .el file) is empty, then the compiler emits a lexical cookie warning but flymake doesn't show it. Stefan, is this because there is no text to attach the warning to?






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-09 10:45                   ` Mattias Engdegård
@ 2024-04-09 11:24                     ` Eli Zaretskii
  2024-04-09 13:35                     ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  1 sibling, 0 replies; 19+ messages in thread
From: Eli Zaretskii @ 2024-04-09 11:24 UTC (permalink / raw)
  To: Mattias Engdegård; +Cc: philipk, monnier, 70068

> From: Mattias Engdegård <mattias.engdegard@gmail.com>
> Date: Tue, 9 Apr 2024 12:45:18 +0200
> Cc: monnier@iro.umontreal.ca,
>  philipk@posteo.net,
>  70068@debbugs.gnu.org
> 
> 9 apr. 2024 kl. 11.51 skrev Eli Zaretskii <eliz@gnu.org>:
> 
> >> Looks like option 3 won. Actually I implemented option 3' which is like 3 but checks the mode instead of lexical-binding, on the grounds that a user who damages his lexical cookie by mistake wants to be reminded of it as soon as possible.
> > 
> > That's not what I see in the changes you installed on master.
> 
> Then I made a mistake, but I don't see where. The intent is to have flymake add the argument
> 
>   --eval (setq bytecomp--inhibit-lexical-cookie-warning t)
> 
> if (derived-mode-p 'lisp-interaction-mode) is true, and then make the warning conditional on that variable. Doesn't it work?

Ah, okay, then it's my misunderstanding: I saw the
(local-variable-p 'lexical-binding) test and thought you
intended to replace that with a mode test.  Apologies.





^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-09 10:45                   ` Mattias Engdegård
  2024-04-09 11:24                     ` Eli Zaretskii
@ 2024-04-09 13:35                     ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-04-09 13:42                       ` Mattias Engdegård
  1 sibling, 1 reply; 19+ messages in thread
From: Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-04-09 13:35 UTC (permalink / raw)
  To: Mattias Engdegård; +Cc: Eli Zaretskii, philipk, 70068

> What I can see is an unrelated bug in flymake: if the first line of a buffer
> (of an .el file) is empty, then the compiler emits a lexical cookie warning
> but flymake doesn't show it.  Stefan, is this because there is no text to
> attach the warning to?

Sorry, I'm not very familiar with flymake.


        Stefan






^ permalink raw reply	[flat|nested] 19+ messages in thread

* bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode
  2024-04-09 13:35                     ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-04-09 13:42                       ` Mattias Engdegård
  0 siblings, 0 replies; 19+ messages in thread
From: Mattias Engdegård @ 2024-04-09 13:42 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: Eli Zaretskii, Philip Kaludercic, 70068-done

9 apr. 2024 kl. 15.35 skrev Stefan Monnier <monnier@iro.umontreal.ca>:

> Sorry, I'm not very familiar with flymake.

I'll open a new bug for it. Closing this one.






^ permalink raw reply	[flat|nested] 19+ messages in thread

end of thread, other threads:[~2024-04-09 13:42 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-03-29 11:31 bug#70068: [PATCH] Don't warn about lexical binding in lisp-interaction-mode Philip Kaludercic
2024-03-30  6:57 ` Eli Zaretskii
2024-03-30 11:07   ` Philip Kaludercic
2024-03-30 12:54     ` Eli Zaretskii
2024-04-01  5:27       ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-03  8:52         ` Philip Kaludercic
2024-04-03  9:35 ` Mattias Engdegård
2024-04-03 18:17   ` Philip Kaludercic
2024-04-03 19:07     ` Mattias Engdegård
2024-04-06 10:14       ` Mattias Engdegård
2024-04-08  7:21         ` Philip Kaludercic
2024-04-08 11:41           ` Eli Zaretskii
2024-04-08 12:02             ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-09  8:57               ` Mattias Engdegård
2024-04-09  9:51                 ` Eli Zaretskii
2024-04-09 10:45                   ` Mattias Engdegård
2024-04-09 11:24                     ` Eli Zaretskii
2024-04-09 13:35                     ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-09 13:42                       ` Mattias Engdegård

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).