Sha256: 6f337830654029f37b7fa931d7319a246f9a0d45c0d4e3292edac228e82837f0

Contents?: true

Size: 1.03 KB

Versions: 10

Compression:

Stored size: 1.03 KB

Contents

module Enumerable

  # Returns an array of elements for the elements that occur n times.
  # Or according to the results of a given block.
  #
  #   [1,1,2,3,3,4,5,5].occur(1)             #=> [2,4]
  #   [1,1,2,3,3,4,5,5].occur(2)             #=> [1,3,5]
  #   [1,1,2,3,3,4,5,5].occur(3)             #=> []
  #
  #   [1,2,2,3,3,3].occur(1..1)              #=> [1]
  #   [1,2,2,3,3,3].occur(2..3)              #=> [2,3]
  #
  #   [1,1,2,3,3,4,5,5].occur { |n| n == 1 } #=> [2,4]
  #   [1,1,2,3,3,4,5,5].occur { |n| n > 1 }  #=> [1,3,5]
  #
  def occur(n=nil) #:yield:
    result = Hash.new { |hash, key| hash[key] = Array.new }
    self.each do |item|
      key = item
      result[key] << item
    end
    if block_given?
      result.reject! { |key, values| ! yield(values.size) }
    else
      raise ArgumentError unless n
      if Range === n
        result.reject! { |key, values| ! n.include?(values.size) }
      else
        result.reject! { |key, values| values.size != n }
      end
    end
    return result.values.flatten.uniq
  end

end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
facets-2.8.4 lib/core/facets/enumerable/occur.rb
facets-2.8.3 lib/core/facets/enumerable/occur.rb
facets-2.8.2 lib/core/facets/enumerable/occur.rb
facets-2.8.1 lib/core/facets/enumerable/occur.rb
facets-2.8.0 lib/core/facets/enumerable/occur.rb
facets-2.7.0 lib/core/facets/enumerable/occur.rb
facets-2.6.0 lib/core/facets/enumerable/occur.rb
facets-2.5.0 lib/core/facets/enumerable/occur.rb
facets-2.5.1 lib/core/facets/enumerable/occur.rb
facets-2.5.2 lib/core/facets/enumerable/occur.rb