Sha256: bf80c6072c6dbc7a8e3b023419ae0a5014b345cbb5e2c7694c8abb3f72485c23
Contents?: true
Size: 1.28 KB
Versions: 30
Compression:
Stored size: 1.28 KB
Contents
# frozen_string_literal: true unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED require 'json' end class Time # See #as_json. def self.json_create(object) if usec = object.delete('u') # used to be tv_usec -> tv_nsec object['n'] = usec * 1000 end at(object['s'], Rational(object['n'], 1000)) end # Methods <tt>Time#as_json</tt> and +Time.json_create+ may be used # to serialize and deserialize a \Time object; # see Marshal[https://docs.ruby-lang.org/en/master/Marshal.html]. # # \Method <tt>Time#as_json</tt> serializes +self+, # returning a 2-element hash representing +self+: # # require 'json/add/time' # x = Time.now.as_json # # => {"json_class"=>"Time", "s"=>1700931656, "n"=>472846644} # # \Method +JSON.create+ deserializes such a hash, returning a \Time object: # # Time.json_create(x) # # => 2023-11-25 11:00:56.472846644 -0600 # def as_json(*) { JSON.create_id => self.class.name, 's' => tv_sec, 'n' => tv_nsec, } end # Returns a JSON string representing +self+: # # require 'json/add/time' # puts Time.now.to_json # # Output: # # {"json_class":"Time","s":1700931678,"n":980650786} # def to_json(*args) as_json.to_json(*args) end end
Version data entries
30 entries across 30 versions & 5 rubygems