Module InactiveSupport::CoreExtensions::Numeric::Time
In: lib/inactive_support/core_ext/numeric/time.rb

Enables the use of time calculations and declarations, like 45.minutes + 2.hours + 4.years.

These methods use Time#advance for precise date calculations when using from_now, ago, etc. as well as adding or subtracting their results from a Time object. For example:

  # equivalent to Time.now.advance(:months => 1)
  1.month.from_now

  # equivalent to Time.now.advance(:years => 2)
  2.years.from_now

  # equivalent to Time.now.advance(:months => 4, :years => 5)
  (4.months + 5.years).from_now

While these methods provide precise calculation when used as in the examples above, care should be taken to note that this is not true if the result of `months’, `years’, etc is converted before use:

  # equivalent to 30.days.to_i.from_now
  1.month.to_i.from_now

  # equivalent to 365.25.days.to_f.from_now
  1.year.to_f.from_now

In such cases, Ruby‘s core Date and Time should be used for precision date and time arithmetic

Methods

ago   day   days   fortnight   fortnights   from_now   hour   hours   minute   minutes   month   months   second   seconds   since   until   week   weeks   year   years  

Public Instance methods

Reads best without arguments: 10.minutes.ago

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 74
        def ago(time = ::Time.now)
          time - self
        end
day()

Alias for days

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 48
        def days
          InactiveSupport::Duration.new(self * 24.hours, [[:days, self]])
        end
fortnight()

Alias for fortnights

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 58
        def fortnights
          InactiveSupport::Duration.new(self * 2.weeks, [[:days, self * 14]])
        end
from_now(time = ::Time.now)

Alias for since

hour()

Alias for hours

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 43
        def hours
          InactiveSupport::Duration.new(self * 3600, [[:seconds, self * 3600]])
        end
minute()

Alias for minutes

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 38
        def minutes
          InactiveSupport::Duration.new(self * 60, [[:seconds, self * 60]])
        end
month()

Alias for months

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 63
        def months
          InactiveSupport::Duration.new(self * 30.days, [[:months, self]])
        end
second()

Alias for seconds

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 33
        def seconds
          InactiveSupport::Duration.new(self, [[:seconds, self]])
        end

Reads best with argument: 10.minutes.since(time)

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 82
        def since(time = ::Time.now)
          time + self
        end
until(time = ::Time.now)

Alias for ago

week()

Alias for weeks

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 53
        def weeks
          InactiveSupport::Duration.new(self * 7.days, [[:days, self * 7]])
        end
year()

Alias for years

[Source]

# File lib/inactive_support/core_ext/numeric/time.rb, line 68
        def years
          InactiveSupport::Duration.new(self * 365.25.days, [[:years, self]])
        end

[Validate]