No commit activity in last 3 years
No release in over 3 years
Utility class for ranges of times (time periods). It's like Range, but has additional enumeration capabilities.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.6
~> 0.12.4
~> 5.4.0
~> 10.0

Runtime

>= 3.2.19
 Project Readme

Utility class for ranges of times (time periods). It's like Range, but has additional enumeration capabilities. See examples for the tasty stuff.

Examples

period = TimeRange.new(1.year.ago, Time.now)

Enumerate by days

period.each(:day) { |time| puts time }

Enumerate by weeks

period.each(:week) { |time| puts time }

(also years, months, hours, minutes and seconds)

Enumerate by custom period

period.each(42.seconds) { |time| puts time }

+each+ Returns Enumerator object, so this is also possible (extra yummy):

period.each(:month).map { |time| time.strftime('%B') }

Supports all Enumerable interface: find, select, reject, inject, etc.

Version compatibility

0.3.0: Public repository along with the very first RubyGems gem

0.2.0: The Granulate class has been converted to a class method that returns a hash. Granulate was not easy to use because it returned an instance of 'Granulate'. This prevented clients from iterating through the result.

0.1.0: breaks compatibility with previous versions because it adds hours to the Granulate class. This means that in previous versions Granulate.rest contained time ranges that cannot be separated into days when granulating, but now it just contains ranges that cannot be separated into hours.