Sha256: 9d7a1c257288f2eee68c97216aeed30a2666e4c6c3a5a66f51608101bee7a7cc

Contents?: true

Size: 1.02 KB

Versions: 3

Compression:

Stored size: 1.02 KB

Contents

class Array

  # The `arrange` method produces appropriate ranges from the objects in the array.
  #
  # Examples
  #
  #     [1,2,3,6,7,8].arrange  #=> [1..3, 6..8]
  #
  #     [10..15, 16..20, 21, 22].arrange  #=> [10..22]
  #
  # Assumes inclusive ranges (ie. 1..4) and range.first <= range.last.
  #
  # Works with integers, dates and strings. However, all the objects in the array must
  # be of the same class.
  #
  # CREDIT: monocle

  def arrange
		array = uniq.sort_by { |e| Range === e ? e.first : e }
		array.inject([]) do |c, value|
			unless c.empty?
				last = c.last
				last_value    = (Range === last  ? last.last   : last)
				current_value = (Range === value ? value.first : value)
				if (last_value.succ <=> current_value) == -1
					c << value
				else
					first  = (Range === last ? last.first : last)
					second = [Range === last ? last.last : last, Range === value ? value.last : value].max
					c[-1] = [first..second]
					c.flatten!
				end
			else
				c << value
			end
		end
	end

  alias rangify arrange

end

Version data entries

3 entries across 3 versions & 2 rubygems

Version Path
facets-glimmer-3.2.0 lib/core/facets/array/arrange.rb
facets-3.1.0 lib/core/facets/array/arrange.rb
facets-3.0.0 lib/core/facets/array/arrange.rb