Class: Puppet::Pops::Time::Timestamp
- Defined in:
- lib/puppet/pops/time/timestamp.rb
Constant Summary collapse
- DEFAULT_FORMATS_WO_TZ =
['%FT%T.%N', '%FT%T', '%F %T.%N', '%F %T', '%F']
- DEFAULT_FORMATS =
['%FT%T.%N %Z', '%FT%T %Z', '%F %T.%N %Z', '%F %T %Z', '%F %Z'] + DEFAULT_FORMATS_WO_TZ
- CURRENT_TIMEZONE =
'current'
- KEY_TIMEZONE =
'timezone'
Constants included from LabelProvider
LabelProvider::A, LabelProvider::AN, LabelProvider::SKIPPED_CHARACTERS, LabelProvider::VOWELS
Instance Attribute Summary
Attributes inherited from TimeData
Class Method Summary collapse
-
.convert_timezone(tz) ⇒ String
private
Converts a timezone that strptime can parse using ‘%z’ into ‘-HH:MM’ or ‘+HH:MM’.
-
.format_time(format, time, timezone) ⇒ Object
Formats a ruby Time object using the given timezone.
- .from_hash(args_hash) ⇒ Object
- .from_time(t) ⇒ Object
- .now ⇒ Object
- .parse(str, format = :default, timezone = nil) ⇒ Object
-
.utc_offset(timezone) ⇒ Integer
private
Returns the zone offset from utc for the given ‘timezone`.
Instance Method Summary collapse
- #+(o) ⇒ Object
- #-(o) ⇒ Object
- #format(format, timezone = nil) ⇒ Object
- #to_s ⇒ Object
- #to_time ⇒ Object
Methods inherited from TimeData
#<=>, #initialize, #label, #to_c, #to_f, #to_i, #to_int, #to_r
Methods included from LabelProvider
#a_an, #a_an_uc, #article, #combine_strings, #label, #plural_s, #the, #the_uc
Constructor Details
This class inherits a constructor from Puppet::Pops::Time::TimeData
Class Method Details
.convert_timezone(tz) ⇒ String
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Converts a timezone that strptime can parse using ‘%z’ into ‘-HH:MM’ or ‘+HH:MM’
16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/puppet/pops/time/timestamp.rb', line 16 def self.convert_timezone(tz) if tz =~ /\A[+-]\d\d:\d\d\z/ tz else offset = utc_offset(tz) / 60 if offset < 0 offset = offset.abs sprintf('-%2.2d:%2.2d', offset / 60, offset % 60) else sprintf('+%2.2d:%2.2d', offset / 60, offset % 60) end end end |
.format_time(format, time, timezone) ⇒ Object
Formats a ruby Time object using the given timezone
47 48 49 50 51 52 |
# File 'lib/puppet/pops/time/timestamp.rb', line 47 def self.format_time(format, time, timezone) unless timezone.nil? || timezone.empty? time = time.localtime(convert_timezone(timezone)) end time.strftime(format) end |
.from_hash(args_hash) ⇒ Object
62 63 64 |
# File 'lib/puppet/pops/time/timestamp.rb', line 62 def self.from_hash(args_hash) parse(args_hash[KEY_STRING], args_hash[KEY_FORMAT], args_hash[KEY_TIMEZONE]) end |
.from_time(t) ⇒ Object
58 59 60 |
# File 'lib/puppet/pops/time/timestamp.rb', line 58 def self.from_time(t) new(t.tv_sec * NSECS_PER_SEC + t.tv_nsec) end |
.now ⇒ Object
54 55 56 |
# File 'lib/puppet/pops/time/timestamp.rb', line 54 def self.now from_time(::Time.now) end |
.parse(str, format = :default, timezone = nil) ⇒ Object
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 |
# File 'lib/puppet/pops/time/timestamp.rb', line 66 def self.parse(str, format = :default, timezone = nil) has_timezone = !(timezone.nil? || timezone.empty? || timezone == :default) if format.nil? || format == :default format = has_timezone ? DEFAULT_FORMATS_WO_TZ : DEFAULT_FORMATS end parsed = nil if format.is_a?(Array) format.each do |fmt| parsed = DateTime._strptime(str, fmt) next if parsed.nil? if parsed.include?(:leftover) || (has_timezone && parsed.include?(:zone)) parsed = nil next end break end if parsed.nil? raise ArgumentError, _( "Unable to parse '%{str}' using any of the formats %{formats}") % { str: str, formats: format.join(', ') } end else parsed = DateTime._strptime(str, format) if parsed.nil? || parsed.include?(:leftover) raise ArgumentError, _("Unable to parse '%{str}' using format '%{format}'") % { str: str, format: format } end if has_timezone && parsed.include?(:zone) raise ArgumentError, _( 'Using a Timezone designator in format specification is mutually exclusive to providing an explicit timezone argument') end end unless has_timezone timezone = parsed[:zone] has_timezone = !timezone.nil? end fraction = parsed[:sec_fraction] # Convert msec rational found in _strptime hash to usec fraction = fraction * 1000000 unless fraction.nil? # Create the Time instance and adjust for timezone parsed_time = ::Time.utc(parsed[:year], parsed[:mon], parsed[:mday], parsed[:hour], parsed[:min], parsed[:sec], fraction) parsed_time -= utc_offset(timezone) if has_timezone # Convert to Timestamp from_time(parsed_time) end |
.utc_offset(timezone) ⇒ Integer
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns the zone offset from utc for the given ‘timezone`
35 36 37 38 39 40 41 42 43 44 |
# File 'lib/puppet/pops/time/timestamp.rb', line 35 def self.utc_offset(timezone) if CURRENT_TIMEZONE.casecmp(timezone) == 0 ::Time.now.utc_offset else hash = DateTime._strptime(timezone, '%z') offset = hash.nil? ? nil : hash[:offset] raise ArgumentError, _("Illegal timezone '%{timezone}'") % { timezone: timezone } if offset.nil? offset end end |
Instance Method Details
#+(o) ⇒ Object
122 123 124 125 126 127 128 129 130 131 |
# File 'lib/puppet/pops/time/timestamp.rb', line 122 def +(o) case o when Timespan Timestamp.new(@nsecs + o.nsecs) when Integer, Float Timestamp.new(@nsecs + (o * NSECS_PER_SEC).to_i) else raise ArgumentError, _("%{klass} cannot be added to a Timestamp") % { klass: a_an_uc(o) } end end |
#-(o) ⇒ Object
133 134 135 136 137 138 139 140 141 142 143 144 145 146 |
# File 'lib/puppet/pops/time/timestamp.rb', line 133 def -(o) case o when Timestamp # Diff between two timestamps is a timespan Timespan.new(@nsecs - o.nsecs) when Timespan Timestamp.new(@nsecs - o.nsecs) when Integer, Float # Subtract seconds Timestamp.new(@nsecs - (o * NSECS_PER_SEC).to_i) else raise ArgumentError, _("%{klass} cannot be subtracted from a Timestamp") % { klass: a_an_uc(o) } end end |
#format(format, timezone = nil) ⇒ Object
148 149 150 |
# File 'lib/puppet/pops/time/timestamp.rb', line 148 def format(format, timezone = nil) self.class.format_time(format, to_time, timezone) end |
#to_s ⇒ Object
152 153 154 |
# File 'lib/puppet/pops/time/timestamp.rb', line 152 def to_s format(DEFAULT_FORMATS[0]) end |
#to_time ⇒ Object
156 157 158 |
# File 'lib/puppet/pops/time/timestamp.rb', line 156 def to_time ::Time.at(to_r).utc end |