Handle case when compiler reports incorrect node location

fixes #168
This commit is contained in:
Vitalii Elenhaupt 2020-10-23 10:41:17 +03:00
parent 9a42d14a1e
commit 44290a6a5d
No known key found for this signature in database
GPG key ID: CD0BF17825928BC0
4 changed files with 39 additions and 1 deletions

View file

@ -60,6 +60,24 @@ module Ameba::AST
" end", " end",
]) ])
end end
it "does not report source of node which has incorrect location" do
s = %q(
module MyModule
macro conditional_error_for_inline_callbacks
\{%
raise ""
%}
end
macro before_save(x = nil)
end
end
)
node = as_nodes(s).nil_literal_nodes.first
source = subject.node_source node, s.split("\n")
source.should be_nil
end
end end
describe "#flow_command?" do describe "#flow_command?" do

View file

@ -95,6 +95,22 @@ module Ameba
end end
) )
it "does not report emtpy expression in macro" do
s = Source.new %q(
module MyModule
macro conditional_error_for_inline_callbacks
\{%
raise ""
%}
end
macro before_save(x = nil)
end
end
)
subject.catch(s).should be_valid
end
it "reports rule, location and message" do it "reports rule, location and message" do
s = Source.new %( s = Source.new %(
if () if ()

View file

@ -151,6 +151,7 @@ module Ameba
class TestNodeVisitor < Crystal::Visitor class TestNodeVisitor < Crystal::Visitor
NODES = [ NODES = [
Crystal::NilLiteral,
Crystal::Var, Crystal::Var,
Crystal::Assign, Crystal::Assign,
Crystal::OpAssign, Crystal::OpAssign,

View file

@ -40,7 +40,8 @@ module Ameba::AST::Util
node_lines = code_lines[line..end_line] node_lines = code_lines[line..end_line]
first_line, last_line = node_lines[0]?, node_lines[-1]? first_line, last_line = node_lines[0]?, node_lines[-1]?
return unless first_line && last_line return if first_line.nil? || last_line.nil?
return if first_line.size < column # compiler reports incorrection location
node_lines[0] = first_line.sub(0...column, "") node_lines[0] = first_line.sub(0...column, "")
@ -48,6 +49,8 @@ module Ameba::AST::Util
end_column = end_column - column end_column = end_column - column
last_line = node_lines[0] last_line = node_lines[0]
end end
return if last_line.size < end_column + 1
node_lines[-1] = last_line.sub(end_column + 1...last_line.size, "") node_lines[-1] = last_line.sub(end_column + 1...last_line.size, "")
node_lines node_lines