-
Notifications
You must be signed in to change notification settings - Fork 67
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #21 from ethereum/fix_flycheck_undefined_errors
Fix flycheck undefined errors
- Loading branch information
Showing
4 changed files
with
231 additions
and
166 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
;;; solidity-common.el --- Common code used by all sourcefiles | ||
|
||
;; Copyright (C) 2015-2018 Lefteris Karapetsas | ||
|
||
;; Author: Lefteris Karapetsas <[email protected]> | ||
;; Keywords: languages | ||
|
||
;; 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: | ||
|
||
;; Some common definitions used by all source files of the package are defined | ||
;; here in order to avoid circular dependencies | ||
;; | ||
;;; Code: | ||
|
||
(defcustom solidity-solc-path "solc" | ||
"Path to the solc binary." | ||
:group 'solidity | ||
:type 'string | ||
:package-version '(solidity . "0.1.1")) | ||
|
||
(defcustom solidity-solium-path "solium" | ||
"Path to the solium binary." | ||
:group 'solidity | ||
:type 'string | ||
:package-version '(solidity . "0.1.4")) | ||
|
||
(provide 'solidity-common) | ||
;;; solidity-common.el ends here |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,181 @@ | ||
;;; solidity-flycheck.el --- Flycheck integration for solidity emacs mode | ||
|
||
;; Copyright (C) 2015-2018 Lefteris Karapetsas | ||
|
||
;; Author: Lefteris Karapetsas <[email protected]> | ||
;; Keywords: languages | ||
|
||
;; 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: | ||
|
||
;; flycheck integration is taken in a different file to prevent problems | ||
;; when flycheck is not present on the user's system. | ||
;; | ||
;;; Code: | ||
|
||
(require 'flycheck) | ||
(require 'solidity-common) | ||
|
||
(defvar flycheck-solidity-checker-executable) | ||
(defvar flycheck-solium-checker-executable) | ||
|
||
(defcustom solidity-flycheck-solc-checker-active nil | ||
"A boolean flag denoting if solc flycheck checker should be active." | ||
:group 'solidity | ||
:type 'boolean | ||
:safe #'booleanp | ||
:package-version '(solidity . "0.1.5")) | ||
|
||
(defcustom solidity-flycheck-chaining-error-level 'warning | ||
"The maximum error level at which chaining of checkers will happen. | ||
This means that this is the error level for which solc checker will allow | ||
next checkers to run. By default this is the warning level. | ||
Possible values are: | ||
`info' | ||
If any errors higher than info level are found in solc, then solium | ||
will not run. | ||
`warning' | ||
If any errors higher than warning level are found in solc, then solium | ||
will not run. | ||
`error' | ||
If any errors higher than error level are found in solc, then solium | ||
will not run. | ||
t | ||
Solium will always run." | ||
:group 'solidity | ||
:type '(choice (const :tag "Chain after info-error level" info) | ||
(const :tag "Chain after warning-error level" warning) | ||
(const :tag "Chain after error-error level" error) | ||
(const :tag "Always chain" t)) | ||
:package-version '(solidity . "0.1.5") | ||
:safe #'symbolp) | ||
|
||
(defcustom solidity-flycheck-solium-checker-active nil | ||
"A boolean flag denoting if solium flycheck checker should be active." | ||
:group 'solidity | ||
:type 'boolean | ||
:safe #'booleanp | ||
:package-version '(solidity . "0.1.5")) | ||
|
||
(flycheck-def-option-var flycheck-solidity-solc-addstd-contracts nil solidity-checker | ||
"Whether to add standard solidity contracts. | ||
When non-nil, enable add also standard solidity contracts via | ||
`--add-std'." | ||
:type 'boolean | ||
:safe #'booleanp | ||
:package-version '(solidity-mode . "0.1.3")) | ||
|
||
(flycheck-def-option-var flycheck-solidity-solium-soliumrcfile nil solium-check | ||
"The path to use for soliumrc.json | ||
The value of this variable is either a string denoting a path to the soliumrc.json | ||
or nil, to use the current directory. When non-nil, | ||
we pass the directory to solium via the `--config' option." | ||
:type '(choice (const :tag "No custom soliumrc" nil) | ||
(string :tag "Custom soliumrc file location")) | ||
:safe #'stringp | ||
:package-version '(solidity-mode . "0.1.4")) | ||
|
||
;; add a solidity mode callback to set the executable of solc for flycheck | ||
;; define solidity's flycheck syntax checker | ||
;; (let ((next-checkers-val `((,solidity-flycheck-chaining-error-level . solium-checker)))) | ||
;; (flycheck-define-checker solidity-checker | ||
;; "A Solidity syntax checker using the solc compiler" | ||
;; :command ("solc" | ||
;; (option-flag "--add-std" flycheck-solidity-solc-addstd-contracts) | ||
;; source-inplace) | ||
;; :error-patterns | ||
;; ((error line-start (file-name) ":" line ":" column ":" " Error: " (message)) | ||
;; (error line-start "Error: " (message)) | ||
;; (warning line-start (file-name) ":" line ":" column ":" " Warning: " (message))) | ||
;; :next-checkers next-checkers-val | ||
;; ;; :next-checkers `((,solidity-flycheck-chaining-error-level . solium-checker)) | ||
;; :modes solidity-mode | ||
;; :predicate (lambda () (eq major-mode 'solidity-mode)))) | ||
|
||
;; expanded the flycheck-define-checker macro as per advice given in gitter | ||
;; https://gitter.im/flycheck/flycheck?at=5a43b3a8232e79134d98872b in order to avoid the | ||
;; next-checkers `'` introduced by the flycheck-define-checker macro | ||
(progn | ||
(flycheck-def-executable-var solidity-checker "solc") | ||
(flycheck-define-command-checker 'solidity-checker "A Solidity syntax checker using the solc compiler" :command | ||
'("solc" | ||
(option-flag "--add-std" flycheck-solidity-solc-addstd-contracts) | ||
source-inplace) | ||
:error-patterns | ||
'((error line-start | ||
(file-name) | ||
":" line ":" column ":" " Error: " | ||
(message)) | ||
(error line-start "Error: " | ||
(message)) | ||
(warning line-start | ||
(file-name) | ||
":" line ":" column ":" " Warning: " | ||
(message))) | ||
:modes 'solidity-mode :predicate | ||
#'(lambda nil | ||
(eq major-mode 'solidity-mode)) | ||
:next-checkers | ||
`((,solidity-flycheck-chaining-error-level . solium-checker)) | ||
:standard-input 'nil :working-directory 'nil)) | ||
|
||
;; define solium flycheck syntax checker | ||
(flycheck-define-checker solium-checker | ||
"A Solidity linter using solium" | ||
:command ("solium" | ||
(option "--config=" flycheck-solidity-solium-soliumrcfile concat) | ||
"-f" | ||
source-inplace) | ||
:error-patterns | ||
((error line-start (zero-or-more " ") line ":" column (zero-or-more " ") "error" (message)) | ||
(error line-start (zero-or-more not-newline) "[Fatal error]" (message)) | ||
(warning line-start (zero-or-more " ") line ":" column (zero-or-more " ") "warning" (message))) | ||
:error-filter | ||
;; Add fake line numbers if they are missing in the lint output | ||
(lambda (errors) | ||
(dolist (err errors) | ||
(unless (flycheck-error-line err) | ||
(setf (flycheck-error-line err) 1))) | ||
errors) | ||
:modes solidity-mode | ||
:predicate (lambda () (eq major-mode 'solidity-mode))) | ||
|
||
;; first try to add solium to the checker's list since if we got solc | ||
;; it must come after it in the list due to it being chained after solc | ||
(when solidity-flycheck-solium-checker-active | ||
(if (file-executable-p solidity-solium-path) | ||
(progn | ||
(add-to-list 'flycheck-checkers 'solium-checker) | ||
(setq flycheck-solium-checker-executable solidity-solium-path)) | ||
(error (format "Solidity Mode Configuration error. Requested solium flycheck integration but can't find solium at: %s" solidity-solium-path)))) | ||
|
||
(when solidity-flycheck-solc-checker-active | ||
(if (file-executable-p solidity-solc-path) | ||
(progn | ||
(add-to-list 'flycheck-checkers 'solidity-checker) | ||
(add-hook 'solidity-mode-hook | ||
(lambda () | ||
(let ((solidity-command (concat solidity-solc-path))) | ||
(setq flycheck-solidity-checker-executable solidity-command))))) | ||
(error (format "Solidity Mode Configuration error. Requested solc flycheck integration but can't find solc at: %s" solidity-solc-path)))) | ||
|
||
(provide 'solidity-flycheck) | ||
;;; solidity-flycheck.el ends here |
Oops, something went wrong.