Sha256: 024e0419c2524c079d31ed192e5051917790ffa7060b82f20059c47d95dd5bbf

Contents?: true

Size: 1.39 KB

Versions: 3

Compression:

Stored size: 1.39 KB

Contents

# frozen_string_literal: true

module RailsBestPractices
  module Reviews
    # Check ruby 1.8 style hash and suggest to change hash syntax to 1.9.
    #
    # Review process:
    #   check hash nodes in all files,
    #   if the sexp type of hash key nodes is not :@lable,
    #   then the hash is ruby 1.8 style.
    class HashSyntaxReview < Review
      interesting_nodes :hash, :bare_assoc_hash
      interesting_files ALL_FILES

      VALID_SYMBOL_KEY = /\A[@$_A-Za-z]([_\w]*[!_=?\w])?\z/

      # check hash node to see if it is ruby 1.8 style.
      add_callback :start_hash, :start_bare_assoc_hash do |node|
        if !empty_hash?(node) && hash_is_18?(node) && valid_keys?(node)
          add_error 'change Hash Syntax to 1.9'
        end
      end

      protected

        # check if hash node is empty.
      def empty_hash?(node)
        s(:hash, nil) == node || s(:bare_assoc_hash, nil) == node
      end

        # check if hash key/value pairs are ruby 1.8 style.
      def hash_is_18?(node)
        pair_nodes = node.sexp_type == :hash ? node[1][1] : node[1]
        return false if pair_nodes.blank?

        pair_nodes.any? { |pair_node| pair_node[1].sexp_type == :symbol_literal }
      end

        # check if the hash keys are valid to be converted to ruby 1.9
        # syntax.
      def valid_keys?(node)
        node.hash_keys.all? { |key| key =~ VALID_SYMBOL_KEY }
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
rails_best_practices-1.20.0 lib/rails_best_practices/reviews/hash_syntax_review.rb
rails_best_practices-1.19.5 lib/rails_best_practices/reviews/hash_syntax_review.rb
rails_best_practices-1.19.4 lib/rails_best_practices/reviews/hash_syntax_review.rb