Class: RDF::Literal::Boolean
- Inherits:
-
RDF::Literal
- Object
- RDF::Literal
- RDF::Literal::Boolean
- Defined in:
- lib/rdf/model/literal/boolean.rb
Overview
A boolean literal.
Constant Summary collapse
- DATATYPE =
XSD.boolean
- GRAMMAR =
/^(true|false|1|0)$/i.freeze
- TRUES =
%w(true 1).freeze
- FALSES =
%w(false 0).freeze
Constants inherited from RDF::Literal
Instance Attribute Summary
Attributes inherited from RDF::Literal
Instance Method Summary collapse
-
#<=>(other) ⇒ Integer
Compares this literal to ‘other` for sorting purposes.
-
#==(other) ⇒ Boolean
Returns ‘true` if this literal is equivalent to `other`.
-
#canonicalize! ⇒ RDF::Literal
Converts this literal into its canonical lexical representation.
-
#false? ⇒ Boolean
Returns ‘true` if this value is `false`.
-
#initialize(value, options = {}) ⇒ Boolean
constructor
A new instance of Boolean.
-
#inspect ⇒ String
Returns a developer-friendly representation of ‘self`.
-
#to_i ⇒ Integer
Returns the value as an integer.
-
#to_s ⇒ String
Returns the value as a string.
-
#true? ⇒ Boolean
Returns ‘true` if this value is `true`.
Methods inherited from RDF::Literal
#anonymous?, #canonicalize, #comperable_datatype?, datatyped_class, #eql?, #has_datatype?, #has_language?, #hash, #invalid?, #literal?, new, #object, #plain?, #valid?, #validate!, #value
Methods included from Term
Methods included from Value
#graph?, #inspect!, #iri?, #literal?, #node?, #resource?, #statement?, #to_ntriples, #to_quad, #to_rdf, #type_error, #uri?, #variable?
Constructor Details
#initialize(value, options = {}) ⇒ Boolean
Returns a new instance of Boolean.
16 17 18 19 20 21 22 23 24 25 26 27 |
# File 'lib/rdf/model/literal/boolean.rb', line 16 def initialize(value, = {}) @datatype = RDF::URI([:datatype] || self.class.const_get(:DATATYPE)) @string = [:lexical] if .has_key?(:lexical) @string ||= value if value.is_a?(String) @object = case when true.equal?(value) then true when false.equal?(value) then false when TRUES.include?(value.to_s.downcase) then true when FALSES.include?(value.to_s.downcase) then false else value end end |
Instance Method Details
#<=>(other) ⇒ Integer
Compares this literal to ‘other` for sorting purposes.
45 46 47 48 49 50 51 52 53 |
# File 'lib/rdf/model/literal/boolean.rb', line 45 def <=>(other) case other when TrueClass, FalseClass to_i <=> (other ? 1 : 0) when RDF::Literal::Boolean to_i <=> other.to_i else super end end |
#==(other) ⇒ Boolean
Returns ‘true` if this literal is equivalent to `other`.
61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/rdf/model/literal/boolean.rb', line 61 def ==(other) # If lexically invalid, use regular literal testing return super unless self.valid? other = Literal::Boolean.new(other) if other.class == TrueClass || other.class == FalseClass case other when Literal::Boolean return super unless other.valid? (cmp = (self <=> other)) ? cmp.zero? : false else super end end |
#canonicalize! ⇒ RDF::Literal
Converts this literal into its canonical lexical representation.
34 35 36 37 |
# File 'lib/rdf/model/literal/boolean.rb', line 34 def canonicalize! @string = (@object ? :true : :false).to_s self end |
#false? ⇒ Boolean
Returns ‘true` if this value is `false`.
105 106 107 |
# File 'lib/rdf/model/literal/boolean.rb', line 105 def false? @object.equal?(false) end |
#inspect ⇒ String
Returns a developer-friendly representation of ‘self`.
113 114 115 116 117 118 119 |
# File 'lib/rdf/model/literal/boolean.rb', line 113 def inspect case when self.equal?(RDF::Literal::TRUE) then 'RDF::Literal::TRUE' when self.equal?(RDF::Literal::FALSE) then 'RDF::Literal::FALSE' else super end end |
#to_i ⇒ Integer
Returns the value as an integer.
89 90 91 |
# File 'lib/rdf/model/literal/boolean.rb', line 89 def to_i @object ? 1 : 0 end |
#to_s ⇒ String
Returns the value as a string.
80 81 82 |
# File 'lib/rdf/model/literal/boolean.rb', line 80 def to_s @string || @object.to_s end |
#true? ⇒ Boolean
Returns ‘true` if this value is `true`.
97 98 99 |
# File 'lib/rdf/model/literal/boolean.rb', line 97 def true? @object.equal?(true) end |