Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ Check [Keep a Changelog](http://keepachangelog.com/) for recommendations on how
* Rerender sideline after `flycheck-mode` is disabled (52801f817c257955f82a37108044b68ae8833190)
* Add face text property according to error level (793f7dbf5f9bb1899d741394a48605f1aa4a5ade)
* Add option to display checker name (1f2f82d4383718a8dd2aff40cffafce4a8d0aca1)
* feat: Add custom variable for max lines (#3)

## 0.1.0
> Released Jun 14, 2022
Expand Down
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,8 @@
#### 🧪 Variables

- `sideline-flycheck-inhibit-functions` - Functions to inhibit display of sideline flycheck.
- `sideline-flycheck-show-checker-name` - If non-nil, show checker name at the back.
- `sideline-flycheck-show-checker-name` - If non-nil, show the checker's name at the back.
- `sideline-flycheck-max-lines` - Maximum number of lines to show.

## Contribute

Expand Down
10 changes: 9 additions & 1 deletion sideline-flycheck.el
Original file line number Diff line number Diff line change
Expand Up @@ -57,10 +57,15 @@
:group 'sideline-flycheck)

(defcustom sideline-flycheck-show-checker-name nil
"If non-nil, show checker name at the back."
"If non-nil, show the checker's name at the back."
:type 'boolean
:group 'sideline-flycheck)

(defcustom sideline-flycheck-max-lines 1
"Maximum number of lines to show."
:type 'integer
:group 'sideline-flycheck)

(defvar-local sideline-flycheck--old-display-function nil
"The former value of `flycheck-display-errors-function'.")

Expand Down Expand Up @@ -90,6 +95,9 @@ Argument COMMAND is required in sideline backend."
(let* ((level (flycheck-error-level err))
(face (if (eq level 'info) 'success level))
(msg (flycheck-error-message err))
(lines (split-string msg "\n"))
(lines (butlast lines (- (length lines) sideline-flycheck-max-lines)))
(msg (mapconcat #'identity lines "\n"))
(checker (flycheck-error-checker err)))
(when sideline-flycheck-show-checker-name
(setq msg (format "%s (%s)" msg checker)))
Expand Down