Sha256: aedff822296764ee07d416a39f32e47ef33fda9108e917e8a409c923064d14d4
Contents?: true
Size: 1.6 KB
Versions: 1
Compression:
Stored size: 1.6 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 = "") cmd = [@path] + files cmd << additional_args.split unless additional_args.nil? || additional_args.empty? cmd << %w(--dryrun --verbose) 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 = /Formatting\s(.*)\n-- rules applied:(.*)$/.freeze def errors(output) errors = [] output.scan(ERRORS_REGEX) do |match| next if match.count < 2 errors << { file: match[0], 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.7.0 | lib/swiftformat/swiftformat.rb |