mirror of
https://gitea.invidious.io/iv-org/shard-ameba.git
synced 2024-08-15 00:53:29 +00:00
parent
202a73ae0e
commit
e1fa8677b0
3 changed files with 118 additions and 43 deletions
44
spec/ameba/formatter/flycheck_formatter_spec.cr
Normal file
44
spec/ameba/formatter/flycheck_formatter_spec.cr
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
require "../../spec_helper"
|
||||||
|
|
||||||
|
private def flycheck
|
||||||
|
output = IO::Memory.new
|
||||||
|
Ameba::Formatter::FlycheckFormatter.new output
|
||||||
|
end
|
||||||
|
|
||||||
|
module Ameba::Formatter
|
||||||
|
describe FlycheckFormatter do
|
||||||
|
context "problems not found" do
|
||||||
|
it "reports nothing" do
|
||||||
|
subject = flycheck
|
||||||
|
subject.source_finished Source.new ""
|
||||||
|
subject.output.to_s.empty?.should be_true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "when problems found" do
|
||||||
|
it "reports an error" do
|
||||||
|
s = Source.new "a = 1", "source.cr"
|
||||||
|
s.error DummyRule.new, s.location(1, 2), "message"
|
||||||
|
subject = flycheck
|
||||||
|
subject.source_finished s
|
||||||
|
subject.output.to_s.should eq "source.cr:1:2: E: message\n"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "properly reports multi-line message" do
|
||||||
|
s = Source.new "a = 1", "source.cr"
|
||||||
|
s.error DummyRule.new, s.location(1, 2), "multi\nline"
|
||||||
|
subject = flycheck
|
||||||
|
subject.source_finished s
|
||||||
|
subject.output.to_s.should eq "source.cr:1:2: E: multi line\n"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "reports nothing if location was not set" do
|
||||||
|
s = Source.new "a = 1", "source.cr"
|
||||||
|
s.error DummyRule.new, nil, "message"
|
||||||
|
subject = flycheck
|
||||||
|
subject.source_finished s
|
||||||
|
subject.output.to_s.should eq ""
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -5,45 +5,15 @@ require "option_parser"
|
||||||
module Ameba::Cli
|
module Ameba::Cli
|
||||||
extend self
|
extend self
|
||||||
|
|
||||||
private class Opts
|
AVAILABLE_FORMATTERS = {
|
||||||
property config = Ameba::Config::PATH
|
progress: Formatter::DotFormatter,
|
||||||
property silent : Bool = false
|
todo: Formatter::TODOFormatter,
|
||||||
property generate : Bool = false
|
flycheck: Formatter::FlycheckFormatter,
|
||||||
property files : Array(String)?
|
silent: Formatter::BaseFormatter,
|
||||||
property only : Array(String)?
|
}
|
||||||
property except : Array(String)?
|
|
||||||
end
|
|
||||||
|
|
||||||
def run(args, opts = Opts.new)
|
def run(args)
|
||||||
OptionParser.parse(args) do |parser|
|
opts = parse_args args
|
||||||
parser.banner = "Usage: ameba [options] [file1 file2 ...]"
|
|
||||||
|
|
||||||
parser.on("-v", "--version", "Print version") { print_version }
|
|
||||||
parser.on("-h", "--help", "Show this help") { show_help parser }
|
|
||||||
parser.on("-s", "--silent", "Disable output") { opts.silent = true }
|
|
||||||
parser.unknown_args { |f| opts.files = f if f.any? }
|
|
||||||
|
|
||||||
parser.on("-c PATH", "--config PATH", "Specify configuration file") do |f|
|
|
||||||
opts.config = f
|
|
||||||
end
|
|
||||||
|
|
||||||
parser.on("--only RULE1,RULE2,...", "Specify a list of rules") do |rules|
|
|
||||||
opts.only = rules.split ","
|
|
||||||
end
|
|
||||||
|
|
||||||
parser.on("--except RULE1,RULE2,...", "Disable the given rules") do |rules|
|
|
||||||
opts.except = rules.split ","
|
|
||||||
end
|
|
||||||
|
|
||||||
parser.on("--gen-config", "Generate a configuration file acting as a TODO list") do
|
|
||||||
opts.generate = true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
run_ameba opts
|
|
||||||
end
|
|
||||||
|
|
||||||
def run_ameba(opts)
|
|
||||||
config = Ameba::Config.load opts.config
|
config = Ameba::Config.load opts.config
|
||||||
config.files = opts.files
|
config.files = opts.files
|
||||||
|
|
||||||
|
@ -56,6 +26,52 @@ module Ameba::Cli
|
||||||
exit 255
|
exit 255
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private class Opts
|
||||||
|
property config = Ameba::Config::PATH
|
||||||
|
property formatter : String | Symbol = :progress
|
||||||
|
property files : Array(String)?
|
||||||
|
property only : Array(String)?
|
||||||
|
property except : Array(String)?
|
||||||
|
end
|
||||||
|
|
||||||
|
def parse_args(args, opts = Opts.new)
|
||||||
|
OptionParser.parse(args) do |parser|
|
||||||
|
parser.banner = "Usage: ameba [options] [file1 file2 ...]"
|
||||||
|
|
||||||
|
parser.on("-v", "--version", "Print version") { print_version }
|
||||||
|
parser.on("-h", "--help", "Show this help") { show_help parser }
|
||||||
|
parser.on("-s", "--silent", "Disable output") { opts.formatter = :silent }
|
||||||
|
parser.unknown_args { |f| opts.files = f if f.any? }
|
||||||
|
|
||||||
|
parser.on("-c", "--config PATH",
|
||||||
|
"Specify a configuration file") do |path|
|
||||||
|
opts.config = path
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on("-f", "--format FORMATTER",
|
||||||
|
"Choose an output formatter: #{formatters}") do |formatter|
|
||||||
|
opts.formatter = formatter
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on("--only RULE1,RULE2,...",
|
||||||
|
"Run only given rules") do |rules|
|
||||||
|
opts.only = rules.split ","
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on("--except RULE1,RULE2,...",
|
||||||
|
"Disable the given rules") do |rules|
|
||||||
|
opts.except = rules.split ","
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on("--gen-config",
|
||||||
|
"Generate a configuration file acting as a TODO list") do
|
||||||
|
opts.formatter = "todo"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
opts
|
||||||
|
end
|
||||||
|
|
||||||
private def configure_rules(config, opts)
|
private def configure_rules(config, opts)
|
||||||
if only = opts.only
|
if only = opts.only
|
||||||
config.rules.map! { |r| r.enabled = false; r }
|
config.rules.map! { |r| r.enabled = false; r }
|
||||||
|
@ -70,15 +86,17 @@ module Ameba::Cli
|
||||||
end
|
end
|
||||||
|
|
||||||
private def configure_formatter(config, opts)
|
private def configure_formatter(config, opts)
|
||||||
if opts.silent
|
if cls = AVAILABLE_FORMATTERS[opts.formatter]?
|
||||||
config.formatter = Ameba::Formatter::BaseFormatter.new
|
config.formatter = cls.new
|
||||||
elsif opts.generate
|
|
||||||
config.formatter = Ameba::Formatter::TODOFormatter.new
|
|
||||||
else
|
else
|
||||||
config.formatter = Ameba::Formatter::DotFormatter.new
|
raise "Unknown formatter `#{opts.formatter}`. Use any of #{formatters}."
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private def formatters
|
||||||
|
AVAILABLE_FORMATTERS.keys.join("|")
|
||||||
|
end
|
||||||
|
|
||||||
private def print_version
|
private def print_version
|
||||||
puts Ameba::VERSION
|
puts Ameba::VERSION
|
||||||
exit 0
|
exit 0
|
||||||
|
|
13
src/ameba/formatter/flycheck_formatter.cr
Normal file
13
src/ameba/formatter/flycheck_formatter.cr
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
module Ameba::Formatter
|
||||||
|
class FlycheckFormatter < BaseFormatter
|
||||||
|
def source_finished(source : Source)
|
||||||
|
source.errors.each do |e|
|
||||||
|
if loc = e.location
|
||||||
|
output.printf "%s:%d:%d: %s: %s\n",
|
||||||
|
source.path, loc.line_number, loc.column_number, "E",
|
||||||
|
e.message.gsub("\n", " ")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue