Range Splitter

Splits a range into multiple ranges.

Usage

Splits are made as evenly as possible. The larger ranges are placed at the beginning of the array unless the endianness is changed.

require 'range_splitter'

(1..10).split
#=> [1..5, 6..10]

(1..9).split
#=> [1..5, 6..9]

(1..9).split(:endianness => :little)
#=> [1..4, 5..9]

(1..10).split(:into => 3)
#=> [1..4, 5..7, 8..10]

(1..9).split(:into => 3)
#=> [1..3, 4..6, 7..9]

(-5..5).split(:into => 5)
#=> [-5..-3, -2..-1, 0..1, 2..3, 4..5]

(5..8).split(:into => 3, :endianness => :little)
#=> [5..5, 6..6, 7..8]

(1..3).split(:into => 100)
#=> [1..1, 2..2, 3..3]

(1..1).split
#=> [1..1]

(1..3).split(:into => 1)
#=> [1..3]

(1..3).split(:into => 0)
# ArgumentError: Cannot split 1..3 into 0 ranges.

(1..3).split(:into => -3)
# ArgumentError: Cannot split 1..3 into -3 ranges.

Contribution

Feel free to contribute. No commit is too small.

You should follow me: @cpatuzzo