Odpowiedź saltycrane sprawdziła się dobrze. Dzięki! Rozwiązanie podaje bardzo krótkie komunikaty o błędach, jak wskazuje. Poprawiłem komunikaty o błędach, aby były bardziej szczegółowe i wyglądają bardziej jak dane wyjściowe z wyjścia flow cli.
Uwaga dla nowych użytkowników, którzy chcą korzystać z tego skryptu, jest pewna, że dokonano edycji, aby użyć odpowiedniego trybu na dole strony w przypadku flycheck-define-checker
. Używam tego w js2-mode
, a saltycrane używa react-mode
. Edytuj go, aby użyć tego, czego używasz.
(require 'f)
(require 'json)
(require 'flycheck)
(defun flycheck-parse-flow (output checker buffer)
(let ((json-array-type 'list))
(let ((o (json-read-from-string output)))
(mapcar #'(lambda (errp)
(let ((err (cadr (assoc 'message errp)))
(err2 (cadr (cdr (assoc 'message errp)))))
(flycheck-error-new
:line (cdr (assoc 'line err))
:column (cdr (assoc 'start err))
:level 'error
:message (concat (cdr (assoc 'descr err)) ". " (cdr (assoc 'descr err2)))
:filename (f-relative
(cdr (assoc 'path err))
(f-dirname (file-truename
(buffer-file-name))))
:buffer buffer
:checker checker)))
(cdr (assoc 'errors o))))))
(flycheck-define-checker javascript-flow
"Static type checking using Flow."
:command ("flow" "--json" source-original)
:error-parser flycheck-parse-flow
:modes js2-mode)
(add-to-list 'flycheck-checkers 'javascript-flow)