class RuboCop::Cop::Layout::EmptyLinesAroundAccessModifier


end
def baz; end
private
def bar; end
class Foo
# good
end
def baz; end
private
def bar; end
class Foo
# bad
@example EnforcedStyle: only_before
end
def baz; end
private
def bar; end
class Foo
# good
end
def baz; end
private
def bar; end
class Foo
# bad
@example EnforcedStyle: around (default)
Access modifiers should be surrounded by blank lines.

def allowed_only_before_style?(node)

def allowed_only_before_style?(node)
  if node.special_modifier?
    return true if processed_source[node.last_line] == 'end'
    return false if next_line_empty?(node.last_line)
  end
  previous_line_empty?(node.first_line)
end

def block_start?(line)

def block_start?(line)
  return false unless @block_line
  line == @block_line + 1
end

def body_end?(line)

def body_end?(line)
  return false unless @class_or_module_def_last_line
  line == @class_or_module_def_last_line - 1
end

def class_def?(line)

def class_def?(line)
  return false unless @class_or_module_def_first_line
  line == @class_or_module_def_first_line + 1
end

def correct_next_line_if_denied_style(corrector, node, line)

def correct_next_line_if_denied_style(corrector, node, line)
  case style
  when :around
    corrector.insert_after(line, "\n") unless next_line_empty?(node.last_line)
  when :only_before
    if next_line_empty?(node.last_line)
      range = next_empty_line_range(node)
      corrector.remove(range)
    end
  end
end

def empty_lines_around?(node)

def empty_lines_around?(node)
  previous_line_empty?(node.first_line) && next_line_empty?(node.last_line)
end

def expected_empty_lines?(node)

def expected_empty_lines?(node)
  case style
  when :around
    return true if empty_lines_around?(node)
  when :only_before
    return true if allowed_only_before_style?(node)
  end
  false
end

def initialize(config = nil, options = nil)

def initialize(config = nil, options = nil)
  super
  @block_line = nil
end

def message(node)

def message(node)
  case style
  when :around
    message_for_around_style(node)
  when :only_before
    message_for_only_before_style(node)
  end
end

def message_for_around_style(node)

def message_for_around_style(node)
  send_line = node.first_line
  if block_start?(send_line) || class_def?(send_line)
    format(MSG_AFTER, modifier: node.loc.selector.source)
  else
    format(MSG_BEFORE_AND_AFTER, modifier: node.loc.selector.source)
  end
end

def message_for_only_before_style(node)

def message_for_only_before_style(node)
  modifier = node.loc.selector.source
  if next_line_empty?(node.last_line)
    format(MSG_AFTER_FOR_ONLY_BEFORE, modifier: modifier)
  else
    format(MSG_BEFORE_FOR_ONLY_BEFORE, modifier: modifier)
  end
end

def next_empty_line_range(node)

def next_empty_line_range(node)
  source_range(processed_source.buffer, node.last_line + 1, 0)
end

def next_line_empty?(last_send_line)

def next_line_empty?(last_send_line)
  next_line = processed_source[last_send_line]
  body_end?(last_send_line) || next_line.blank?
end

def on_block(node)

def on_block(node)
  @block_line = node.source_range.first_line
end

def on_class(node)

def on_class(node)
  @class_or_module_def_first_line = if node.parent_class
                                      node.parent_class.first_line
                                    else
                                      node.source_range.first_line
                                    end
  @class_or_module_def_last_line = node.source_range.last_line
end

def on_module(node)

def on_module(node)
  @class_or_module_def_first_line = node.source_range.first_line
  @class_or_module_def_last_line = node.source_range.last_line
end

def on_sclass(node)

def on_sclass(node)
  @class_or_module_def_first_line = node.identifier.source_range.first_line
  @class_or_module_def_last_line = node.source_range.last_line
end

def on_send(node) # rubocop:disable Metrics/CyclomaticComplexity

rubocop:disable Metrics/CyclomaticComplexity
def on_send(node) # rubocop:disable Metrics/CyclomaticComplexity
  return unless node.bare_access_modifier? &&
                !(node.parent&.block_type? || node.parent&.numblock_type?)
  return if expected_empty_lines?(node)
  message = message(node)
  add_offense(node, message: message) do |corrector|
    line = range_by_whole_lines(node.source_range)
    corrector.insert_before(line, "\n") unless previous_line_empty?(node.first_line)
    correct_next_line_if_denied_style(corrector, node, line)
  end
end

def previous_line_empty?(send_line)

def previous_line_empty?(send_line)
  previous_line = previous_line_ignoring_comments(processed_source, send_line)
  return true unless previous_line
  block_start?(send_line) || class_def?(send_line) || previous_line.blank?
end

def previous_line_ignoring_comments(processed_source, send_line)

def previous_line_ignoring_comments(processed_source, send_line)
  processed_source[0..send_line - 2].reverse.find { |line| !comment_line?(line) }
end