Sha256: fa5d320640708f85ab925f5ecc310e721c952ed0589ff1a70eb21c883f812900
Contents?: true
Size: 1.65 KB
Versions: 1
Compression:
Stored size: 1.65 KB
Contents
# encoding: utf-8 module RailsBestPractices module Reviews # Review a view file to make sure there is no finder, finder should be moved to controller. # # See the best practice details here http://rails-bestpractices.com/posts/24-move-code-into-controller. # # Implementation: # # Review process: # only check all view files to see if there are finders, then the finders should be moved to controller. class MoveCodeIntoControllerReview < Review interesting_nodes :method_add_arg, :assign interesting_files VIEW_FILES url "http://rails-bestpractices.com/posts/24-move-code-into-controller" FINDERS = %w(find all first last) # check method_add_arg nodes. # # if the receiver of the method_add_arg node is a constant, # and the message of the method_add_arg node is one of the find, all, first and last, # then it is a finder and should be moved to controller. add_callback :start_method_add_arg do |node| add_error "move code into controller" if finder?(node) end # check assign nodes. # # if the receiver of the right value node is a constant, # and the message of the right value node is one of the find, all, first and last, # then it is a finder and should be moved to controller. add_callback :start_assign do |node| add_error "move code into controller", node.file, node.right_value.line if finder?(node.right_value) end private # check if the node is a finder call node. def finder?(node) node.receiver.const? && FINDERS.include?(node.message.to_s) end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rails_best_practices-1.14.0 | lib/rails_best_practices/reviews/move_code_into_controller_review.rb |