Цікава проблема. Схоже, редактор запускається post-command-hook
кожного разу, коли він вводить новий командний цикл, тобто a recursive-edit
. Але ми можемо почати з того minibuffer-setup-hook
, що виконує функцію після входу в мінібуфер. Хоча це дозволяє вставляти вхід, занадто рано виходити з мінібуфера, оскільки улов ще не налаштовано.
(defmacro with-minibuffer-input (form &rest inputs)
(declare (indent 1))
`(minibuffer-with-setup-hook
(lambda ()
(minibuffer-input-provider ',inputs))
,form))
Ось це нам потрібно було загорнути «аргументи» у власний «командний цикл», який виконується кожного разу, коли ми вводимо a recursive-edit
, і в цей момент він вискакує один аргумент і кидає один рівень вгору через exit-minibuffer
.
;; -*- lexical-binding: t -*-
(defun minibuffer-input-provider (inputs)
(let ((hook (make-symbol "hook")))
(fset hook (lambda ()
(remove-hook 'post-command-hook hook)
(when inputs
(when (= 0 (minibuffer-depth))
(error "Too many inputs"))
(when (cdr inputs)
(add-hook 'post-command-hook hook))
(insert (pop inputs))
(exit-minibuffer))))
(add-hook 'post-command-hook hook)))
(with-minibuffer-input (call-interactively 'find-file)
"/")
(with-minibuffer-input (call-interactively 'occur)
"\\(foo\\)\\(bar\\)" "\\1");;C-u C-x C-e
;;foobar
(with-minibuffer-input (call-interactively 'replace-string)
"foo" "bar")
;; foo
interactive
пункті. Коли ви телефонуєте з elisp, ви повинні мати можливість передавати інформацію як аргумент функції. Звичайно, це вам не допомагає, якщо функція, яку ви намагаєтеся викликати, не відповідає цій конструкції.