Skip to content

Commit

Permalink
feat: define a flycheck checker
Browse files Browse the repository at this point in the history
  • Loading branch information
justinbarclay committed Oct 31, 2024
1 parent c611628 commit ea41945
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 0 deletions.
53 changes: 53 additions & 0 deletions parinfer-rust-flycheck.el
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
;;; parinfer-rust-flycheck.el --- Flycheck integration for parinfer-rust-mode -*- lexical-binding: t; -*-

;; Copyright (C) 2024 Justin Barclay

;; Author: Justin Barclay <[email protected]>

;; 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 <https://www.gnu.org/licenses/>.

;; This file is not part of GNU Emacs.

;;; Commentary:;; An assortment of helper functions and ports of functions from Emacs

;;; Code:
(eval-when-compile
(defvar parinfe-rust--errors '()))

(defun parinfer-rust--flycheck-start (checker callback)
"Process errors stored in parinfer-rust--errors into flycheck format."
(funcall callback 'finished
(mapcar (lambda (error)
(flycheck-error-new-at
(+ 1 (plist-get error :line_no))
(+ 1 (plist-get error :x))
'error
(plist-get error :message)
:id (plist-get error :name)
:checker checker))
parinfer-rust--errors)))
;; require flycheck if it is available
(when (require 'flycheck nil t)
(flycheck-define-generic-checker 'parinfer-rust
"A checker for parinfer-rust."
:start 'parinfer-rust--flycheck-start
:modes '(emacs-lisp-mode
scheme-mode
lisp-mode
clojure-mode
clojurescript-mode
clojure-ts-mode)))

(provide 'parifner-rust-flycheck)
;;; parinfer-rust-flycheck.el ends here
1 change: 1 addition & 0 deletions parinfer-rust-mode.el
Original file line number Diff line number Diff line change
Expand Up @@ -620,6 +620,7 @@ CHANGES."
(when (and (local-variable-if-set-p 'parinfer-rust--in-debug)
parinfer-rust--in-debug)
(parinfer-rust-debug "./parinfer-rust-debug.txt" options answer))
(setq parinfer-rust--errors (list parinfer-error))
(if parinfer-error
(message "Problem on line %s: %s"
(plist-get parinfer-error :line_no)
Expand Down

0 comments on commit ea41945

Please sign in to comment.