Skip to content

Commit

Permalink
rubocop: preserve comments when ordering uninstall methods
Browse files Browse the repository at this point in the history
  • Loading branch information
razvanazamfirei committed Jan 28, 2024
1 parent 7c540dd commit 9aabe1b
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 10 deletions.
34 changes: 25 additions & 9 deletions Library/Homebrew/rubocops/cask/uninstall_methods_order.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,9 @@ module Cask
# This cop checks for the correct order of methods within the 'uninstall' and 'zap' stanzas.
class UninstallMethodsOrder < Base
extend AutoCorrector
include CaskHelp
include HelperFunctions

MSG = T.let("`%<method>s` method out of order".freeze, String)
MSG = T.let("`%<method>s` method out of order", String)

sig { params(node: AST::SendNode).void }
def on_send(node)
Expand All @@ -23,18 +22,35 @@ def on_send(node)

method_nodes = hash_node.pairs.map(&:key)
expected_order = method_nodes.sort_by { |method| method_order_index(method) }
comments = processed_source.comments

method_nodes.each_with_index do |method, index|
next if method == expected_order[index]

add_offense(method, message: format(MSG, method: method.children.first)) do |corrector|
indentation = " " * (start_column(method) - line_start_column(method))
ordered_sources = expected_order.map do |expected_method|
hash_node.pairs.find { |pair| pair.key == expected_method }.source
report_and_correct_offense(method, hash_node, expected_order, comments)
end
end

sig {
params(method: AST::Node,
hash_node: AST::HashNode,
expected_order: T::Array[AST::Node],
comments: T::Array[Parser::Source::Comment]).void
}
def report_and_correct_offense(method, hash_node, expected_order, comments)
add_offense(method, message: format(MSG, method: method.children.first)) do |corrector|
indentation = " " * (start_column(method) - line_start_column(method))
new_code = expected_order.map do |expected_method|
method_pair = hash_node.pairs.find { |pair| pair.key == expected_method }
source = method_pair.source

# Find and attach a comment on the same line as the method_pair, if any
inline_comment = comments.find do |comment|
comment.location.line == method_pair.loc.line && comment.location.column > method_pair.loc.column
end
new_code = ordered_sources.join(",\n#{indentation}")
corrector.replace(hash_node.source_range, new_code)
end
inline_comment ? "#{source} #{inline_comment.text}" : source
end.join(",\n#{indentation}")
corrector.replace(hash_node.source_range, new_code)
end
end

Expand Down
2 changes: 1 addition & 1 deletion Library/Homebrew/rubocops/rubocop-cask.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@
require_relative "cask/homepage_url_trailing_slash"
require_relative "cask/no_overrides"
require_relative "cask/on_system_conditionals"
require_relative "cask/uninstall_methods_order"
require_relative "cask/stanza_order"
require_relative "cask/stanza_grouping"
require_relative "cask/uninstall_methods_order"
require_relative "cask/url"
require_relative "cask/url_legacy_comma_separators"
require_relative "cask/variables"

0 comments on commit 9aabe1b

Please sign in to comment.