-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathflycheck-mmark.el
More file actions
79 lines (67 loc) · 2.52 KB
/
flycheck-mmark.el
File metadata and controls
79 lines (67 loc) · 2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
;;; flycheck-mmark.el --- Flycheck checker for the MMark markdown processor -*- lexical-binding: t; -*-
;;
;; Copyright © 2018–present Mark Karpov <markkarpov92@gmail.com>
;;
;; Author: Mark Karpov <markkarpov92@gmail.com>
;; URL: https://github.com/mmark-md/flycheck-mmark
;; Version: 0.1.0
;; Package-Requires: ((emacs "24.4") (flycheck "0.29"))
;; Keywords: convenience, text
;;
;; This file is not part of GNU Emacs.
;;
;; This program is free software: you can redistribute it and/or modify it
;; under the terms of the GNU General Public License as published by the
;; Free Software Foundation, either version 3 of the License, or (at your
;; option) any later version.
;;
;; This program is distributed in the hope that it will be useful, but
;; WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
;; Public License for more details.
;;
;; You should have received a copy of the GNU General Public License along
;; with this program. If not, see <http://www.gnu.org/licenses/>.
;;; Commentary:
;; This package provides a Flycheck checker for the MMark markdown
;; processor.
;;; Code:
(require 'flycheck)
(require 'json)
(defgroup flycheck-mmark nil
"Flycheck checker for the MMark markdown processor."
:group 'flycheck
:tag "Flycheck MMark"
:prefix "flycheck-mmark-"
:link '(url-link :tag "GitHub"
"https://github.com/mmark-md/flycheck-mmark"))
(defun flycheck-mmark-parse-errors (output checker buffer)
"Decode MMark parse errors in JSON format decoding OUTPUT.
CHECKER is the checker used, BUFFER is the buffer that is being
checked."
(let ((json-array-type 'list))
(unless (string-empty-p output)
(mapcar
(lambda (err)
(flycheck-error-new
:checker checker
:buffer buffer
:line (cdr (assoc 'line err))
:column (cdr (assoc 'column err))
:message (cdr (assoc 'text err))
:level 'error))
(json-read-from-string output)))))
(flycheck-define-checker mmark
"A syntax checker for the MMark markdown processor using ‘mmark’ CLI tool.
See: https://github.com/mmark-md/mmark-cli"
:command ("mmark" "--json" "--ofile" null-device)
:standard-input t
:error-parser flycheck-mmark-parse-errors
:modes markdown-mode)
;;;###autoload
(defun flycheck-mmark-setup ()
"Setup Flycheck for MMark."
(interactive)
(add-to-list 'flycheck-checkers 'mmark))
(provide 'flycheck-mmark)
;;; flycheck-mmark.el ends here