fix(emacs/lean-info): proofstate display problem
This commit is contained in:
parent
fe710ac6d0
commit
99f85c8dbc
2 changed files with 49 additions and 31 deletions
|
@ -200,18 +200,17 @@
|
||||||
|
|
||||||
(defun lean-info-id-symbol-body-str (info)
|
(defun lean-info-id-symbol-body-str (info)
|
||||||
(case (lean-info-kind info)
|
(case (lean-info-kind info)
|
||||||
('PROOFSTATE (string-join (lean-info-proofstate-body info) "\n"))
|
|
||||||
('IDENTIFIER (string-join (lean-info-symbol-body info) "\n"))
|
('IDENTIFIER (string-join (lean-info-symbol-body info) "\n"))
|
||||||
('SYMBOL (string-join (lean-info-identifier-body info) "\n"))))
|
('SYMBOL (string-join (lean-info-identifier-body info) "\n"))))
|
||||||
|
|
||||||
|
|
||||||
;; Proofstate Information
|
;; Proofstate Information
|
||||||
;; ----------------
|
;; --------------------
|
||||||
(defun lean-info-proofstate-kind (proofstate)
|
(defun lean-info-proofstate-type (proofstate)
|
||||||
(cl-first proofstate))
|
(cl-first proofstate))
|
||||||
(defun lean-info-proofstate-p (proofstate)
|
(defun lean-info-proofstate-p (proofstate)
|
||||||
(pcase proofstate
|
(pcase proofstate
|
||||||
(`PROOFSTATE t)
|
(`PROOF_STATE t)
|
||||||
((pred stringp) (string-prefix-p "-- PROOF_STATE" proofstate))
|
((pred stringp) (string-prefix-p "-- PROOF_STATE" proofstate))
|
||||||
((pred listp) (and (lean-info-proofstate-p (cl-first proofstate))))))
|
((pred listp) (and (lean-info-proofstate-p (cl-first proofstate))))))
|
||||||
(defun lean-info-proofstate-pos (proofstate)
|
(defun lean-info-proofstate-pos (proofstate)
|
||||||
|
@ -223,12 +222,18 @@
|
||||||
(defun lean-info-proofstate-parse (seq)
|
(defun lean-info-proofstate-parse (seq)
|
||||||
(when (lean-info-proofstate-p seq)
|
(when (lean-info-proofstate-p seq)
|
||||||
(let ((header (lean-info-proofstate-parse-header (car seq)))
|
(let ((header (lean-info-proofstate-parse-header (car seq)))
|
||||||
(body (cdr seq)))
|
(body (-split-on "--" (cdr seq))))
|
||||||
`(PROOFSTATE ,header ,body))))
|
`(PROOF_STATE ,header ,body)
|
||||||
(defun lean-info-proofstate-body (proofstate)
|
)))
|
||||||
|
(defun lean-info-proofstate-states (proofstate)
|
||||||
(cl-third proofstate))
|
(cl-third proofstate))
|
||||||
(defun lean-info-proofstate-body-str (proofstate)
|
(defun lean-info-proofstate-state-str (string-seq)
|
||||||
(string-join (lean-info-proofstate-body proofstate) "\n"))
|
(string-join string-seq "\n"))
|
||||||
|
(defun lean-info-proofstate-states-str (proofstate)
|
||||||
|
(string-join
|
||||||
|
(-map 'lean-info-proofstate-state-str
|
||||||
|
(lean-info-proofstate-states proofstate))
|
||||||
|
"\n\n"))
|
||||||
|
|
||||||
;; Basic
|
;; Basic
|
||||||
;; -----
|
;; -----
|
||||||
|
@ -249,7 +254,7 @@
|
||||||
(IDENTIFIER (lean-info-identifier-pos info))
|
(IDENTIFIER (lean-info-identifier-pos info))
|
||||||
(SYMBOL (lean-info-symbol-pos info))
|
(SYMBOL (lean-info-symbol-pos info))
|
||||||
(EXTRA (lean-info-extra-pos info))
|
(EXTRA (lean-info-extra-pos info))
|
||||||
(PROOFSTATE (lean-info-proofstate-pos info))))
|
(PROOF_STATE (lean-info-proofstate-pos info))))
|
||||||
(defun lean-info-line-number (info)
|
(defun lean-info-line-number (info)
|
||||||
(cl-first (lean-info-pos info)))
|
(cl-first (lean-info-pos info)))
|
||||||
(defun lean-info-column (info)
|
(defun lean-info-column (info)
|
||||||
|
@ -406,8 +411,8 @@ Take out \"BEGININFO\" and \"ENDINFO\" and Use \"ACK\" as a delim."
|
||||||
:nay (lean-info-nay-p string)
|
:nay (lean-info-nay-p string)
|
||||||
:stale (lean-info-stale-p string))))
|
:stale (lean-info-stale-p string))))
|
||||||
|
|
||||||
(defun lean-info-record-to-string (info-record)
|
(defun lean-info-record-to-strings (info-record)
|
||||||
"Given typeinfo, overload, and sym-name, compose string information."
|
"Given typeinfo, overload, and sym-name, compose information as a list of strings."
|
||||||
(let* ((type (cl-first (lean-info-record-type info-record)))
|
(let* ((type (cl-first (lean-info-record-type info-record)))
|
||||||
(overload (cl-first (lean-info-record-overload info-record)))
|
(overload (cl-first (lean-info-record-overload info-record)))
|
||||||
(synth (cl-first (lean-info-record-synth info-record)))
|
(synth (cl-first (lean-info-record-synth info-record)))
|
||||||
|
@ -417,7 +422,7 @@ Take out \"BEGININFO\" and \"ENDINFO\" and Use \"ACK\" as a delim."
|
||||||
(id (cl-first (lean-info-record-identifier info-record)))
|
(id (cl-first (lean-info-record-identifier info-record)))
|
||||||
(sym (cl-first (lean-info-record-symbol info-record)))
|
(sym (cl-first (lean-info-record-symbol info-record)))
|
||||||
(stale (lean-info-record-stale info-record))
|
(stale (lean-info-record-stale info-record))
|
||||||
name-str type-str coercion-str extra-str proofstate-str overload-str str)
|
name-str type-str coercion-str extra-str proofstate-str overload-str stale-str str)
|
||||||
(setq name-str
|
(setq name-str
|
||||||
(cond
|
(cond
|
||||||
(synth (lean-info-synth-body-str synth))
|
(synth (lean-info-synth-body-str synth))
|
||||||
|
@ -464,12 +469,14 @@ Take out \"BEGININFO\" and \"ENDINFO\" and Use \"ACK\" as a delim."
|
||||||
(propertize "overloaded" 'face 'font-lock-keyword-face)
|
(propertize "overloaded" 'face 'font-lock-keyword-face)
|
||||||
overload-str))))
|
overload-str))))
|
||||||
(when proofstate
|
(when proofstate
|
||||||
(setq str (format "%s" (lean-info-proofstate-body-str proofstate))))
|
(cond ((not (lean-info-proofstate-states proofstate))
|
||||||
|
(setq str "No Goal"))
|
||||||
|
(t (setq str (lean-info-proofstate-states-str proofstate)))))
|
||||||
(when (and stale str)
|
(when (and stale str)
|
||||||
(setq str (format "[%s] %s"
|
(setq stale-str (format "[%s]"
|
||||||
(propertize "stale" 'face '(foreground-color . "red"))
|
(propertize "stale" 'face '(foreground-color . "red")))))
|
||||||
str)))
|
(cond (stale-str (list stale-str str))
|
||||||
str))
|
(t (list str)))))
|
||||||
|
|
||||||
(defun lean-get-info-record-at-point-cont (info-record cont)
|
(defun lean-get-info-record-at-point-cont (info-record cont)
|
||||||
(cond ((lean-info-record-nay info-record)
|
(cond ((lean-info-record-nay info-record)
|
||||||
|
|
|
@ -33,18 +33,29 @@
|
||||||
(interactive)
|
(interactive)
|
||||||
(lean-get-info-record-at-point 'lean-fill-placeholder-cont))
|
(lean-get-info-record-at-point 'lean-fill-placeholder-cont))
|
||||||
|
|
||||||
|
(defconst lean-info-buffer-name "*lean-info*")
|
||||||
|
|
||||||
|
(defun lean-setup-info-buffer ()
|
||||||
|
(unless (get-buffer lean-info-buffer-name)
|
||||||
|
(with-current-buffer (get-buffer-create lean-info-buffer-name)
|
||||||
|
(lean-info-mode))))
|
||||||
|
|
||||||
(defun lean-eldoc-documentation-function-cont (info-record &optional add-to-kill-ring)
|
(defun lean-eldoc-documentation-function-cont (info-record &optional add-to-kill-ring)
|
||||||
"Continuation for lean-eldoc-documentation-function"
|
"Continuation for lean-eldoc-documentation-function"
|
||||||
(let ((info-string (lean-info-record-to-string info-record)))
|
(let* ((info-strings (lean-info-record-to-strings info-record))
|
||||||
(when info-string
|
(info-string-mini-buffer (and info-strings (string-join info-strings " ")))
|
||||||
|
(info-string-info-buffer (and info-strings (string-join info-strings "\n")))
|
||||||
|
(info-buffer-delimiter "-------------------------------\n"))
|
||||||
|
(when info-strings
|
||||||
(when add-to-kill-ring
|
(when add-to-kill-ring
|
||||||
(kill-new
|
(kill-new
|
||||||
(substring-no-properties info-string)))
|
(substring-no-properties info-string-mini-buffer)))
|
||||||
(when (or lean-show-proofstate-in-minibuffer
|
(when (or lean-show-proofstate-in-minibuffer
|
||||||
(not (lean-info-record-proofstate info-record)))
|
(not (lean-info-record-proofstate info-record)))
|
||||||
(message "%s" info-string))
|
(message "%s" info-string-mini-buffer))
|
||||||
(lean-output-to-buffer "*lean-info*" "--------------------------\n" nil)
|
(lean-setup-info-buffer)
|
||||||
(lean-output-to-buffer "*lean-info*" "%s\n" (list info-string)))))
|
(lean-output-to-buffer "*lean-info*" info-buffer-delimiter nil)
|
||||||
|
(lean-output-to-buffer "*lean-info*" "%s\n" (list info-string-info-buffer)))))
|
||||||
|
|
||||||
(defun lean-eldoc-documentation-function (&optional add-to-kill-ring)
|
(defun lean-eldoc-documentation-function (&optional add-to-kill-ring)
|
||||||
"Show information of lean expression at point if any"
|
"Show information of lean expression at point if any"
|
||||||
|
|
Loading…
Reference in a new issue