mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
[ruby/irb] Indent correctly with method calling with receiver
https://github.com/ruby/irb/commit/e7c68e74a0
This commit is contained in:
parent
fc54af8aa1
commit
743c44ee21
2 changed files with 83 additions and 2 deletions
|
@ -424,6 +424,24 @@ class RubyLex
|
|||
indent
|
||||
end
|
||||
|
||||
def is_method_calling?(tokens, index)
|
||||
tk = tokens[index]
|
||||
if tk[3].anybits?(Ripper::EXPR_CMDARG) and tk[1] == :on_ident
|
||||
# The target method call to pass the block with "do".
|
||||
return true
|
||||
elsif tk[3].anybits?(Ripper::EXPR_ARG) and tk[1] == :on_ident
|
||||
non_sp_index = tokens[0..(index - 1)].rindex{ |t| t[1] != :on_sp }
|
||||
if non_sp_index
|
||||
prev_tk = tokens[non_sp_index]
|
||||
if prev_tk[3].anybits?(Ripper::EXPR_DOT) and prev_tk[1] == :on_period
|
||||
# The target method call with receiver to pass the block with "do".
|
||||
return true
|
||||
end
|
||||
end
|
||||
end
|
||||
false
|
||||
end
|
||||
|
||||
def take_corresponding_syntax_to_kw_do(tokens, index)
|
||||
syntax_of_do = nil
|
||||
# Finding a syntax correnponding to "do".
|
||||
|
@ -437,8 +455,7 @@ class RubyLex
|
|||
elsif [:on_ignored_nl, :on_nl, :on_comment].include?(tokens[non_sp_index][1])
|
||||
first_in_fomula = true
|
||||
end
|
||||
if tk[3].anybits?(Ripper::EXPR_CMDARG) and tk[1] == :on_ident
|
||||
# The target method call to pass the block with "do".
|
||||
if is_method_calling?(tokens, i)
|
||||
syntax_of_do = :method_calling
|
||||
break if first_in_fomula
|
||||
elsif tk[1] == :on_kw && %w{while until for}.include?(tk[2])
|
||||
|
|
|
@ -365,6 +365,70 @@ module TestIRB
|
|||
end
|
||||
end
|
||||
|
||||
def test_bracket_corresponding_to_times
|
||||
input_with_correct_indents = [
|
||||
Row.new(%q(3.times { |i|), nil, 2, 1),
|
||||
Row.new(%q( puts i), nil, 2, 1),
|
||||
Row.new(%q(}), 0, 0, 0),
|
||||
]
|
||||
|
||||
lines = []
|
||||
input_with_correct_indents.each do |row|
|
||||
lines << row.content
|
||||
assert_indenting(lines, row.current_line_spaces, false)
|
||||
assert_indenting(lines, row.new_line_spaces, true)
|
||||
assert_nesting_level(lines, row.nesting_level)
|
||||
end
|
||||
end
|
||||
|
||||
def test_do_corresponding_to_times
|
||||
input_with_correct_indents = [
|
||||
Row.new(%q(3.times do |i|), nil, 2, 1),
|
||||
#Row.new(%q( puts i), nil, 2, 1),
|
||||
#Row.new(%q(end), 0, 0, 0),
|
||||
]
|
||||
|
||||
lines = []
|
||||
input_with_correct_indents.each do |row|
|
||||
lines << row.content
|
||||
assert_indenting(lines, row.current_line_spaces, false)
|
||||
assert_indenting(lines, row.new_line_spaces, true)
|
||||
assert_nesting_level(lines, row.nesting_level)
|
||||
end
|
||||
end
|
||||
|
||||
def test_bracket_corresponding_to_loop
|
||||
input_with_correct_indents = [
|
||||
Row.new(%q(loop {), nil, 2, 1),
|
||||
Row.new(%q( 3), nil, 2, 1),
|
||||
Row.new(%q(}), 0, 0, 0),
|
||||
]
|
||||
|
||||
lines = []
|
||||
input_with_correct_indents.each do |row|
|
||||
lines << row.content
|
||||
assert_indenting(lines, row.current_line_spaces, false)
|
||||
assert_indenting(lines, row.new_line_spaces, true)
|
||||
assert_nesting_level(lines, row.nesting_level)
|
||||
end
|
||||
end
|
||||
|
||||
def test_do_corresponding_to_loop
|
||||
input_with_correct_indents = [
|
||||
Row.new(%q(loop do), nil, 2, 1),
|
||||
Row.new(%q( 3), nil, 2, 1),
|
||||
Row.new(%q(end), 0, 0, 0),
|
||||
]
|
||||
|
||||
lines = []
|
||||
input_with_correct_indents.each do |row|
|
||||
lines << row.content
|
||||
assert_indenting(lines, row.current_line_spaces, false)
|
||||
assert_indenting(lines, row.new_line_spaces, true)
|
||||
assert_nesting_level(lines, row.nesting_level)
|
||||
end
|
||||
end
|
||||
|
||||
def test_heredoc_with_indent
|
||||
input_with_correct_indents = [
|
||||
Row.new(%q(<<~Q), nil, 0, 0),
|
||||
|
|
Loading…
Reference in a new issue