Module: ActiveSupport::CoreExtensions::Time::Zones
Defined Under Namespace
Modules: ClassMethods
Class Method Summary collapse
-
.included(base) ⇒ Object
:nodoc:.
Instance Method Summary collapse
-
#in_time_zone(zone = ::Time.zone) ⇒ Object
Returns the simultaneous time in
Time.zone
.
Class Method Details
.included(base) ⇒ Object
:nodoc:
5 6 7 |
# File 'lib/active_support/core_ext/time/zones.rb', line 5 def self.included(base) #:nodoc: base.extend(ClassMethods) if base == ::Time # i.e., don't include class methods in DateTime end |
Instance Method Details
#in_time_zone(zone = ::Time.zone) ⇒ Object
Returns the simultaneous time in Time.zone
.
Time.zone = 'Hawaii' # => 'Hawaii'
Time.utc(2000).in_time_zone # => Fri, 31 Dec 1999 14:00:00 HST -10:00
This method is similar to Time#localtime, except that it uses Time.zone
as the local zone instead of the operating system’s time zone.
You can also pass in a TimeZone instance or string that identifies a TimeZone as an argument, and the conversion will be based on that zone instead of Time.zone
.
Time.utc(2000).in_time_zone('Alaska') # => Fri, 31 Dec 1999 15:00:00 AKST -09:00
80 81 82 |
# File 'lib/active_support/core_ext/time/zones.rb', line 80 def in_time_zone(zone = ::Time.zone) ActiveSupport::TimeWithZone.new(utc? ? self : getutc, ::Time.__send__(:get_zone, zone)) end |