Class: Overcommit::GitHook::RubyStyle

Inherits:
HookSpecificCheck show all
Includes:
HookRegistry
Defined in:
lib/overcommit/plugins/pre_commit/ruby_style.rb

Instance Method Summary collapse

Methods included from HookRegistry

included

Methods inherited from HookSpecificCheck

file_type, friendly_name, #initialize, #name, required!, #skip?, skippable?, #staged, stealth!, #stealth?

Constructor Details

This class inherits a constructor from Overcommit::GitHook::HookSpecificCheck

Instance Method Details

#run_checkObject



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
# File 'lib/overcommit/plugins/pre_commit/ruby_style.rb', line 9

def run_check
  unless in_path?('rubocop')
    return :warn, 'rubocop not installed -- run `gem install rubocop`'
  end

  paths_to_staged_files = Hash[staged.map { |s| [s.path, s] }]

  success, output = run_rubocop
  return :good if success

  # Keep lines from the output for files that we actually modified
  error_lines, warning_lines = output.lines.partition do |output_line|
    if match = output_line.match(/^([^:]+):(\d+)/)
      file = match[1]
      line = match[2]
    end
    unless paths_to_staged_files[file]
      return :warn, "Unexpected output from rubocop:\n#{output}"
    end
    paths_to_staged_files[file].modified_lines.include?(line.to_i)
  end

  return :bad, error_lines.join unless error_lines.empty?
  return :warn, "Modified files have style lints (on lines you didn't modify)\n" <<
                warning_lines.join
end