]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/minibuffer.el: Install a workaround for bug#16274
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 11 Nov 2017 15:25:20 +0000 (10:25 -0500)
committerStefan Monnier <monnier@iro.umontreal.ca>
Sat, 11 Nov 2017 15:25:20 +0000 (10:25 -0500)
* lisp/minibuffer.el (completion--nth-completion): Avoid signaling an
error when `md` is applied to another table.

lisp/minibuffer.el

index 26861de87b0b12b534afdb8a157f2cc30c053e7f..a4a8f5cb282d84b8feb10b0402ec9f0dfa7e42fe 100644 (file)
@@ -896,8 +896,15 @@ This overrides the defaults specified in `completion-category-defaults'."
   ;; 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).  See bug#28898 and bug#16274.
+                ;; 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))