module RuboCop::Cop::Style::ConditionalAssignmentHelper
def assignment_rhs_exist?(node)
def assignment_rhs_exist?(node) parent = node.parent return true unless parent !(parent.mlhs_type? || parent.resbody_type?) end
def end_with_eq?(sym)
def end_with_eq?(sym) sym.to_s.end_with?(EQUAL) end
def expand_elses(branch)
but the last `node` an `elsif` branch and consider the last `node`
to recursively iterate over all `else` branches and consider all
`elsif` branches show up in the `node` as an `else`. We need
def expand_elses(branch) elsif_branches = expand_elsif(branch) else_branch = elsif_branches.any? ? elsif_branches.pop : branch [elsif_branches, else_branch] end
def expand_elsif(node, elsif_branches = [])
def expand_elsif(node, elsif_branches = []) return [] if node.nil? || !node.if_type? || !node.elsif? elsif_branches << node.if_branch else_branch = node.else_branch if else_branch&.if_type? && else_branch&.elsif? expand_elsif(else_branch, elsif_branches) else elsif_branches << else_branch end end
def expand_when_branches(when_branches)
`when` nodes contain the entire branch including the condition.
def expand_when_branches(when_branches) when_branches.map(&:body) end
def indent(cop, source)
def indent(cop, source) conf = cop.config.for_cop(END_ALIGNMENT) if conf[ALIGN_WITH] == KEYWORD ' ' * source.length else '' end end
def lhs(node)
def lhs(node) case node.type when :send lhs_for_send(node) when :op_asgn "#{node.children[0].source} #{node.children[1]}= " when :and_asgn, :or_asgn "#{node.children[0].source} #{node.loc.operator.source} " when :casgn lhs_for_casgn(node) when *ConditionalAssignment::VARIABLE_ASSIGNMENT_TYPES "#{node.children[0]} = " else node.source end end
def lhs_for_casgn(node)
def lhs_for_casgn(node) namespace = node.children[0] if namespace.nil? || namespace.cbase_type? "#{namespace&.source}#{node.children[1]} = " else "#{namespace.source}::#{node.children[1]} = " end end
def lhs_for_send(node)
def lhs_for_send(node) receiver = node.receiver ? node.receiver.source : '' if node.method?(:[]=) indices = node.arguments[0...-1].map(&:source).join(', ') "#{receiver}[#{indices}] = " elsif node.setter_method? "#{receiver}.#{node.method_name[0...-1]} = " else "#{receiver} #{node.method_name} " end end
def setter_method?(method_name)
def setter_method?(method_name) method_name.to_s.end_with?(EQUAL) && !%i[!= == === >= <=].include?(method_name) end
def tail(branch)
def tail(branch) branch.begin_type? ? Array(branch).last : branch end