Sha256: 43efbdedaa32e19a39f295ad0dc9f8b1e85c89dae9ea7adcbdbd7afc79cac10c
Contents?: true
Size: 1.74 KB
Versions: 1
Compression:
Stored size: 1.74 KB
Contents
require "logger" module Danger class SwiftFormat def initialize(path = nil) @path = path || "swiftformat" end def installed? Cmd.run([@path, "--version"]) end def check_format(files, additional_args = "", swiftversion = "") cmd = [@path] + files cmd << additional_args.split unless additional_args.nil? || additional_args.empty? unless swiftversion.empty? cmd << "--swiftversion" cmd << swiftversion end cmd << %w(--lint --lenient) stdout, stderr, status = Cmd.run(cmd.flatten) output = stdout.empty? ? stderr : stdout raise "Error running SwiftFormat: Empty output." unless output output = output.strip.no_color if status && !status.success? raise "Error running SwiftFormat:\nError: #{output}" else raise "Error running SwiftFormat: Empty output." if output.empty? end process(output) end private def process(output) { errors: errors(output), stats: { run_time: run_time(output) } } end ERRORS_REGEX = /(.*:\d+:\d+): ((warning|error):.*)$/.freeze def errors(output) errors = [] output.scan(ERRORS_REGEX) do |match| next if match.count < 2 errors << { file: match[0].sub("#{Dir.pwd}/", ""), rules: match[1].split(",").map(&:strip) } end errors end RUNTIME_REGEX = /.*SwiftFormat completed.*(.+\..+)s/.freeze def run_time(output) if RUNTIME_REGEX.match(output) RUNTIME_REGEX.match(output)[1] else logger = Logger.new($stderr) logger.error("Invalid run_time output: #{output}") "-1" end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
danger-swiftformat-0.8.0 | lib/swiftformat/swiftformat.rb |