class Hash

:nodoc:

def self.hash_traverse(hash, &block)

def self.hash_traverse(hash, &block)
  hash.each do |key, val|
    block.call(key)
    case val
    when Hash
      val.keys.each do |k|
        _hash_traverse(val, &block)
      end
    when Array
      val.each do |item|
        _hash_traverse(item, &block)
      end
    end
  end
  return hash
end

def all_keys # :nodoc:

:nodoc:
def all_keys # :nodoc:
  keys = self.keys
  keys.each do |key|
    if self[key].is_a?(Hash)
      keys << self[key].all_keys.compact.flatten
      next
    end
  end
  keys.flatten
end unless method_defined?(:all_keys)

def except(*items) # :nodoc:

:nodoc:
def except(*items) # :nodoc:
  self.dup.except!(*items)
end unless method_defined?(:except)

def except!(*keys) # :nodoc:

:nodoc:
def except!(*keys) # :nodoc:
  copy = self.dup
  keys.each { |key| copy.delete!(key) }
  copy
end unless method_defined?(:except!)

def has_deep_key?(key)

def has_deep_key?(key)
  self.all_keys.include? key
end unless method_defined?(:has_deep_key?)

def serialize # :nodoc:

:nodoc:
def serialize # :nodoc:
  self.map { |key, val| [key, val].join("=") }.join("&")
end unless method_defined?(:serialize)

def symbolize_keys # :nodoc:

:nodoc:
def symbolize_keys  # :nodoc:
  inject({}) do |hash, (key, value)|
    hash[(key.to_sym rescue key) || key] = value
    hash
  end
end unless method_defined?(:symbolize_keys)

def symbolize_keys! # :nodoc:

:nodoc:
def symbolize_keys! # :nodoc:
  hash = symbolize_keys
  hash.each do |key, val|
    hash[key] = case val
      when Hash
        val.symbolize_keys!
      when Array
        val.map do |item|
          item.is_a?(Hash) ? item.symbolize_keys! : item
        end
      else
        val
      end
  end
  return hash
end unless method_defined?(:symbolize_keys!)