feat(emacs/lean-flycheck): detect and use flycheck error buffer width
Detect the width of flycheck error list buffer and set pp.width when calling flycheck. It uses the same heuristic that `split-window-sensibly` function is using. A user can also set `lean-flycheck-msg-width` custom variable to enforce a certain width. Close #205.
This commit is contained in:
parent
486839881c
commit
41acc10d49
4 changed files with 63 additions and 19 deletions
|
@ -15,7 +15,7 @@
|
||||||
lean-flycheck-checker-options
|
lean-flycheck-checker-options
|
||||||
'("--cache")
|
'("--cache")
|
||||||
'(source-original)
|
'(source-original)
|
||||||
'((eval (lean-option-string)))
|
'((eval (lean-option-string t)))
|
||||||
'("--")
|
'("--")
|
||||||
'(source-inplace))))
|
'(source-inplace))))
|
||||||
(when (string= system-type "windows-nt")
|
(when (string= system-type "windows-nt")
|
||||||
|
@ -97,4 +97,27 @@
|
||||||
(tempfiles (--map (concat tempfile it) exts)))
|
(tempfiles (--map (concat tempfile it) exts)))
|
||||||
(mapc #'flycheck-safe-delete tempfiles))))
|
(mapc #'flycheck-safe-delete tempfiles))))
|
||||||
|
|
||||||
|
|
||||||
|
(defun lean-flycheck-error-list-buffer-width ()
|
||||||
|
"Return the width of flycheck-error list buffer"
|
||||||
|
(interactive)
|
||||||
|
(let* ((flycheck-error-window (get-buffer-window "*Flycheck errors*" t))
|
||||||
|
(window (selected-window))
|
||||||
|
(body-width (window-body-width window)))
|
||||||
|
(cond
|
||||||
|
;; If "*Flycheck errors" buffer is available, use its width
|
||||||
|
(flycheck-error-window
|
||||||
|
(window-body-width flycheck-error-window))
|
||||||
|
;; If lean-flycheck-msg-width is set, use it
|
||||||
|
(lean-flycheck-msg-width
|
||||||
|
lean-flycheck-msg-width)
|
||||||
|
;; Can we split vertically?
|
||||||
|
((window-splittable-p window nil)
|
||||||
|
body-width)
|
||||||
|
;; Can we split horizontally?
|
||||||
|
((window-splittable-p window t)
|
||||||
|
(/ body-width 2))
|
||||||
|
;; In worst case, just use the same width of current window
|
||||||
|
(t body-width))))
|
||||||
|
|
||||||
(provide 'lean-flycheck)
|
(provide 'lean-flycheck)
|
||||||
|
|
|
@ -26,21 +26,30 @@
|
||||||
(-drop 1 str-list)))
|
(-drop 1 str-list)))
|
||||||
(string-join str-list "\n")))
|
(string-join str-list "\n")))
|
||||||
|
|
||||||
(defun lean-option-string ()
|
(defun lean-option-string (&optional use-flycheck)
|
||||||
"Return string of Lean options set by lean-set-option command"
|
"Return string of Lean options set by lean-set-option command"
|
||||||
(let ((pp-width-entry (assoc-string "pp.width" lean-global-option-alist)))
|
(let* ((option-alist lean-global-option-alist)
|
||||||
(unless pp-width-entry
|
(pp-width-entry (assoc-string "pp.width" option-alist)))
|
||||||
(lean-update-option-alist "pp.width" lean-default-pp-width)))
|
(cond (use-flycheck
|
||||||
(when lean-global-option-alist
|
(setq option-alist
|
||||||
|
(lean-update-option-alist option-alist
|
||||||
|
"pp.width"
|
||||||
|
(lean-flycheck-error-list-buffer-width))))
|
||||||
|
((not pp-width-entry)
|
||||||
|
(setq option-alist
|
||||||
|
(lean-update-option-alist option-alist
|
||||||
|
"pp.width"
|
||||||
|
lean-default-pp-width))))
|
||||||
|
(when option-alist
|
||||||
(--reduce (format "%s %s" acc it)
|
(--reduce (format "%s %s" acc it)
|
||||||
(--map (format "-D%s=%s" (car it) (cdr it))
|
(--map (format "-D%s=%s" (car it) (cdr it))
|
||||||
lean-global-option-alist))))
|
option-alist)))))
|
||||||
|
|
||||||
(defun lean-update-option-alist (name value)
|
(defun lean-update-option-alist (option-alist name value)
|
||||||
(let ((needle (assoc-string name lean-global-option-alist)))
|
(let ((needle (assoc-string name option-alist)))
|
||||||
(when needle
|
(when needle
|
||||||
(setq lean-global-option-alist (delq needle lean-global-option-alist)))
|
(setq option-alist (delq needle option-alist)))
|
||||||
(setq lean-global-option-alist (cl-acons name value lean-global-option-alist))))
|
(setq option-alist (cl-acons name value option-alist))))
|
||||||
|
|
||||||
(defun lean-set-option-cont (option-record-alist)
|
(defun lean-set-option-cont (option-record-alist)
|
||||||
(let* ((key-list (-map 'car option-record-alist))
|
(let* ((key-list (-map 'car option-record-alist))
|
||||||
|
@ -52,7 +61,10 @@
|
||||||
(option-value (lean-option-read option)))
|
(option-value (lean-option-read option)))
|
||||||
(lean-server-send-cmd-async
|
(lean-server-send-cmd-async
|
||||||
(lean-cmd-set option-name option-value)
|
(lean-cmd-set option-name option-value)
|
||||||
(lambda (dummy) (lean-update-option-alist option-name option-value)))))
|
(lambda (dummy) (setq lean-global-option-alist
|
||||||
|
(lean-update-option-alist lean-global-option-alist
|
||||||
|
option-name
|
||||||
|
option-value))))))
|
||||||
|
|
||||||
(defun lean-set-option ()
|
(defun lean-set-option ()
|
||||||
"Set Lean option."
|
"Set Lean option."
|
||||||
|
|
|
@ -68,12 +68,18 @@ show both of expressions and types.")
|
||||||
"Maximum number of flycheck messages to displaylean-flychecker checker name
|
"Maximum number of flycheck messages to displaylean-flychecker checker name
|
||||||
(Restart required to be effective)"
|
(Restart required to be effective)"
|
||||||
:group 'lean
|
:group 'lean
|
||||||
:type 'int)
|
:type 'number)
|
||||||
|
|
||||||
(defcustom lean-default-pp-width 120
|
(defcustom lean-default-pp-width 120
|
||||||
"Width of Lean error/warning messages"
|
"Width of Lean error/warning messages"
|
||||||
:group 'lean
|
:group 'lean
|
||||||
:type 'int)
|
:type 'number)
|
||||||
|
|
||||||
|
(defcustom lean-flycheck-msg-width nil
|
||||||
|
"Width of Lean error/warning messages"
|
||||||
|
:group 'lean
|
||||||
|
:type '(choice (const :tag "Let lean-mode automatically detect this" nil)
|
||||||
|
(integer :tag "Specify the value and force lean-mode to use")))
|
||||||
|
|
||||||
(defcustom lean-flycheck-checker-options
|
(defcustom lean-flycheck-checker-options
|
||||||
`("--flycheck"
|
`("--flycheck"
|
||||||
|
|
|
@ -10,11 +10,13 @@
|
||||||
(require 'lean-option)
|
(require 'lean-option)
|
||||||
|
|
||||||
(ert-deftest lean-test-update-string-alist ()
|
(ert-deftest lean-test-update-string-alist ()
|
||||||
(lean-update-option-alist "pp.implicit" 'true)
|
(setq lean-global-option-alist
|
||||||
|
(lean-update-option-alist lean-global-option-alist "pp.implicit" 'true))
|
||||||
(should
|
(should
|
||||||
(equal (assoc-string "pp.implicit" lean-global-option-alist)
|
(equal (assoc-string "pp.implicit" lean-global-option-alist)
|
||||||
'("pp.implicit" . true)))
|
'("pp.implicit" . true)))
|
||||||
(lean-update-option-alist "pp.implicit" 'false)
|
(setq lean-global-option-alist
|
||||||
|
(lean-update-option-alist lean-global-option-alist "pp.implicit" 'false))
|
||||||
(should
|
(should
|
||||||
(equal (assoc-string "pp.implicit" lean-global-option-alist)
|
(equal (assoc-string "pp.implicit" lean-global-option-alist)
|
||||||
'("pp.implicit" . false))))
|
'("pp.implicit" . false))))
|
||||||
|
@ -25,7 +27,8 @@
|
||||||
(format "-D%s=%d"
|
(format "-D%s=%d"
|
||||||
"pp.width"
|
"pp.width"
|
||||||
lean-default-pp-width)))
|
lean-default-pp-width)))
|
||||||
(lean-update-option-alist "pp.width" 80)
|
(setq lean-global-option-alist
|
||||||
|
(lean-update-option-alist lean-global-option-alist "pp.width" 80))
|
||||||
(should (string= (lean-option-string)
|
(should (string= (lean-option-string)
|
||||||
(format "-D%s=%d"
|
(format "-D%s=%d"
|
||||||
"pp.width"
|
"pp.width"
|
||||||
|
|
Loading…
Reference in a new issue