forked from sds/overcommit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpylint.rb
30 lines (26 loc) · 889 Bytes
/
pylint.rb
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
module Overcommit::Hook::PreCommit
# Runs `pylint` against any modified Python files.
#
# @see http://www.pylint.org/
class Pylint < Base
MESSAGE_REGEX = /^(?<file>(?:\w:)?.+):(?<line>\d+):(?<type>[CEFRW])/
# Classify 'E' and 'F' message codes as errors,
# everything else as warnings.
# http://pylint.readthedocs.org/en/latest/tutorial.html#getting-started
MESSAGE_TYPE_CATEGORIZER = lambda do |type|
'EF'.include?(type) ? :error : :warning
end
def run
result = execute(command, args: applicable_files)
return :pass if result.success?
output = result.stdout.chomp
# example message:
# path/to/file.py:64:C: Missing function docstring (missing-docstring)
extract_messages(
output.split("\n").grep(MESSAGE_REGEX),
MESSAGE_REGEX,
MESSAGE_TYPE_CATEGORIZER
)
end
end
end