* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
@ 2013-12-28 5:52 Drew Adams
2014-01-03 4:23 ` Stefan Monnier
` (2 more replies)
0 siblings, 3 replies; 25+ messages in thread
From: Drew Adams @ 2013-12-28 5:52 UTC (permalink / raw)
To: 16274
I believe I reported long ago (in the Emacs 24 cycle, IIRC) that I
occasionally get this error. This is still the case. The value it
complains about not being a function is a list of completions (strings),
which each have text property `face' with values
`completions-common-part' and `(completions-first-difference)' (a list).
I haven't been able to see where in the code this error could occur. I
have noticed it being raised with my setup (icomplete+.el). Dunno
whether it occurs also in emacs -Q.
FWIW, my code does not even reference `icomplete-post-command-hook'
explicitly, and it does not use those particular faces explicitly.
I also have not been able to find the code that issues that error
message. Perhaps it is in some C code - the latest C code I have is for
Emacs 24.3.
A wild guess about this is that the list of completions is the cached
value in variable `completion-all-sorted-completions'. And perhaps in
code like this:
(completion-try-completion name comps nil (length name) md)
Maybe COMPS here (which is the value of
`completion-all-sorted-completions') is somehow expected to be a
function? Does this ring a bell for anyone? Just poking in the dark.
Dunno how to debug this better. The error message does not stop
execution, being on `post-command-hook'. It just flashes ephemerally
and then I can find it in `*Messages*'.
And, again, it seems that this happens just once in a while.
If this info does not help at all, feel free to close the bug. Or leave
it open, for future reference. It has been there for a while now.
In GNU Emacs 24.3.50.1 (i686-pc-mingw32)
of 2013-12-27 on ODIEONE
Bzr revision: 115778 rgm@gnu.org-20131228000456-1797o8z6veuyozs0
Windowing system distributor `Microsoft Corp.', version 6.1.7601
Configured using:
`configure --prefix=/c/Devel/emacs/binary --enable-checking=yes,glyphs
'CFLAGS=-O0 -g3' LDFLAGS=-Lc:/Devel/emacs/lib
CPPFLAGS=-Ic:/Devel/emacs/include'
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2013-12-28 5:52 bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...)) Drew Adams
@ 2014-01-03 4:23 ` Stefan Monnier
2014-01-03 16:20 ` Drew Adams
2015-01-30 14:25 ` bug#16274: ; One method to produce an error in icomplete-post-command-hook Jeremy Moore
2015-08-11 19:02 ` bug#16274: Can still reproduce in Emacs 24.5.2/x86_64-unknown-linux-gnu Michael Hoffman
2 siblings, 1 reply; 25+ messages in thread
From: Stefan Monnier @ 2014-01-03 4:23 UTC (permalink / raw)
To: Drew Adams; +Cc: 16274
> I haven't been able to see where in the code this error could occur.
> I have noticed it being raised with my setup (icomplete+.el). Dunno
> whether it occurs also in emacs -Q.
For now, I'll assume that the problem is in your icomplete+.el, because
in any case, there's not much info to go about tracking down
the problem.
Stefan
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-03 4:23 ` Stefan Monnier
@ 2014-01-03 16:20 ` Drew Adams
2014-01-03 22:14 ` Stefan Monnier
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-01-03 16:20 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> > I haven't been able to see where in the code this error could
> > occur. I have noticed it being raised with my setup
> > (icomplete+.el). Dunno whether it occurs also in emacs -Q.
>
> For now, I'll assume that the problem is in your icomplete+.el,
> because in any case, there's not much info to go about tracking
> down the problem.
Fair enough. But note that I mentioned that:
> FWIW, my code does not even reference `icomplete-post-command-hook'
> explicitly, and it does not use those particular faces explicitly.
Can you identify the code that issues that error message? That
might help.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-03 16:20 ` Drew Adams
@ 2014-01-03 22:14 ` Stefan Monnier
2014-01-03 22:52 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Stefan Monnier @ 2014-01-03 22:14 UTC (permalink / raw)
To: Drew Adams; +Cc: 16274
>> FWIW, my code does not even reference `icomplete-post-command-hook'
>> explicitly,
The message only says that the error occurs while running
icomplete-post-command-hook. So if your code affects
something run by icomplete-post-command-hook, it's still a possible culprit.
>> and it does not use those particular faces explicitly.
Obviously the list of strings comes from completion-all-completions or
completion-all-sorted-completions and looks sane. So the error is that
some code mistakenly treats the list as a function.
> Can you identify the code that issues that error message?
It's the C code that runs `post-command-hook', AFAIK.
Stefan
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-03 22:14 ` Stefan Monnier
@ 2014-01-03 22:52 ` Drew Adams
2014-01-04 4:51 ` Stefan Monnier
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-01-03 22:52 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> Obviously the list of strings comes from completion-all-completions
> or completion-all-sorted-completions and looks sane. So the error is
> that some code mistakenly treats the list as a function.
Yes, I said as much, explicitly.
> > Can you identify the code that issues that error message?
>
> It's the C code that runs `post-command-hook', AFAIK.
I was looking for the function that issued the `invalid-function'
error. It seems to be `eval_sub' (via `Qinvalid_function').
So no special help there.
So far, my best guess is still that in
(completion-try-completion name comps nil (length name) md)
the list COMPS is for some reason being treated as a function (the
second argument can of course be either).
And I'm still wild-guessing that this somehow has to do with
the caching of the list of completions in variable
`completion-all-sorted-completions'.
Maybe `completion--nth-completion' (called by
`completion-try-completion') for some reason finds
(completion-metadata-get metadata 'completion--unquote-requote) to be
non-nil, and so calls its TABLE argument, trying to requote?
Not easy to debug this. I do not see the problem regularly.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-03 22:52 ` Drew Adams
@ 2014-01-04 4:51 ` Stefan Monnier
2014-01-04 7:03 ` Drew Adams
2017-10-22 15:06 ` Charles A. Roelli
0 siblings, 2 replies; 25+ messages in thread
From: Stefan Monnier @ 2014-01-04 4:51 UTC (permalink / raw)
To: Drew Adams; +Cc: 16274
>> > Can you identify the code that issues that error message?
>> It's the C code that runs `post-command-hook', AFAIK.
> I was looking for the function that issued the `invalid-function'
> error. It seems to be `eval_sub' (via `Qinvalid_function').
Right, it's probably eval of funcall.
> So no special help there.
Indeed.
> So far, my best guess is still that in
> (completion-try-completion name comps nil (length name) md)
> the list COMPS is for some reason being treated as a function (the
> second argument can of course be either).
Oh, you mean that the error could come from the fact that `md' goes with
`candidates', so some code might assume that the completion table is
a function based on the `md' data, whereas we passed `comps' which is
a list of strings?
Hmm... that sounds plausible.
> Maybe `completion--nth-completion' (called by
> `completion-try-completion') for some reason finds
> (completion-metadata-get metadata 'completion--unquote-requote) to be
> non-nil, and so calls its TABLE argument, trying to requote?
Apply the patch below. That should replace your error message with
a different one, so if the error message stays the same, the problem
is elsewhere. And if a new message appears we've found a culprit.
Of course, minibuffer.el is preloaded, so you'll want to re-dump your
Emacs, force reloading minibuffer.el(c) from your .emacs, or do some
other dance to make sure you use the new definition of
completion--nth-completion.
Stefan
=== modified file 'lisp/minibuffer.el'
--- lisp/minibuffer.el 2014-01-01 07:43:34 +0000
+++ lisp/minibuffer.el 2014-01-04 04:48:56 +0000
@@ -819,6 +819,7 @@
;; part of the string (e.g. substitute-in-file-name).
(let ((requote
(when (completion-metadata-get metadata 'completion--unquote-requote)
+ (cl-assert (functionp table))
(let ((new (funcall table string point 'completion--unquote)))
(setq string (pop new))
(setq table (pop new))
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-04 4:51 ` Stefan Monnier
@ 2014-01-04 7:03 ` Drew Adams
2014-01-04 15:45 ` Drew Adams
2017-10-22 15:06 ` Charles A. Roelli
1 sibling, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-01-04 7:03 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> Apply the patch below. That should replace your error message with
> a different one, so if the error message stays the same, the problem
> is elsewhere. And if a new message appears we've found a culprit.
> Of course, minibuffer.el is preloaded, so you'll want to re-dump
> your Emacs, force reloading minibuffer.el(c) from your .emacs, or
> do some other dance to make sure you use the new definition of
> completion--nth-completion.
Hey, thanks for hanging in there. I patched minibuffer.el and will
`load-library' the patched version from my .emacs. That should do it,
I assume.
It's not often that I notice the error (in *Messages*, since the message
itself is fleeting), but I'll try to keep an eye out for the new message
and let you know. (I added a noticeable STRING arg to the `cl-assert'
form.)
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-04 7:03 ` Drew Adams
@ 2014-01-04 15:45 ` Drew Adams
2014-02-10 3:53 ` Lars Ingebrigtsen
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-01-04 15:45 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> It's not often that I notice the error (in *Messages*, since the
> message itself is fleeting), but I'll try to keep an eye out for
> the new message and let you know. (I added a noticeable STRING
> arg to the `cl-assert' form.)
Well, it didn't take that long. In the same session (after loading
the patched minibuffer.el. I did not get the `cl-assert' violation.
I got the same, original error:
Error in post-command-hook (icomplete-post-command-hook):
(wrong-type-argument stringp nil)
Well, actually, that's not the same error, but it is (IIRC)
the one I reported originally.
I've added some more debug with `stringp' assertions. Will let
you know what I find out.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-04 15:45 ` Drew Adams
@ 2014-02-10 3:53 ` Lars Ingebrigtsen
2014-02-10 16:34 ` Stefan Monnier
0 siblings, 1 reply; 25+ messages in thread
From: Lars Ingebrigtsen @ 2014-02-10 3:53 UTC (permalink / raw)
To: Drew Adams; +Cc: 16274
Drew Adams <drew.adams@oracle.com> writes:
>> It's not often that I notice the error (in *Messages*, since the
>> message itself is fleeting), but I'll try to keep an eye out for
>> the new message and let you know. (I added a noticeable STRING
>> arg to the `cl-assert' form.)
>
> Well, it didn't take that long. In the same session (after loading
> the patched minibuffer.el. I did not get the `cl-assert' violation.
> I got the same, original error:
>
> Error in post-command-hook (icomplete-post-command-hook):
> (wrong-type-argument stringp nil)
>
> Well, actually, that's not the same error, but it is (IIRC)
> the one I reported originally.
>
> I've added some more debug with `stringp' assertions. Will let
> you know what I find out.
You can also use `debug-on-message' to find what make the message appear.
Anyway, is this an Emacs bug?
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog http://lars.ingebrigtsen.no/
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-02-10 3:53 ` Lars Ingebrigtsen
@ 2014-02-10 16:34 ` Stefan Monnier
2014-02-10 20:55 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Stefan Monnier @ 2014-02-10 16:34 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 16274
>> Error in post-command-hook (icomplete-post-command-hook):
>> (wrong-type-argument stringp nil)
> You can also use `debug-on-message' to find what make the message appear.
In this case, you won't learn anything more than what the error message
says, sadly.
> Anyway, is this an Emacs bug?
That was the working hypothesis, yes. Drew, any news on this bug?
Stefan
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-02-10 16:34 ` Stefan Monnier
@ 2014-02-10 20:55 ` Drew Adams
2014-02-20 5:09 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-02-10 20:55 UTC (permalink / raw)
To: Stefan Monnier, Lars Ingebrigtsen; +Cc: 16274
> > Anyway, is this an Emacs bug?
>
> That was the working hypothesis, yes. Drew, any news on this bug?
Not yet, unfortunately. But I've been checking *Messages*.
And I've kept my copy of minibuffer.el, with the inserted cl-assert's,
up-to-date wrt minibuffer.el changes. I'll keep watching *Messages*.
Unfortunately, although I've pretty much sprinkled cl-assert's
everywhere, I still see the error with no cl-assert message. Here,
for example, an extract of *Messages* from today:
...
Refining difference region 22 ...
Saving old diff region #22 of buffer A. To recover, type `ra' [2 times]
Only white-space differences in region 22
Quit this Ediff session? (y or n) y
Saving file d:/path/to/stefan-minibuffer.el...
Wrote d:/path/to/stefan-minibuffer.el
byte-code: Beginning of buffer
Quit
Undo! [2 times]
Error in post-command-hook (icomplete-post-command-hook): (wrong-type-argument stringp yes)
Sending...
Sending via mail...
Sending...done
Back to top level.
Mark set
Auto-saving...done
Mark set [2 times]
...
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-02-10 20:55 ` Drew Adams
@ 2014-02-20 5:09 ` Drew Adams
2014-07-19 21:51 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-02-20 5:09 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> > Drew, any news on this bug?
An update, but I'm not sure whether it is the exact same problem I
have seen before. After changing some of my code recently, and doing
something different, I can now get such an assertion violation.
If I turn off icomplete-mode then the problem goes away.
The assertion violation occurs in `completion--nth-completion', after
(when (completion-metadata-get metadata 'completion--unquote-requote).
I inserted this debug code just after that arg to `when':
(message "N: %S, STRING: %S, TABLE: %S, PRED: %S, POINT: %S, METADATA: %S"
n string table pred point metadata)
(cl-assert (functionp table) nil
"=================== INVALID FUNCTION ==================")
This is what I see in *Messages* (I've added some newlines for the mail):
N: 2, STRING: "ls", TABLE: read-file-name-internal, PRED: file-exists-p,
POINT: 2, METADATA: (metadata (category . file) (completion--unquote-requote . t))
N: 1, STRING: "ls", TABLE: (#("ls-lisp+.el" 0 1 (face completions-common-part)
1 2 (face completions-common-part) 2 3 (face (completions-first-difference)))
#("ls-lisp-20.el" 0 1 (face completions-common-part) 1 2
(face completions-common-part) 2 3 (face (completions-first-difference)))),
PRED: nil, POINT: 2, METADATA: (metadata (category . file)
(completion--unquote-requote . t))
Error in post-command-hook (icomplete-post-command-hook):
(error "=================== INVALID FUNCTION ==================")
There are two calls to `completion--nth-completion' here, of which the
first (which I guess corresponds to `completion-all-completions') goes OK.
For the second (which I guess corresponds to `completion-try-completion'),
arg TABLE is a list of (propertized) strings, not a function.
I do not understand this code very well. Hope this sheds some light for you.
I doubt if describing what I was doing at the time will help, but here
it is, just in case:
With my code (Icicles), I use a different kind of completion for `!'
in Dired (e.g.). It is file-name completion (against program files in
the path etc.), but the minibuffer history in this case is
`shell-command-history'. I hit `!' on a file in Dired, then hit `M-p'
to access the first item of the history, which was `ls' (which matches
a couple of file names). It was when I hit `M-p' that I got the assertion
violation.
The same thing happened using my icomplete+.el and using vanilla
icomplete.el.
With a little more debug I determined that it is the second call to
`completion-try-completion' that causes the problem: the one that
is used when BASE-SIZE is not > 0. In this case, BASE-SIZE = 0, so
this code is executed:
;; If the `comps' are 0-based, the result should be the same with `comps'.
(completion-try-completion name comps nil (length name) md)))
The problem is apparently that COMPS is a list of strings (file names),
not a function.
HTH. Let me know if you have further debugging suggestions or need
more info.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-02-20 5:09 ` Drew Adams
@ 2014-07-19 21:51 ` Drew Adams
2015-12-26 3:40 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2014-07-19 21:51 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
FWIW, just got the error again, in this version:
In GNU Emacs 24.4.50.1 (i686-pc-mingw32)
of 2014-06-28 on ODIEONE
Bzr revision: 117431 rgm@gnu.org-20140628015517-eku6hj8mpgcvfnso
Windowing system distributor `Microsoft Corp.', version 6.1.7601
Configured using:
`configure --prefix=/c/Devel/emacs/snapshot/trunk
--enable-checking=yes,glyphs 'CFLAGS=-O0 -g3'
LDFLAGS=-Lc:/Devel/emacs/lib 'CPPFLAGS=-DGC_MCHECK=1
-Ic:/Devel/emacs/include''
Error in post-command-hook (icomplete-post-command-hook): (cl-assertion-failed (functionp table))
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: ; One method to produce an error in icomplete-post-command-hook
2013-12-28 5:52 bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...)) Drew Adams
2014-01-03 4:23 ` Stefan Monnier
@ 2015-01-30 14:25 ` Jeremy Moore
2015-08-11 19:02 ` bug#16274: Can still reproduce in Emacs 24.5.2/x86_64-unknown-linux-gnu Michael Hoffman
2 siblings, 0 replies; 25+ messages in thread
From: Jeremy Moore @ 2015-01-30 14:25 UTC (permalink / raw)
To: 16274
[-- Attachment #1: Type: text/plain, Size: 3494 bytes --]
Hi folks,
I get a similar error by following this sequence in 24.4.1:
1. emacs -Q
2. M-x icomplete-mode
3. M-x set-variable icomplete-show-matches-on-no-input t
4. C-x C-f C-a C-k
Version and settings are below.
Regards,
Jeremy
In GNU Emacs 24.4.1 (i686-pc-mingw32)
of 2014-10-24 on LEG570
Windowing system distributor `Microsoft Corp.', version 6.1.7601
Configured using:
`configure --prefix=/c/usr'
Important settings:
value of $LANG: ENG
locale-coding-system: cp1252
Major mode: Lisp Interaction
Minor modes in effect:
icomplete-mode: t
tooltip-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
blink-cursor-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
line-number-mode: t
transient-mark-mode: t
Recent input:
M-x i c o m p l e t e SPC m o d e <return> M-x s e
t SPC v a r <return> i c o m p l e t e SPC s h o w
<return> t <return> C-x C-f C-a C-k C-g M-x r e p o
t <backspace> r t <return>
Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.
Icomplete mode enabled
Error in post-command-hook (icomplete-post-command-hook): (invalid-function
(#("./" 0 1 (face (completions-first-difference))) #("../" 0 1 (face
(completions-first-difference))) #("addpm.exe" 0 1 (face
(completions-first-difference))) #("ctags.exe" 0 1 (face
(completions-first-difference))) #("emacs.exe" 0 1 (face
(completions-first-difference))) #("etags.exe" 0 1 (face
(completions-first-difference))) #("libXpm.dll" 0 1 (face
(completions-first-difference))) #("ebrowse.exe" 0 1 (face
(completions-first-difference))) #("runemacs.exe" 0 1 (face
(completions-first-difference))) #("emacs-24.4.exe" 0 1 (face
(completions-first-difference))) #("grep-changelog" 0 1 (face
(completions-first-difference))) #("runvanilla.lnk" 0 1 (face
(completions-first-difference))) #("emacsclient.exe" 0 1 (face
(completions-first-difference))) #("emacsclientw.exe" 0 1 (face
(completions-first-difference)))))
Quit
Load-path shadows:
None found.
Features:
(shadow sort gnus-util mail-extr emacsbug message format-spec rfc822 mml
mml-sec 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-edit easymenu wid-edit cl-loaddefs cl-lib
help-fns mule-util cus-start cus-load icomplete time-date tooltip
electric uniquify ediff-hook vc-hooks lisp-float-type mwheel dos-w32
ls-lisp w32-common-fns disp-table w32-win w32-vars tool-bar dnd fontset
image regexp-opt fringe tabulated-list newcomment lisp-mode prog-mode
register page menu-bar rfn-eshadow timer select scroll-bar mouse
jit-lock font-lock syntax facemenu font-core frame cham georgian
utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao korean
japanese hebrew greek romanian slovak czech european ethiopic indian
cyrillic chinese case-table epa-hook jka-cmpr-hook help simple abbrev
minibuffer 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 make-network-process
w32notify w32 multi-tty emacs)
Memory information:
((conses 8 94199 5225)
(symbols 32 19208 0)
(miscs 32 36 138)
(strings 16 14989 3911)
(string-bytes 1 391743)
(vectors 8 10790)
(vector-slots 4 394081 3824)
(floats 8 65 84)
(intervals 28 212 41)
(buffers 508 11))
[-- Attachment #2: Type: text/html, Size: 4096 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: Can still reproduce in Emacs 24.5.2/x86_64-unknown-linux-gnu
2013-12-28 5:52 bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...)) Drew Adams
2014-01-03 4:23 ` Stefan Monnier
2015-01-30 14:25 ` bug#16274: ; One method to produce an error in icomplete-post-command-hook Jeremy Moore
@ 2015-08-11 19:02 ` Michael Hoffman
2 siblings, 0 replies; 25+ messages in thread
From: Michael Hoffman @ 2015-08-11 19:02 UTC (permalink / raw)
To: 16274
I can reproduce this with Emacs 24.5.2 on Linux using the instructions found in <http://lists.gnu.org/archive/html/bug-gnu-emacs/2015-01/msg00995.html>. Specifically:
1. emacs -Q
2. M-x icomplete-mode
3. M-x set-variable icomplete-show-matches-on-no-input t
4. C-x C-f C-a C-k
I have now set `icomplete-show-matches-on-no-input` to `nil` and have not triggered the bug again.
In GNU Emacs 24.5.2 (x86_64-unknown-linux-gnu, GTK+ Version 3.8.8)
of 2015-07-29 on mhoffman2.uhnres.utoronto.ca
Windowing system distributor `The X.Org Foundation', version 11.0.11500000
System Description: CentOS Linux release 7.1.1503 (Core)
Configured using:
`configure --prefix=/users/mhoffman
--exec-prefix=/users/mhoffman/arch/Linux-x86_64 'CFLAGS=-O2
-march=native -pipe -fomit-frame-pointer' LDFLAGS=-Wl,-O1'
Important settings:
value of $LANG: en_US.UTF-8
value of $XMODIFIERS: @im=ibus
locale-coding-system: utf-8-unix
Major mode: Lisp Interaction
Minor modes in effect:
icomplete-mode: t
tooltip-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
blink-cursor-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
line-number-mode: t
transient-mark-mode: t
Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.
Icomplete mode enabled
Error in post-command-hook (icomplete-post-command-hook): (invalid-function (#("./" 0 1 (face (completions-first-difference))) #("../" 0 1 (face (completions-first-difference)))))
Quit
Load-path shadows:
None found.
Features:
(shadow sort gnus-util mail-extr emacsbug message format-spec rfc822 mml
mml-sec 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-edit easymenu wid-edit cl-loaddefs cl-lib
help-fns mule-util cus-start cus-load icomplete time-date tooltip
electric uniquify ediff-hook vc-hooks lisp-float-type mwheel x-win x-dnd
tool-bar dnd fontset image regexp-opt fringe tabulated-list newcomment
lisp-mode prog-mode register page menu-bar rfn-eshadow timer select
scroll-bar mouse jit-lock font-lock syntax facemenu font-core frame cham
georgian utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao
korean japanese hebrew greek romanian slovak czech european ethiopic
indian cyrillic chinese case-table epa-hook jka-cmpr-hook help simple
abbrev minibuffer 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 make-network-process
dbusbind gfilenotify dynamic-setting system-font-setting
font-render-setting move-toolbar gtk x-toolkit x multi-tty emacs)
Memory information:
((conses 16 90594 3758)
(symbols 48 19313 0)
(miscs 40 36 124)
(strings 32 13452 4435)
(string-bytes 1 370253)
(vectors 16 10101)
(vector-slots 8 392565 9391)
(floats 8 71 91)
(intervals 56 176 1)
(buffers 960 11)
(heap 1024 20881 916))
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-07-19 21:51 ` Drew Adams
@ 2015-12-26 3:40 ` Drew Adams
2017-02-03 15:49 ` Drew Adams
0 siblings, 1 reply; 25+ messages in thread
From: Drew Adams @ 2015-12-26 3:40 UTC (permalink / raw)
To: 16274
> FWIW, just got the error again, in this version:
>
> In GNU Emacs 24.4.50.1 (i686-pc-mingw32)
> of 2014-06-28 on ODIEONE
> ...
>
> Error in post-command-hook (icomplete-post-command-hook):
> (cl-assertion-failed (functionp table))
FYI, I still get this error fairly often, in Emacs 25 builds.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2015-12-26 3:40 ` Drew Adams
@ 2017-02-03 15:49 ` Drew Adams
0 siblings, 0 replies; 25+ messages in thread
From: Drew Adams @ 2017-02-03 15:49 UTC (permalink / raw)
To: 16274
Now that this bug reported 4 years ago has been confirmed by someone else, perhaps it can be fixed? Thx.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2014-01-04 4:51 ` Stefan Monnier
2014-01-04 7:03 ` Drew Adams
@ 2017-10-22 15:06 ` Charles A. Roelli
2017-11-01 20:02 ` Charles A. Roelli
1 sibling, 1 reply; 25+ messages in thread
From: Charles A. Roelli @ 2017-10-22 15:06 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274
> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Date: Fri, 03 Jan 2014 23:51:48 -0500
>
> > So far, my best guess is still that in
> > (completion-try-completion name comps nil (length name) md)
> > the list COMPS is for some reason being treated as a function (the
> > second argument can of course be either).
>
> Oh, you mean that the error could come from the fact that `md' goes with
> `candidates', so some code might assume that the completion table is
> a function based on the `md' data, whereas we passed `comps' which is
> a list of strings?
>
> Hmm... that sounds plausible.
This seems to be the mistake. If you pass nil instead of `md' (as in
the patch below), then there's no more problem.
diff --git a/lisp/icomplete.el b/lisp/icomplete.el
index 038f58f..38be657 100644
--- a/lisp/icomplete.el
+++ b/lisp/icomplete.el
@@ -395,7 +395,7 @@ icomplete-completions
;; If the `comps' are 0-based, the result should be
;; the same with `comps'.
(completion-try-completion
- name comps nil (length name) md)))
+ name comps nil (length name) nil)))
(most (if (consp most-try) (car most-try)
(if most-try (car comps) "")))
;; Compare name and most, so we can determine if name is
Alternatively, this part of `completion--nth-completion' could be
updated to respond to `completio--unquote-requote' in the completion
metadata when `table' is not a function:
(when (completion-metadata-get metadata 'completion--unquote-requote)
(cl-assert (functionp table))
(let ((new (funcall table string point 'completion--unquote)))
(No idea if that would make sense.)
I was using this recipe for testing:
> Date: Fri, 30 Jan 2015 14:25:04 +0000
> From: Jeremy Moore <jmoore@ieee.org>
>
> Hi folks,
>
> I get a similar error by following this sequence in 24.4.1:
> 1. emacs -Q
> 2. M-x icomplete-mode
> 3. M-x set-variable icomplete-show-matches-on-no-input t
> 4. C-x C-f C-a C-k
>
> Version and settings are below.
>
> Regards,
> Jeremy
>
> In GNU Emacs 24.4.1 (i686-pc-mingw32)
> of 2014-10-24 on LEG570
> Windowing system distributor `Microsoft Corp.', version 6.1.7601
> Configured using:
> `configure --prefix=/c/usr'
^ permalink raw reply related [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-10-22 15:06 ` Charles A. Roelli
@ 2017-11-01 20:02 ` Charles A. Roelli
2017-11-04 8:56 ` Eli Zaretskii
0 siblings, 1 reply; 25+ messages in thread
From: Charles A. Roelli @ 2017-11-01 20:02 UTC (permalink / raw)
To: Charles A. Roelli; +Cc: 16274, monnier
Ping! I hope to fix this for emacs-26 if it's possible. It also
solves Bug#28898.
> Date: Sun, 22 Oct 2017 17:06:35 +0200
> From: charles@aurox.ch (Charles A. Roelli)
>
> > From: Stefan Monnier <monnier@iro.umontreal.ca>
> > Date: Fri, 03 Jan 2014 23:51:48 -0500
> >
> > > So far, my best guess is still that in
> > > (completion-try-completion name comps nil (length name) md)
> > > the list COMPS is for some reason being treated as a function (the
> > > second argument can of course be either).
> >
> > Oh, you mean that the error could come from the fact that `md' goes with
> > `candidates', so some code might assume that the completion table is
> > a function based on the `md' data, whereas we passed `comps' which is
> > a list of strings?
> >
> > Hmm... that sounds plausible.
>
> This seems to be the mistake. If you pass nil instead of `md' (as in
> the patch below), then there's no more problem.
>
> diff --git a/lisp/icomplete.el b/lisp/icomplete.el
> index 038f58f..38be657 100644
> --- a/lisp/icomplete.el
> +++ b/lisp/icomplete.el
> @@ -395,7 +395,7 @@ icomplete-completions
> ;; If the `comps' are 0-based, the result should be
> ;; the same with `comps'.
> (completion-try-completion
> - name comps nil (length name) md)))
> + name comps nil (length name) nil)))
> (most (if (consp most-try) (car most-try)
> (if most-try (car comps) "")))
> ;; Compare name and most, so we can determine if name is
>
> Alternatively, this part of `completion--nth-completion' could be
> updated to respond to `completio--unquote-requote' in the completion
> metadata when `table' is not a function:
>
> (when (completion-metadata-get metadata 'completion--unquote-requote)
> (cl-assert (functionp table))
> (let ((new (funcall table string point 'completion--unquote)))
>
> (No idea if that would make sense.)
>
> I was using this recipe for testing:
>
> > Date: Fri, 30 Jan 2015 14:25:04 +0000
> > From: Jeremy Moore <jmoore@ieee.org>
> >
> > Hi folks,
> >
> > I get a similar error by following this sequence in 24.4.1:
> > 1. emacs -Q
> > 2. M-x icomplete-mode
> > 3. M-x set-variable icomplete-show-matches-on-no-input t
> > 4. C-x C-f C-a C-k
> >
> > Version and settings are below.
> >
> > Regards,
> > Jeremy
> >
> > In GNU Emacs 24.4.1 (i686-pc-mingw32)
> > of 2014-10-24 on LEG570
> > Windowing system distributor `Microsoft Corp.', version 6.1.7601
> > Configured using:
> > `configure --prefix=/c/usr'
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-01 20:02 ` Charles A. Roelli
@ 2017-11-04 8:56 ` Eli Zaretskii
2017-11-07 4:06 ` Stefan Monnier
0 siblings, 1 reply; 25+ messages in thread
From: Eli Zaretskii @ 2017-11-04 8:56 UTC (permalink / raw)
To: Charles A. Roelli; +Cc: 16274, monnier
> Date: Wed, 01 Nov 2017 21:02:00 +0100
> From: charles@aurox.ch (Charles A. Roelli)
> Cc: 16274@debbugs.gnu.org, monnier@iro.umontreal.ca
>
> Ping! I hope to fix this for emacs-26 if it's possible. It also
> solves Bug#28898.
Stefan, any objections for pushing this to the emacs-26 branch?
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-04 8:56 ` Eli Zaretskii
@ 2017-11-07 4:06 ` Stefan Monnier
2017-11-11 10:09 ` Eli Zaretskii
0 siblings, 1 reply; 25+ messages in thread
From: Stefan Monnier @ 2017-11-07 4:06 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 16274, Charles A. Roelli
>> Ping! I hope to fix this for emacs-26 if it's possible. It also
>> solves Bug#28898.
> Stefan, any objections for pushing this to the emacs-26 branch?
Yes, using nil instead of `md` has other undesirable side-effects.
E.g. it loses the `category` metadata so it will cause the wrong
completion-styles to be used e.g. in C-x b.
Does the patch below work around the problem?
BTW, thanks Charles for the recipe,
Stefan
diff --git a/lisp/minibuffer.el b/lisp/minibuffer.el
index f13f1fa798..54a6afeca9 100644
--- a/lisp/minibuffer.el
+++ b/lisp/minibuffer.el
@@ -896,8 +896,15 @@ completion--nth-completion
;; than from completion-extra-properties) because it may apply only to some
;; part of the string (e.g. substitute-in-file-name).
(let ((requote
- (when (completion-metadata-get metadata 'completion--unquote-requote)
- (cl-assert (functionp table))
+ (when (and
+ (completion-metadata-get metadata 'completion--unquote-requote)
+ ;; Sometimes a table's metadata is used on another
+ ;; table (typically that other table is just a list taken
+ ;; from the output of `all-completions' or something equivalent,
+ ;; for progressive refinement).
+ ;; FIXME: Rather than do nothing, we should somehow call
+ ;; the original table, in that case!
+ (functionp table))
(let ((new (funcall table string point 'completion--unquote)))
(setq string (pop new))
(setq table (pop new))
^ permalink raw reply related [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-07 4:06 ` Stefan Monnier
@ 2017-11-11 10:09 ` Eli Zaretskii
2017-11-11 10:31 ` Charles A. Roelli
0 siblings, 1 reply; 25+ messages in thread
From: Eli Zaretskii @ 2017-11-11 10:09 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 16274, charles
> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Cc: charles@aurox.ch (Charles A. Roelli), 16274@debbugs.gnu.org
> Date: Mon, 06 Nov 2017 23:06:26 -0500
>
> >> Ping! I hope to fix this for emacs-26 if it's possible. It also
> >> solves Bug#28898.
> > Stefan, any objections for pushing this to the emacs-26 branch?
>
> Yes, using nil instead of `md` has other undesirable side-effects.
> E.g. it loses the `category` metadata so it will cause the wrong
> completion-styles to be used e.g. in C-x b.
>
> Does the patch below work around the problem?
Ping! Charles, any comments?
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-11 10:09 ` Eli Zaretskii
@ 2017-11-11 10:31 ` Charles A. Roelli
2017-11-11 10:41 ` Eli Zaretskii
0 siblings, 1 reply; 25+ messages in thread
From: Charles A. Roelli @ 2017-11-11 10:31 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 16274, monnier
> Date: Sat, 11 Nov 2017 12:09:00 +0200
> From: Eli Zaretskii <eliz@gnu.org>
>
> > From: Stefan Monnier <monnier@iro.umontreal.ca>
> > Cc: charles@aurox.ch (Charles A. Roelli), 16274@debbugs.gnu.org
> > Date: Mon, 06 Nov 2017 23:06:26 -0500
> >
> > >> Ping! I hope to fix this for emacs-26 if it's possible. It also
> > >> solves Bug#28898.
> > > Stefan, any objections for pushing this to the emacs-26 branch?
> >
> > Yes, using nil instead of `md` has other undesirable side-effects.
> > E.g. it loses the `category` metadata so it will cause the wrong
> > completion-styles to be used e.g. in C-x b.
> >
> > Does the patch below work around the problem?
>
> Ping! Charles, any comments?
All good. Thanks to both of you for looking into this.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-11 10:31 ` Charles A. Roelli
@ 2017-11-11 10:41 ` Eli Zaretskii
2017-11-11 15:25 ` Stefan Monnier
0 siblings, 1 reply; 25+ messages in thread
From: Eli Zaretskii @ 2017-11-11 10:41 UTC (permalink / raw)
To: Charles A. Roelli; +Cc: 16274, monnier
> Date: Sat, 11 Nov 2017 11:31:45 +0100
> From: charles@aurox.ch (Charles A. Roelli)
> CC: monnier@iro.umontreal.ca, 16274@debbugs.gnu.org
>
> > Date: Sat, 11 Nov 2017 12:09:00 +0200
> > From: Eli Zaretskii <eliz@gnu.org>
> >
> > > From: Stefan Monnier <monnier@iro.umontreal.ca>
> > > Cc: charles@aurox.ch (Charles A. Roelli), 16274@debbugs.gnu.org
> > > Date: Mon, 06 Nov 2017 23:06:26 -0500
> > >
> > > >> Ping! I hope to fix this for emacs-26 if it's possible. It also
> > > >> solves Bug#28898.
> > > > Stefan, any objections for pushing this to the emacs-26 branch?
> > >
> > > Yes, using nil instead of `md` has other undesirable side-effects.
> > > E.g. it loses the `category` metadata so it will cause the wrong
> > > completion-styles to be used e.g. in C-x b.
> > >
> > > Does the patch below work around the problem?
> >
> > Ping! Charles, any comments?
>
> All good. Thanks to both of you for looking into this.
Thanks. Stefan, please install your changes and close the bug.
^ permalink raw reply [flat|nested] 25+ messages in thread
* bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...))
2017-11-11 10:41 ` Eli Zaretskii
@ 2017-11-11 15:25 ` Stefan Monnier
0 siblings, 0 replies; 25+ messages in thread
From: Stefan Monnier @ 2017-11-11 15:25 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Charles A. Roelli, 16274-done
>> All good. Thanks to both of you for looking into this.
Thanks, installed,
Stefan
^ permalink raw reply [flat|nested] 25+ messages in thread
end of thread, other threads:[~2017-11-11 15:25 UTC | newest]
Thread overview: 25+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-12-28 5:52 bug#16274: 24.3.50; Error in post-command-hook (icomplete-post-command-hook): (invalid-function ("..." ...)) Drew Adams
2014-01-03 4:23 ` Stefan Monnier
2014-01-03 16:20 ` Drew Adams
2014-01-03 22:14 ` Stefan Monnier
2014-01-03 22:52 ` Drew Adams
2014-01-04 4:51 ` Stefan Monnier
2014-01-04 7:03 ` Drew Adams
2014-01-04 15:45 ` Drew Adams
2014-02-10 3:53 ` Lars Ingebrigtsen
2014-02-10 16:34 ` Stefan Monnier
2014-02-10 20:55 ` Drew Adams
2014-02-20 5:09 ` Drew Adams
2014-07-19 21:51 ` Drew Adams
2015-12-26 3:40 ` Drew Adams
2017-02-03 15:49 ` Drew Adams
2017-10-22 15:06 ` Charles A. Roelli
2017-11-01 20:02 ` Charles A. Roelli
2017-11-04 8:56 ` Eli Zaretskii
2017-11-07 4:06 ` Stefan Monnier
2017-11-11 10:09 ` Eli Zaretskii
2017-11-11 10:31 ` Charles A. Roelli
2017-11-11 10:41 ` Eli Zaretskii
2017-11-11 15:25 ` Stefan Monnier
2015-01-30 14:25 ` bug#16274: ; One method to produce an error in icomplete-post-command-hook Jeremy Moore
2015-08-11 19:02 ` bug#16274: Can still reproduce in Emacs 24.5.2/x86_64-unknown-linux-gnu Michael Hoffman
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).