Sha256: 54ed55cf4e6c81bcb24fe0850262e3f9d522a0660c02f6dfb3e985aa918e013d

Contents?: true

Size: 1.05 KB

Versions: 3

Compression:

Stored size: 1.05 KB

Contents

# encoding: utf-8
module RailsBestPractices
  module Reviews
    # Review a helper file to make sure it is not an empty moduel.
    #
    # See the best practice details here http://rails-bestpractices.com/posts/2011/04/09/remove-empty-helpers/
    #
    # Implementation:
    #
    # Review process:
    #   check all helper files, if the body of module is nil, then the helper file should be removed.
    class RemoveEmptyHelpersReview < Review
      interesting_nodes :module
      interesting_files HELPER_FILES
      url "http://rails-bestpractices.com/posts/2011/04/09/remove-empty-helpers/"

      # check the body of module node, if it is nil, then it should be removed.
      add_callback :start_module do |module_node|
        if "ApplicationHelper" != module_node.module_name.to_s && empty_body?(module_node)
          add_error "remove empty helpers"
        end
      end

      protected

        def empty_body?(module_node)
          s(:bodystmt, s(:stmts_add, s(:stmts_new), s(:void_stmt)), nil, nil, nil) == module_node.body
        end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
rails_best_practices-1.18.1 lib/rails_best_practices/reviews/remove_empty_helpers_review.rb
rails_best_practices-1.18.0 lib/rails_best_practices/reviews/remove_empty_helpers_review.rb
rails_best_practices-1.17.0 lib/rails_best_practices/reviews/remove_empty_helpers_review.rb