class ReeArray::InGroups
def call(array, number, **opts, &block)
def call(array, number, **opts, &block) # size.div number gives minor group size; # size % number gives how many objects need extra accommodation; # each group hold either division or division + 1 items. division = array.size.div(number) modulo = array.size % number # create a new array avoiding dup groups = [] start = 0 number.times do |index| length = division + (modulo > 0 && modulo > index ? 1 : 0) groups << last_group = array.slice(start, length) if opts.has_key?(:fill_with) && modulo > 0 && length == division last_group << opts[:fill_with] end start += length end if block_given? groups.each(&block) else groups end end