Sha256: bc400dfd08543428cdb30177d59784c1c3de41f0bd701e54373ba370bcbc7a39

Contents?: true

Size: 1.59 KB

Versions: 10

Compression:

Stored size: 1.59 KB

Contents

# encoding: utf-8
require 'rails_best_practices/reviews/review'

module RailsBestPractices
  module Reviews
    # Review a view file to make sure using simplified syntax for render.
    #
    # See the best practice details here http://rails-bestpractices.com/posts/61-simplify-render-in-views.
    #
    # Implementation:
    #
    # Review process:
    #   check all render method commands in view files,
    #   if there is a key 'partial' in the argument, then they should be replaced by simplified syntax.
    class SimplifyRenderInViewsReview < Review
      interesting_nodes :command
      interesting_files VIEW_FILES
      url "http://rails-bestpractices.com/posts/61-simplify-render-in-views"

      VALID_KEYS = %w(object collection locals)

      # check command node in view file,
      # if its message is render and the arguments contain a key partial,
      # then it should be replaced by simplified syntax.
      add_callback :start_command do |node|
        if "render" == node.message.to_s
          hash_node =  node.arguments.all.first
          if hash_node && :bare_assoc_hash == hash_node.sexp_type &&
              include_partial?(hash_node) && valid_hash?(hash_node)
            add_error 'simplify render in views'
          end
        end
      end

      protected
        def include_partial?(hash_node)
          hash_node.hash_keys.include?("partial") && !hash_node.hash_value("partial").to_s.include?('/')
        end

        def valid_hash?(hash_node)
          keys = hash_node.hash_keys
          keys.delete("partial")
          (keys - VALID_KEYS).empty?
        end
    end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
rails_best_practices-1.13.8 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.5 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.4 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.3 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.2 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.1 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.13.0 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.12.0 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.11.1 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb
rails_best_practices-1.11.0 lib/rails_best_practices/reviews/simplify_render_in_views_review.rb