Skip to content

Commit

Permalink
Add --stdin-file-path option (#125)
Browse files Browse the repository at this point in the history
* Add --stdin-file-path option

* Put stdin_file_path name into files for report
  • Loading branch information
Dmitry Matveyev authored May 13, 2021
1 parent f9c2c21 commit 82fe833
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 8 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ Command Line Flag | Description
`-e`/`--exclude` | Exclude one or more files from being linted
`-i`/`--include-linter` | Specify which linters you specifically want to run
`-x`/`--exclude-linter` | Specify which linters you _don't_ want to run
`--stdin-file-path [file]`| Pipe source from STDIN, using file in offense reports
`--[no-]color` | Whether to output in color
`--reporter [reporter]` | Specify which output formatter to use
`--show-linters` | Show all registered linters
Expand Down
5 changes: 5 additions & 0 deletions lib/slim_lint/options.rb
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,11 @@ def add_file_options(parser)
'List of file names to exclude') do |files|
@options[:excluded_files] = files
end

parser.on('--stdin-file-path file', String,
'Pipe source from STDIN, using file in offense reports.') do |file|
@options[:stdin_file_path] = file
end
end

# Register informational flags.
Expand Down
20 changes: 12 additions & 8 deletions lib/slim_lint/runner.rb
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,17 @@ class Runner
# @return [SlimLint::Report] a summary of all lints found
def run(options = {})
config = load_applicable_config(options)
files = extract_applicable_files(config, options)

linter_selector = SlimLint::LinterSelector.new(config, options)

lints = files.map do |file|
collect_lints(file, linter_selector, config)
end.flatten
if options[:stdin_file_path].nil?
files = extract_applicable_files(config, options)
lints = files.map do |file|
collect_lints(File.read(file), file, linter_selector, config)
end.flatten
else
files = [options[:stdin_file_path]]
lints = collect_lints($stdin.read, options[:stdin_file_path], linter_selector, config)
end

SlimLint::Report.new(lints, files)
end
Expand Down Expand Up @@ -49,14 +53,14 @@ def load_applicable_config(options)
# @param file [String] path to file to lint
# @param linter_selector [SlimLint::LinterSelector]
# @param config [SlimLint::Configuration]
def collect_lints(file, linter_selector, config)
def collect_lints(file_content, file_name, linter_selector, config)
begin
document = SlimLint::Document.new(File.read(file), file: file, config: config)
document = SlimLint::Document.new(file_content, file: file_name, config: config)
rescue SlimLint::Exceptions::ParseError => e
return [SlimLint::Lint.new(nil, file, e.lineno, e.error, :error)]
end

linter_selector.linters_for_file(file).map do |linter|
linter_selector.linters_for_file(file_name).map do |linter|
linter.run(document)
end.flatten
end
Expand Down
8 changes: 8 additions & 0 deletions spec/slim_lint/options_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,14 @@
end
end

context 'with input from stdin' do
let(:args) { %w[--stdin-file-path file1.slim] }

it 'sets the `stdin_file_path` option to passed file name' do
subject.should include stdin_file_path: 'file1.slim'
end
end

context 'with a reporter option' do
context 'for a reporter that exists' do
let(:args) { %w[--reporter Json] }
Expand Down
14 changes: 14 additions & 0 deletions spec/slim_lint/runner_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@

before do
runner.stub(:collect_lints).and_return([])
File.stub(:read).and_return('.myclass')
end

it 'searches for lints in each file' do
Expand Down Expand Up @@ -62,5 +63,18 @@
subject
end
end

context 'when `--stdin-file-path` option specified' do
let(:options) { { stdin_file_path: 'file1.slim' } }

before do
$stdin.stub(:read).and_return('.myclass')
end

it 'searches for lints from STDIN' do
runner.should_receive(:collect_lints).exactly(1).times
subject
end
end
end
end

0 comments on commit 82fe833

Please sign in to comment.