1 /**
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 */
18 package org.apache.commons.rdf.api;
19
20 import java.util.Objects;
21
22 /**
23 * An <a href= "http://www.w3.org/TR/rdf11-concepts/#dfn-rdf-triple" >RDF-1.1
24 * Triple</a>, as defined by
25 * <a href= "http://www.w3.org/TR/rdf11-concepts/#section-triples" >RDF-1.1 Concepts and
26 * Abstract Syntax</a>, a W3C Recommendation published on 25 February 2014.
27 * <p>
28 * A <code>Triple</code> object in Commons RDF is considered
29 * <strong>immutable</strong>, that is, over its life time it will have
30 * consistent behaviour for its {@link #equals(Object)}, and the {@link RDFTerm}
31 * instances returned from {@link #getSubject()}, {@link #getPredicate()} and
32 * {@link #getObject()} will have consistent {@link RDFTerm#equals(Object)}
33 * behaviour.
34 * <p>
35 * Note that <code>Triple</code> methods are not required to return object
36 * identical (<code>==</code>) instances as long as they are equivalent
37 * according to {@link RDFTerm#equals(Object)}. Specialisations of
38 * <code>Triple</code> may provide additional methods that are documented to be
39 * mutable.
40 * <p>
41 * <code>Triple</code> methods are <strong>thread-safe</strong>, however
42 * specialisations may provide additional methods that are documented to not be
43 * thread-safe.
44 * <p>
45 * <code>Triple</code>s can be safely used in hashing collections like
46 * {@link java.util.HashSet} and {@link java.util.HashMap}.
47 * <p>
48 * Any <code>Triple</code> can be used interchangeably across Commons RDF
49 * implementations.
50 *
51 * @see Quad
52 * @see RDF#createTriple(BlankNodeOrIRI,IRI,RDFTerm)
53 * @see <a href= "http://www.w3.org/TR/rdf11-concepts/#dfn-rdf-triple" >RDF-1.1
54 * Triple</a>
55 */
56 public interface Triple extends TripleLike {
57
58 /**
59 * The subject of this triple, which may be either a {@link BlankNode} or an
60 * {@link IRI}, which are represented in Commons RDF by the interface
61 * {@link BlankNodeOrIRI}.
62 *
63 * @return The subject {@link BlankNodeOrIRI} of this triple.
64 * @see <a href="http://www.w3.org/TR/rdf11-concepts/#dfn-subject">RDF-1.1
65 * Triple subject</a>
66 */
67 @Override
68 BlankNodeOrIRI getSubject();
69
70 /**
71 * The predicate {@link IRI} of this triple.
72 *
73 * @return The predicate {@link IRI} of this triple.
74 * @see <a href="http://www.w3.org/TR/rdf11-concepts/#dfn-predicate">RDF-1.1
75 * Triple predicate</a>
76 */
77 @Override
78 IRI getPredicate();
79
80 /**
81 * The object of this triple, which may be either a {@link BlankNode}, an
82 * {@link IRI}, or a {@link Literal}, which are represented in Commons RDF
83 * by the interface {@link RDFTerm}.
84 *
85 * @return The object {@link RDFTerm} of this triple.
86 * @see <a href="http://www.w3.org/TR/rdf11-concepts/#dfn-object">RDF-1.1
87 * Triple object</a>
88 */
89 @Override
90 RDFTerm getObject();
91
92 /**
93 * Check it this Triple is equal to another Triple.
94 * <p>
95 * Two Triples are equal if and only if their {@link #getSubject()},
96 * {@link #getPredicate()} and {@link #getObject()} are equal.
97 * </p>
98 * <p>
99 * Implementations MUST also override {@link #hashCode()} so that two equal
100 * Triples produce the same hash code.
101 * </p>
102 *
103 * @param other
104 * Another object
105 * @return true if other is a Triple and is equal to this
106 * @see Object#equals(Object)
107 */
108 @Override
109 boolean equals(Object other);
110
111 /**
112 * Calculate a hash code for this Triple.
113 * <p>
114 * The returned hash code MUST be equal to the result of
115 * {@link Objects#hash(Object...)} with the arguments {@link #getSubject()},
116 * {@link #getPredicate()}, {@link #getObject()}.
117 * <p>
118 * This method MUST be implemented in conjunction with
119 * {@link #equals(Object)} so that two equal {@link Triple}s produce the
120 * same hash code.
121 *
122 * @return a hash code value for this Triple.
123 * @see Object#hashCode()
124 * @see Objects#hash(Object...)
125 */
126 @Override
127 int hashCode();
128
129 }