Class: RDF::Literal::DateTime
- Inherits:
-
Temporal
- Object
- RDF::Literal
- Temporal
- RDF::Literal::DateTime
- Defined in:
- vendor/bundler/ruby/3.3.0/bundler/gems/rdf-d5b00f1260e9/lib/rdf/model/literal/datetime.rb
Overview
A date/time literal.
Direct Known Subclasses
Constant Summary collapse
- DATATYPE =
RDF::URI("http://www.w3.org/2001/XMLSchema#dateTime")
- GRAMMAR =
%r(\A (#{YEARFRAG} -#{MONTHFRAG} -#{DAYFRAG} T (?: (?: #{HOURFRAG} :#{MINUTEFRAG} :#{SECONDFRAG}) | #{EODFRAG})) (#{TZFRAG})?\z)x.freeze
- FORMAT =
'%Y-%m-%dT%H:%M:%S.%L'.freeze
Constants inherited from Temporal
Temporal::DAYFRAG, Temporal::EODFRAG, Temporal::HOURFRAG, Temporal::MINUTEFRAG, Temporal::MONTHFRAG, Temporal::SECONDFRAG, Temporal::TZFRAG, Temporal::YEARFRAG, Temporal::ZONE_GRAMMAR
Constants inherited from RDF::Literal
FALSE, TRUE, XSD_STRING, ZERO
Constants included from N3::Terminals
N3::Terminals::ANON, N3::Terminals::BASE, N3::Terminals::BLANK_NODE_LABEL, N3::Terminals::DECIMAL, N3::Terminals::DOUBLE, N3::Terminals::ECHAR, N3::Terminals::ESCAPE_CHAR4, N3::Terminals::ESCAPE_CHAR8, N3::Terminals::EXPONENT, N3::Terminals::INTEGER, N3::Terminals::IPLSTART, N3::Terminals::IRIREF, N3::Terminals::IRI_RANGE, N3::Terminals::LANGTAG, N3::Terminals::PERCENT, N3::Terminals::PLX, N3::Terminals::PNAME_LN, N3::Terminals::PNAME_NS, N3::Terminals::PN_CHARS, N3::Terminals::PN_CHARS_BASE, N3::Terminals::PN_CHARS_BODY, N3::Terminals::PN_CHARS_U, N3::Terminals::PN_LOCAL, N3::Terminals::PN_LOCAL_BODY, N3::Terminals::PN_LOCAL_ESC, N3::Terminals::PN_PREFIX, N3::Terminals::PREFIX, N3::Terminals::QUICK_VAR_NAME, N3::Terminals::STRING_LITERAL_LONG_QUOTE, N3::Terminals::STRING_LITERAL_LONG_SINGLE_QUOTE, N3::Terminals::STRING_LITERAL_QUOTE, N3::Terminals::STRING_LITERAL_SINGLE_QUOTE, N3::Terminals::UCHAR, N3::Terminals::U_CHARS1, N3::Terminals::U_CHARS2, N3::Terminals::WS
Constants included from SPARQL::Algebra::Expression
SPARQL::Algebra::Expression::PATTERN_PARENTS
Constants included from Util::Logger
Instance Attribute Summary
Attributes inherited from RDF::Literal
#datatype, #direction, #language
Instance Method Summary collapse
-
#humanize(lang = :en) ⇒ String
Returns a human-readable value for the literal.
-
#initialize(value, datatype: nil, lexical: nil, **options) ⇒ DateTime
constructor
Internally, a
DateTime
is represented using a native::DateTime
.
Methods inherited from Temporal
#+, #-, #<=>, #==, #adjust_to_timezone, #adjust_to_timezone!, #canonicalize!, #day, #hours, #milliseconds?, #minutes, #month, #seconds, #timezone, #timezone?, #to_s, #tz, #valid?, #year
Methods inherited from RDF::Literal
#<=>, #==, #as_datetime, #as_number, #canonicalize!, #compatible?, #comperable_datatype2?, #comperable_datatype?, #datatype?, #direction?, #english?, #eql?, #escape, #hash, #inspect, #language?, #literal?, #method_missing, #object, #plain?, #respond_to_missing?, #simple?, #squish, #squish!, #to_s, #valid?, #valid_extended?, #validate!, #value, #value_hash
Methods included from Term
#<=>, #==, #aggregate?, #as_datetime, #as_number, #compatible?, #eql?, #escape, #evaluate, #ndvars, #optimize, #sameTerm?, #term?, #terms, #to_base, #to_sparql, #to_term, #vars
Methods included from SPARQL::Algebra::Expression
cast, #constant?, #evaluate, extension, extension?, extensions, for, #invalid?, new, #node?, open, #optimize, #optimize!, parse, register_extension, #to_sxp_bin, #valid?, #validate!, #variable?
Methods included from Util::Logger
#log_debug, #log_depth, #log_error, #log_fatal, #log_info, #log_recover, #log_recovering?, #log_statistics, #log_warn, #logger
Methods included from Value
#anonymous?, #canonicalize, #canonicalize!, #constant?, #formula?, #graph?, #inspect, #inspect!, #invalid?, #iri?, #list?, #literal?, #node?, #resource?, #start_with?, #statement?, #term?, #to_ndvar, #to_nquads, #to_ntriples, #to_rdf, #to_term, #type_error, #uri?, #valid?, #validate!, #variable?
Constructor Details
#initialize(value, datatype: nil, lexical: nil, **options) ⇒ DateTime
Internally, a DateTime
is represented using a native ::DateTime
. If initialized from a ::Date
, there is no timezone component, If initialized from a ::DateTime
, the timezone is taken from that native object, otherwise, a timezone (or no timezone) is taken from the string representation having a matching zzzzzz
component.
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
# File 'vendor/bundler/ruby/3.3.0/bundler/gems/rdf-d5b00f1260e9/lib/rdf/model/literal/datetime.rb', line 29 def initialize(value, datatype: nil, lexical: nil, **) @datatype = RDF::URI(datatype || self.class.const_get(:DATATYPE)) @string = lexical || (value if value.is_a?(String)) @object = case when value.is_a?(::DateTime) @zone = value.zone value when value.respond_to?(:to_datetime) @zone = value.to_datetime.zone value.to_datetime else md = value.to_s.match(GRAMMAR) _, _, tz = Array(md) if tz @zone = tz == 'Z' ? '+00:00' : tz else @zone = nil # No timezone end ::DateTime.parse(value.to_s) end rescue ::DateTime.new end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class RDF::Literal
Instance Method Details
#humanize(lang = :en) ⇒ String
Returns a human-readable value for the literal
56 57 58 59 60 61 62 63 |
# File 'vendor/bundler/ruby/3.3.0/bundler/gems/rdf-d5b00f1260e9/lib/rdf/model/literal/datetime.rb', line 56 def humanize(lang = :en) d = object.strftime("%r on %A, %d %B %Y") if timezone? z = @zone == '+00:00' ? "UTC" : @zone d.sub!(" on ", " #{z} on ") end d end |