GNU bug report logs -
#45610
27.1; Symbol’s function definition is void: seq-concatenate
Previous Next
Reported by: Leo Liu <sdl.web <at> gmail.com>
Date: Sat, 2 Jan 2021 12:30:01 UTC
Severity: normal
Found in version 27.1
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 45610 in the body.
You can then email your comments to 45610 AT debbugs.gnu.org in the normal way.
Toggle the display of automated, internal messages from the tracker.
Report forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 12:30:01 GMT)
Full text and
rfc822 format available.
Acknowledgement sent
to
Leo Liu <sdl.web <at> gmail.com>
:
New bug report received and forwarded. Copy sent to
bug-gnu-emacs <at> gnu.org
.
(Sat, 02 Jan 2021 12:30:01 GMT)
Full text and
rfc822 format available.
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
I have the following macro that is working until 27.1.
(defmacro cl-concatenatef (type place &rest sequences)
`(cl-callf2 cl-concatenate ,type ,place ,@sequences))
cl-concatenate is inlinable (since forever) as declared in cl-macs:
(cl-proclaim '(inline cl-acons cl-map cl-concatenate cl-notany
cl-notevery cl-revappend cl-nreconc gethash))
In 27.1 after expansion only (apply #'seq-concatenate type sequences)
remains bypassing the cl-concatenate autoload which is supposed to load
the dependency seq.el.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 12:48:02 GMT)
Full text and
rfc822 format available.
Message #8 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> From: Leo Liu <sdl.web <at> gmail.com>
> Date: Sat, 02 Jan 2021 20:29:37 +0800
>
> I have the following macro that is working until 27.1.
>
> (defmacro cl-concatenatef (type place &rest sequences)
> `(cl-callf2 cl-concatenate ,type ,place ,@sequences))
>
> cl-concatenate is inlinable (since forever) as declared in cl-macs:
>
> (cl-proclaim '(inline cl-acons cl-map cl-concatenate cl-notany
> cl-notevery cl-revappend cl-nreconc gethash))
>
> In 27.1 after expansion only (apply #'seq-concatenate type sequences)
> remains bypassing the cl-concatenate autoload which is supposed to load
> the dependency seq.el.
What did that expand to in Emacs 26?
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 14:23:01 GMT)
Full text and
rfc822 format available.
Message #11 received at 45610 <at> debbugs.gnu.org (full text, mbox):
On 2021-01-02 14:47 +0200, Eli Zaretskii wrote:
> What did that expand to in Emacs 26?
The body of cl-concatenate before Emacs 27:
(pcase type
(`vector (apply #'vconcat sequences))
(`string (apply #'concat sequences))
(`list (apply #'append (append sequences '(nil))))
(_ (error "Not a sequence type name: %S" type)))
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 14:27:02 GMT)
Full text and
rfc822 format available.
Message #14 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> From: Leo Liu <sdl.web <at> gmail.com>
> Cc: 45610 <at> debbugs.gnu.org
> Date: Sat, 02 Jan 2021 22:22:35 +0800
>
> On 2021-01-02 14:47 +0200, Eli Zaretskii wrote:
> > What did that expand to in Emacs 26?
>
> The body of cl-concatenate before Emacs 27:
>
> (pcase type
> (`vector (apply #'vconcat sequences))
> (`string (apply #'concat sequences))
> (`list (apply #'append (append sequences '(nil))))
> (_ (error "Not a sequence type name: %S" type)))
Thanks. Then does the patch below fix the problem in Emacs 27.1?
diff --git a/lisp/emacs-lisp/cl-extra.el b/lisp/emacs-lisp/cl-extra.el
index 9c9da4a..a6e6619 100644
--- a/lisp/emacs-lisp/cl-extra.el
+++ b/lisp/emacs-lisp/cl-extra.el
@@ -556,6 +556,7 @@ cl-subseq
(defun cl-concatenate (type &rest sequences)
"Concatenate, into a sequence of type TYPE, the argument SEQUENCEs.
\n(fn TYPE SEQUENCE...)"
+ (require 'seq)
(apply #'seq-concatenate type sequences))
;;; List functions.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 16:08:01 GMT)
Full text and
rfc822 format available.
Message #17 received at 45610 <at> debbugs.gnu.org (full text, mbox):
On 2021-01-02 16:25 +0200, Eli Zaretskii wrote:
> Thanks. Then does the patch below fix the problem in Emacs 27.1?
Yes it does.
> diff --git a/lisp/emacs-lisp/cl-extra.el b/lisp/emacs-lisp/cl-extra.el
> index 9c9da4a..a6e6619 100644
> --- a/lisp/emacs-lisp/cl-extra.el
> +++ b/lisp/emacs-lisp/cl-extra.el
> @@ -556,6 +556,7 @@ cl-subseq
> (defun cl-concatenate (type &rest sequences)
> "Concatenate, into a sequence of type TYPE, the argument SEQUENCEs.
> \n(fn TYPE SEQUENCE...)"
> + (require 'seq)
> (apply #'seq-concatenate type sequences))
>
> ;;; List functions.
But it seems the function will become slower when called regularly
because of the (require 'seq).
Is it better to remove cl-concatenate from the cl-proclaim list in
cl-macs.el?
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 16:32:01 GMT)
Full text and
rfc822 format available.
Message #20 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> From: Leo Liu <sdl.web <at> gmail.com>
> Cc: 45610 <at> debbugs.gnu.org
> Date: Sun, 03 Jan 2021 00:07:47 +0800
>
> On 2021-01-02 16:25 +0200, Eli Zaretskii wrote:
> > Thanks. Then does the patch below fix the problem in Emacs 27.1?
>
> Yes it does.
Then I'd like to push this fix to the release branch, but...
> > (defun cl-concatenate (type &rest sequences)
> > "Concatenate, into a sequence of type TYPE, the argument SEQUENCEs.
> > \n(fn TYPE SEQUENCE...)"
> > + (require 'seq)
> > (apply #'seq-concatenate type sequences))
> >
> > ;;; List functions.
>
> But it seems the function will become slower when called regularly
> because of the (require 'seq).
...slightly, yes.
> Is it better to remove cl-concatenate from the cl-proclaim list in
> cl-macs.el?
Wouldn't that make it even slower? And cause incompatibilities with
already byte-compiled files that saw the original cl-macs.el?
But I'm not an expert on these issues, so I'l defer to Stefan and Lars
here.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 16:36:02 GMT)
Full text and
rfc822 format available.
Message #23 received at 45610 <at> debbugs.gnu.org (full text, mbox):
Eli Zaretskii <eliz <at> gnu.org> writes:
> But I'm not an expert on these issues, so I'l defer to Stefan and Lars
> here.
Hey, what did I do? :-)
I think the easiest fix here is to put an autoload cookie on
seq-concatenate. But there may be something off on the macro expansion
that should be fixed instead, perhaps?
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sat, 02 Jan 2021 16:46:02 GMT)
Full text and
rfc822 format available.
Message #26 received at 45610 <at> debbugs.gnu.org (full text, mbox):
On 2021-01-02 18:30 +0200, Eli Zaretskii wrote:
> Wouldn't that make it even slower?
Indeed. But my suggestion to remove it was based on the fact that
cl-concatenate depends on another package at runtime, unlike other items
on that list.
> And cause incompatibilities with already byte-compiled files that saw
> the original cl-macs.el?
>
> But I'm not an expert on these issues, so I'l defer to Stefan and Lars
> here.
I am curious too.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sun, 03 Jan 2021 15:47:01 GMT)
Full text and
rfc822 format available.
Message #29 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> From: Lars Ingebrigtsen <larsi <at> gnus.org>
> Cc: Leo Liu <sdl.web <at> gmail.com>, Stefan Monnier <monnier <at> iro.umontreal.ca>,
> 45610 <at> debbugs.gnu.org
> Date: Sat, 02 Jan 2021 17:35:08 +0100
>
> I think the easiest fix here is to put an autoload cookie on
> seq-concatenate.
Leo, does this work for your use case? In your opinion, is this
better than my suggestion?
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Sun, 03 Jan 2021 16:20:02 GMT)
Full text and
rfc822 format available.
Message #32 received at 45610 <at> debbugs.gnu.org (full text, mbox):
On 2021-01-03 17:46 +0200, Eli Zaretskii wrote:
> Leo, does this work for your use case? In your opinion, is this
> better than my suggestion?
Yes autoload works too.
I was hesitant to suggest it because the autoload (cookie) would live
too far away from cl-concatenate.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Mon, 04 Jan 2021 05:40:02 GMT)
Full text and
rfc822 format available.
Message #35 received at 45610 <at> debbugs.gnu.org (full text, mbox):
On 2021-01-03 17:46 +0200, Eli Zaretskii wrote:
> In your opinion, is this better than my suggestion?
I didn't comment much on this point last night.
Adding (require 'seq) to cl-concatenate is probably the least favourable
because it also defeats the purpose of the `inline' cl-proclaim.
Adding autoload cookie for seq-concatenate is simple though not the
cleanest, IOW, we have the workings of cl-concatenate in some situations
depend on the autoload cookie. But this is not uncommon practice.
Given the dilemma we are in I wonder if the considerations for `inline'
cl-concatenate in the first place are no longer applicable.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Mon, 04 Jan 2021 15:08:01 GMT)
Full text and
rfc822 format available.
Message #38 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> From: Leo Liu <sdl.web <at> gmail.com>
> Cc: Lars Ingebrigtsen <larsi <at> gnus.org>, 45610 <at> debbugs.gnu.org, monnier <at> iro.umontreal.ca
> Date: Mon, 04 Jan 2021 13:39:03 +0800
>
> On 2021-01-03 17:46 +0200, Eli Zaretskii wrote:
> > In your opinion, is this better than my suggestion?
>
> I didn't comment much on this point last night.
>
> Adding (require 'seq) to cl-concatenate is probably the least favourable
> because it also defeats the purpose of the `inline' cl-proclaim.
>
> Adding autoload cookie for seq-concatenate is simple though not the
> cleanest, IOW, we have the workings of cl-concatenate in some situations
> depend on the autoload cookie. But this is not uncommon practice.
>
> Given the dilemma we are in I wonder if the considerations for `inline'
> cl-concatenate in the first place are no longer applicable.
Thanks.
Stefan, any comments? My personal tendency is to add the autoload
cookie, with a comment saying that cl-concatenate needs that. At
least on the emacs-27 branch. Any problems or issues with that? What
do people think about removing cl-concatenate from the inline
declaration (on master)?
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#45610
; Package
emacs
.
(Mon, 04 Jan 2021 17:33:01 GMT)
Full text and
rfc822 format available.
Message #41 received at 45610 <at> debbugs.gnu.org (full text, mbox):
> Stefan, any comments? My personal tendency is to add the autoload
> cookie, with a comment saying that cl-concatenate needs that. At
> least on the emacs-27 branch. Any problems or issues with that?
Sounds good to me.
> What do people think about removing cl-concatenate from the inline
> declaration (on master)?
Fine by me as well,
Stefan
Reply sent
to
Eli Zaretskii <eliz <at> gnu.org>
:
You have taken responsibility.
(Sat, 09 Jan 2021 12:14:01 GMT)
Full text and
rfc822 format available.
Notification sent
to
Leo Liu <sdl.web <at> gmail.com>
:
bug acknowledged by developer.
(Sat, 09 Jan 2021 12:14:02 GMT)
Full text and
rfc822 format available.
Message #46 received at 45610-done <at> debbugs.gnu.org (full text, mbox):
> From: Stefan Monnier <monnier <at> iro.umontreal.ca>
> Cc: Leo Liu <sdl.web <at> gmail.com>, larsi <at> gnus.org, 45610 <at> debbugs.gnu.org
> Date: Mon, 04 Jan 2021 12:35:13 -0500
>
> > Stefan, any comments? My personal tendency is to add the autoload
> > cookie, with a comment saying that cl-concatenate needs that. At
> > least on the emacs-27 branch. Any problems or issues with that?
>
> Sounds good to me.
>
> > What do people think about removing cl-concatenate from the inline
> > declaration (on master)?
>
> Fine by me as well,
I've now done both, and I'm closing this bug.
Thanks.
bug archived.
Request was from
Debbugs Internal Request <help-debbugs <at> gnu.org>
to
internal_control <at> debbugs.gnu.org
.
(Sat, 06 Feb 2021 12:24:05 GMT)
Full text and
rfc822 format available.
This bug report was last modified 3 years and 333 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.