Sha256: 7f62e4afa0eac806b086d68a3d5c7429b64baefc67c3bbf35eb703b0e9fcbd3a
Contents?: true
Size: 1.52 KB
Versions: 5
Compression:
Stored size: 1.52 KB
Contents
module RDF; class Literal ## # A date literal. # # @see http://www.w3.org/TR/xmlschema-2/#date # @since 0.2.1 class Date < Literal DATATYPE = XSD.date GRAMMAR = %r(\A-?\d{4}-\d{2}-\d{2}(([\+\-]\d{2}:\d{2})|UTC|Z)?\Z).freeze ## # @param [Date] value # @option options [String] :lexical (nil) def initialize(value, options = {}) @datatype = RDF::URI(options[:datatype] || DATATYPE) @string = options[:lexical] if options.has_key?(:lexical) @string = value if !defined?(@string) && value.is_a?(String) @object = case when value.is_a?(::Date) then value when value.respond_to?(:to_date) then value.to_date # Ruby 1.9+ else ::Date.parse(value.to_s) end end ## # Converts this literal into its canonical lexical representation. # # @return [RDF::Literal] `self` # @see http://www.w3.org/TR/xmlschema-2/#date def canonicalize! @string = @object.strftime('%Y-%m-%d%Z').sub(/\+00:00|UTC/, 'Z') self end ## # Returns `true` if the value adheres to the defined grammar of the # datatype. # # Special case for date and dateTime, for which '0000' is not a valid year # # @return [Boolean] # @since 0.2.1 def valid? !!(value =~ GRAMMAR) && value !~ %r(\A0000) end ## # Returns the value as a string. # # @return [String] def to_s @string || @object.strftime('%Y-%m-%d%Z').sub(/\+00:00|UTC/, 'Z') end end # Date end; end # RDF::Literal
Version data entries
5 entries across 5 versions & 1 rubygems