Class: RDF::Statement
- Inherits:
- 
      Object
      
        - Object
- RDF::Statement
 
- Includes:
- Resource
- Defined in:
- lib/rdf/model/statement.rb
Overview
An RDF statement.
Direct Known Subclasses
Instance Attribute Summary collapse
- #graph_name ⇒ RDF::Resource
- #id ⇒ Object
- #object ⇒ RDF::Term
- #options ⇒ Hash{Symbol => Object}
- #predicate ⇒ RDF::URI
- #subject ⇒ RDF::Resource
Instance Method Summary collapse
- 
  
    
      #==(other)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Checks statement equality as a triple. 
- 
  
    
      #===(other)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Checks statement equality with patterns. 
- #[](index) ⇒ RDF::Term
- #[]=(index, value) ⇒ RDF::Term
- #asserted? ⇒ Boolean
- 
  
    
      #canonicalize  ⇒ RDF::Statement 
    
    
  
  
  
  
  
  
  
  
  
    Returns a version of the statement with each position in canonical form. 
- 
  
    
      #canonicalize!  ⇒ RDF::Statement 
    
    
  
  
  
  
  
  
  
  
  
    Canonicalizes each unfrozen term in the statement. 
- 
  
    
      #complete?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Determines if the statement is complete, vs. 
- 
  
    
      #dup  ⇒ RDF::Statement 
    
    
  
  
  
  
  
  
  
  
  
    New statement with duplicated components (other than blank nodes). 
- 
  
    
      #embedded?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Returns trueif any element of the statement is, itself, a statement.
- 
  
    
      #eql?(other)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Checks statement equality as a quad. 
- #graph?(*args) ⇒ Object (also: #name?, #has_graph?, #has_name?)
- 
  
    
      #hash  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Generates a Integer hash value as a quad. 
- 
  
    
      #incomplete?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Determines if the statement is incomplete, vs. 
- #inferred? ⇒ Boolean
- 
  
    
      #initialize(subject = nil, predicate = nil, object = nil, options = {})  ⇒ Statement 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of Statement. 
- #invalid? ⇒ Boolean
- 
  
    
      #node?  ⇒ Boolean 
    
    
      (also: #has_blank_nodes?)
    
  
  
  
  
  
  
  
  
  
    Returns trueif any resource of this statement is a blank node or has an embedded statement including a blank node.
- #object? ⇒ Boolean (also: #has_object?)
- #predicate? ⇒ Boolean (also: #has_predicate?)
- 
  
    
      #reified(subject: nil, id: nil, graph_name: nil)  ⇒ RDF::Graph 
    
    
  
  
  
  
  
  
  
  
  
    Returns a graph containing this statement in reified form. 
- #statement?(*args) ⇒ Object
- #subject? ⇒ Boolean (also: #has_subject?)
- 
  
    
      #terms  ⇒ Array(RDF::Term) 
    
    
  
  
  
  
  
  
  
  
  
    Returns an array of all the non-nil non-statement terms. 
- 
  
    
      #to_h(subject_key = :subject, predicate_key = :predicate, object_key = :object, graph_key = :graph_name)  ⇒ Hash{Symbol => RDF::Term} 
    
    
  
  
  
  
  
  
  
  
  
    Returns the terms of this statement as a Hash.
- #to_quad ⇒ Array(RDF::Term)
- 
  
    
      #to_s  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    Returns a string representation of this statement. 
- #to_triple ⇒ Array(RDF::Term) (also: #to_a)
- #tripleTerm? ⇒ Boolean
- #valid? ⇒ Boolean
- 
  
    
      #variable?(*args)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    URI, Node or Literal. 
Methods included from Resource
Methods included from Term
#<=>, #compatible?, #escape, #term?, #to_base, #to_term
Methods included from Value
#anonymous?, #constant?, #inspect, #inspect!, #iri?, #list?, #literal?, #resource?, #start_with?, #term?, #to_nquads, #to_ntriples, #to_rdf, #to_term, #type_error, #uri?, #validate!
Constructor Details
#initialize(**options) ⇒ RDF::Statement #initialize(subject, predicate, object, **options) ⇒ RDF::Statement
Returns a new instance of Statement.
| 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | # File 'lib/rdf/model/statement.rb', line 89 def initialize(subject = nil, predicate = nil, object = nil, = {}) if subject.is_a?(Hash) @options = Hash[subject] # faster subject.dup @subject = @options.delete(:subject) @predicate = @options.delete(:predicate) @object = @options.delete(:object) else @options = !.empty? ? Hash[] : {} @subject = subject @predicate = predicate @object = object end @id = @options.delete(:id) if @options.key?(:id) @graph_name = @options.delete(:graph_name) initialize! end | 
Instance Attribute Details
#graph_name ⇒ RDF::Resource
| 49 50 51 | # File 'lib/rdf/model/statement.rb', line 49 def graph_name @graph_name end | 
#id ⇒ Object
| 46 47 48 | # File 'lib/rdf/model/statement.rb', line 46 def id @id end | 
#options ⇒ Hash{Symbol => Object}
| 61 62 63 | # File 'lib/rdf/model/statement.rb', line 61 def @options end | 
#predicate ⇒ RDF::URI
| 55 56 57 | # File 'lib/rdf/model/statement.rb', line 55 def predicate @predicate end | 
#subject ⇒ RDF::Resource
| 52 53 54 | # File 'lib/rdf/model/statement.rb', line 52 def subject @subject end | 
Instance Method Details
#==(other) ⇒ Boolean
Checks statement equality as a triple.
| 326 327 328 329 | # File 'lib/rdf/model/statement.rb', line 326 def ==(other) to_a == Array(other) && !(other.is_a?(RDF::Value) && other.list?) end | 
#===(other) ⇒ Boolean
Checks statement equality with patterns.
Uses #eql? to compare each of #subject, #predicate, #object, and #graph_name to those of other. Any statement part which is not present in self is ignored.
| 358 359 360 361 362 363 364 | # File 'lib/rdf/model/statement.rb', line 358 def ===(other) return false if object? && !object.eql?(other.object) return false if predicate? && !predicate.eql?(other.predicate) return false if subject? && !subject.eql?(other.subject) return false if graph? && !graph_name.eql?(other.graph_name) return true end | 
#[](index) ⇒ RDF::Term
| 369 370 371 372 373 374 375 376 377 | # File 'lib/rdf/model/statement.rb', line 369 def [](index) case index when 0 then self.subject when 1 then self.predicate when 2 then self.object when 3 then self.graph_name else nil end end | 
#[]=(index, value) ⇒ RDF::Term
| 383 384 385 386 387 388 389 390 391 | # File 'lib/rdf/model/statement.rb', line 383 def []=(index, value) case index when 0 then self.subject = value when 1 then self.predicate = value when 2 then self.object = value when 3 then self.graph_name = value else nil end end | 
#asserted? ⇒ Boolean
| 208 209 210 | # File 'lib/rdf/model/statement.rb', line 208 def asserted? ! end | 
#canonicalize ⇒ RDF::Statement
Returns a version of the statement with each position in canonical form
| 434 435 436 437 438 | # File 'lib/rdf/model/statement.rb', line 434 def canonicalize self.dup.canonicalize! rescue ArgumentError nil end | 
#canonicalize! ⇒ RDF::Statement
Canonicalizes each unfrozen term in the statement.
| 419 420 421 422 423 424 425 426 427 | # File 'lib/rdf/model/statement.rb', line 419 def canonicalize! self.subject.canonicalize! if subject? && !self.subject.frozen? self.predicate.canonicalize! if predicate? && !self.predicate.frozen? self.object.canonicalize! if object? && !self.object.frozen? self.graph_name.canonicalize! if graph? && !self.graph_name.frozen? self.validate! @hash = nil self end | 
#complete? ⇒ Boolean
Determines if the statement is complete, vs. invalid. A complete statement is one in which none of subject, predicate, or object, are nil.
| 238 239 240 | # File 'lib/rdf/model/statement.rb', line 238 def complete? !incomplete? end | 
#dup ⇒ RDF::Statement
New statement with duplicated components (other than blank nodes)
| 443 444 445 446 447 448 449 450 | # File 'lib/rdf/model/statement.rb', line 443 def dup = Hash[@options] [:subject] = subject.is_a?(RDF::Node) ? subject : subject.dup [:predicate] = predicate.dup [:object] = object.is_a?(RDF::Node) ? object : object.dup [:graph_name] = graph_name.is_a?(RDF::Node) ? graph_name : graph_name.dup if graph_name RDF::Statement.new() end | 
#embedded? ⇒ Boolean
Returns true if any element of the statement is, itself, a statement.
Note: Nomenclature is evolving, alternatives could include #complex? and #nested?
| 187 188 189 | # File 'lib/rdf/model/statement.rb', line 187 def object && object.statement? end | 
#eql?(other) ⇒ Boolean
Checks statement equality as a quad.
| 306 307 308 | # File 'lib/rdf/model/statement.rb', line 306 def eql?(other) other.is_a?(Statement) && self.to_a.eql?(other.to_a) && (self.graph_name || false) == (other.graph_name || false) end | 
#graph? ⇒ Boolean #graph?(name) ⇒ Boolean Also known as: name?, has_graph?, has_name?
| 253 254 255 256 257 258 259 | # File 'lib/rdf/model/statement.rb', line 253 def graph?(*args) case args.length when 0 then !!graph_name when 1 then graph_name == args.first else raise ArgumentError("wrong number of arguments (given #{args.length}, expected 0 or 1)") end end | 
#hash ⇒ Object
Generates a Integer hash value as a quad.
| 312 313 314 | # File 'lib/rdf/model/statement.rb', line 312 def hash @hash ||= to_quad.hash end | 
#incomplete? ⇒ Boolean
Determines if the statement is incomplete, vs. invalid. An incomplete statement is one in which any of subject, predicate, or object, are nil.
| 229 230 231 | # File 'lib/rdf/model/statement.rb', line 229 def incomplete? to_triple.any?(&:nil?) end | 
#inferred? ⇒ Boolean
| 220 221 222 | # File 'lib/rdf/model/statement.rb', line 220 def inferred? !!@options[:inferred] end | 
#invalid? ⇒ Boolean
| 193 194 195 | # File 'lib/rdf/model/statement.rb', line 193 def invalid? !valid? end | 
#node? ⇒ Boolean Also known as: has_blank_nodes?
Returns true if any resource of this statement is a blank node or has an embedded statement including a blank node.
| 291 292 293 | # File 'lib/rdf/model/statement.rb', line 291 def node? to_quad.compact.any?(&:node?) end | 
#object? ⇒ Boolean Also known as: has_object?
| 280 281 282 | # File 'lib/rdf/model/statement.rb', line 280 def object? !!object end | 
#predicate? ⇒ Boolean Also known as: has_predicate?
| 273 274 275 | # File 'lib/rdf/model/statement.rb', line 273 def predicate? !!predicate end | 
#reified(subject: nil, id: nil, graph_name: nil) ⇒ RDF::Graph
Returns a graph containing this statement in reified form.
| 490 491 492 493 494 495 496 497 498 | # File 'lib/rdf/model/statement.rb', line 490 def reified(subject: nil, id: nil, graph_name: nil) RDF::Graph.new(graph_name: graph_name) do |graph| subject = subject || RDF::Node.new(id) graph << [subject, RDF.type, RDF[:Statement]] graph << [subject, RDF.subject, self.subject] graph << [subject, RDF.predicate, self.predicate] graph << [subject, RDF.object, self.object] end end | 
#statement? ⇒ Boolean #statement?(statement) ⇒ Boolean
| 150 151 152 153 154 155 156 | # File 'lib/rdf/model/statement.rb', line 150 def statement?(*args) case args.length when 0 then true when 1 then self == args.first || subject.statement?(*args) || object.statement?(*args) else raise ArgumentError("wrong number of arguments (given #{args.length}, expected 0 or 1)") end end | 
#subject? ⇒ Boolean Also known as: has_subject?
| 266 267 268 | # File 'lib/rdf/model/statement.rb', line 266 def subject? !!subject end | 
#terms ⇒ Array(RDF::Term)
Returns an array of all the non-nil non-statement terms.
| 409 410 411 | # File 'lib/rdf/model/statement.rb', line 409 def terms to_quad.map {|t| t.respond_to?(:terms) ? t.terms : t}.flatten.compact end | 
#to_h(subject_key = :subject, predicate_key = :predicate, object_key = :object, graph_key = :graph_name) ⇒ Hash{Symbol => RDF::Term}
Returns the terms of this statement as a Hash.
| 459 460 461 | # File 'lib/rdf/model/statement.rb', line 459 def to_h(subject_key = :subject, predicate_key = :predicate, object_key = :object, graph_key = :graph_name) {subject_key => subject, predicate_key => predicate, object_key => object, graph_key => graph_name} end | 
#to_quad ⇒ Array(RDF::Term)
| 395 396 397 | # File 'lib/rdf/model/statement.rb', line 395 def to_quad [subject, predicate, object, graph_name] end | 
#to_s ⇒ String
Returns a string representation of this statement.
| 467 468 469 470 471 472 473 474 475 476 477 | # File 'lib/rdf/model/statement.rb', line 467 def to_s (graph_name ? to_quad : to_triple).map do |term| if term.is_a?(Statement) "<<(#{term.to_s[0..-3]})>>" elsif term.respond_to?(:to_base) term.to_base else term.inspect end end.join(" ") + " ." end | 
#to_triple ⇒ Array(RDF::Term) Also known as: to_a
| 401 402 403 | # File 'lib/rdf/model/statement.rb', line 401 def to_triple [subject, predicate, object] end | 
#tripleTerm? ⇒ Boolean
| 214 215 216 | # File 'lib/rdf/model/statement.rb', line 214 def tripleTerm? !!@options[:tripleTerm] end | 
#valid? ⇒ Boolean
| 199 200 201 202 203 204 | # File 'lib/rdf/model/statement.rb', line 199 def valid? subject? && subject.resource? && subject.valid? && predicate? && predicate.uri? && predicate.valid? && object? && object.term? && object.valid? && (graph? ? (graph_name.resource? && graph_name.valid?) : true) end | 
#variable? ⇒ Object #variable?(variables) ⇒ Boolean
URI, Node or Literal.
@return [Boolean]
| 169 170 171 172 173 174 175 176 177 178 179 180 | # File 'lib/rdf/model/statement.rb', line 169 def variable?(*args) case args.length when 0 !(subject? && subject.constant? && predicate? && predicate.constant? && object? && object.constant? && (graph? ? graph_name.constant? : true)) when 1 to_quad.any? {|t| t.respond_to?(:variable?) && t.variable?(*args)} else raise ArgumentError("wrong number of arguments (given #{args.length}, expected 0 or 1)") end end |