org.semanticweb.owlapi.model.IRI Maven / Gradle / Ivy
The newest version!
/*
* This file is part of the OWL API.
*
* The contents of this file are subject to the LGPL License, Version 3.0.
*
* Copyright (C) 2011, The University of Manchester
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see http://www.gnu.org/licenses/.
*
*
* Alternatively, the contents of this file may be used under the terms of the Apache License, Version 2.0
* in which case, the provisions of the Apache License Version 2.0 are applicable instead of those above.
*
* Copyright 2011, University of Manchester
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.semanticweb.owlapi.model;
import java.io.File;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
import java.util.Collections;
import java.util.Set;
import org.openrdf.model.impl.ValueFactoryImpl;
import org.semanticweb.owlapi.io.XMLUtils;
import org.semanticweb.owlapi.util.WeakCache;
import org.semanticweb.owlapi.vocab.Namespaces;
import org.semanticweb.owlapi.vocab.OWLRDFVocabulary;
/** Author: Matthew Horridge
* The University of Manchester
* Information Management Group
* Date: 14-Jan-2009 Represents International Resource Identifiers */
public class IRI implements OWLAnnotationSubject, OWLAnnotationValue, SWRLPredicate,
CharSequence {
/** Obtains this IRI as a URI. Note that Java URIs handle unicode characters,
* so there is no loss during this translation.
*
* @return The URI */
public URI toURI() {
if (remainder != null) {
StringBuilder sb = new StringBuilder();
sb.append(prefix);
sb.append(remainder);
return URI.create(sb.toString());
} else {
return URI.create(prefix);
}
}
/**
* Obtains this IRI as an OpenRDF URI.
* @return The URI
*/
public org.openrdf.model.URI toOpenRDFURI() {
if (remainder != null) {
StringBuilder sb = new StringBuilder();
sb.append(prefix);
sb.append(remainder);
return ValueFactoryImpl.getInstance().createURI(sb.toString());
}
else {
return ValueFactoryImpl.getInstance().createURI(prefix);
}
}
/** Determines if this IRI is absolute
*
* @return true
if this IRI is absolute or false
* if this IRI is not absolute */
public boolean isAbsolute() {
int colonIndex = prefix.indexOf(':');
if (colonIndex == -1) {
return false;
}
for (int i = 0; i < colonIndex; i++) {
char ch = prefix.charAt(i);
if (!Character.isLetter(ch) && !Character.isDigit(ch) && ch != '.'
&& ch != '+' && ch != '-') {
return false;
}
}
return true;
}
/** @return the IRI scheme, e.g., http, urn... can be null */
public String getScheme() {
int colonIndex = prefix.indexOf(':');
if (colonIndex == -1) {
return null;
}
return prefix.substring(0, colonIndex);
}
/** @return the prefix. Can be null.
* @deprecated use getNamespace instead - better name */
@Deprecated
public String getStart() {
return prefix;
}
/** @return the prefix. Can be null. */
public String getNamespace() {
return prefix;
}
/** @param s
* the IRI stirng to be resolved
* @return s resolved against this IRI (with the URI::resolve() method,
* unless this IRI is opaque) */
public IRI resolve(String s) {
// shortcut: checking absolute and opaque here saves the creation of an
// extra URI object
URI uri = URI.create(s);
if (uri.isAbsolute() || uri.isOpaque()) {
return IRI.create(uri);
}
return IRI.create(toURI().resolve(uri).toString());
}
/** Determines if this IRI is in the reserved vocabulary. An IRI is in the
* reserved vocabulary if it starts with
* <http://www.w3.org/1999/02/22-rdf-syntax-ns#> or
* <http://www.w3.org/2000/01/rdf-schema#> or
* <http://www.w3.org/2001/XMLSchema#> or
* <http://www.w3.org/2002/07/owl#>
*
* @return true
if the IRI is in the reserved vocabulary,
* otherwise false
. */
public boolean isReservedVocabulary() {
return Namespaces.OWL.inNamespace(prefix) || Namespaces.RDF.inNamespace(prefix)
|| Namespaces.RDFS.inNamespace(prefix)
|| Namespaces.XSD.inNamespace(prefix);
}
/** Determines if this IRI is equal to the IRI that owl:Thing
is
* named with
*
* @return true
if this IRI is equal to
* <http://www.w3.org/2002/07/owl#Thing> and otherwise
* false
*/
public boolean isThing() {
return remainder != null && remainder.equals("Thing")
&& Namespaces.OWL.inNamespace(prefix);
}
/** Determines if this IRI is equal to the IRI that owl:Nothing
* is named with
*
* @return true
if this IRI is equal to
* <http://www.w3.org/2002/07/owl#Nothing> and otherwise
* false
*/
public boolean isNothing() {
return equals(OWLRDFVocabulary.OWL_NOTHING.getIRI());
}
/** Determines if this IRI is equal to the IRI that is named
* rdf:PlainLiteral
*
* @return true
if this IRI is equal to
* <http://www.w3.org/1999/02/22-rdf-syntax-ns#PlainLiteral>,
* otherwise false
*/
public boolean isPlainLiteral() {
return remainder != null && remainder.equals("PlainLiteral")
&& Namespaces.RDF.inNamespace(prefix);
}
/** Gets the fragment of the IRI.
*
* @return The IRI fragment, or null
if the IRI does not have a
* fragment */
public String getFragment() {
return remainder;
}
/** Obtained this IRI surrounded by angled brackets
*
* @return This IRI surrounded by < and > */
public String toQuotedString() {
StringBuilder sb = new StringBuilder();
sb.append("<");
sb.append(prefix);
if (remainder != null) {
sb.append(remainder);
}
sb.append(">");
return sb.toString();
}
/** Creates an IRI from the specified String.
*
* @param str
* The String that specifies the IRI. Cannot be null.
* @return The IRI that has the specified string representation. */
public static IRI create(String str) {
if (str == null) {
throw new IllegalArgumentException("String must not be null");
}
int index = XMLUtils.getNCNameSuffixIndex(str);
if (index < 0) {
// no ncname
return new IRI(str, null);
}
return new IRI(str.substring(0, index), str.substring(index));
}
/** Creates an IRI by concatenating two strings. The full IRI is an IRI that
* contains the characters in prefix + suffix.
*
* @param prefix
* The first string. May be null
.
* @param suffix
* The second string. May be null
.
* @return An IRI whose characters consist of prefix + suffix.
* @since 3.3 */
public static IRI create(String prefix, String suffix) {
if (prefix == null) {
return create(suffix);
} else if (suffix == null) {
// suffix set deliberately to null is used only in blank node
// management
// this is not great but blank nodes should be changed to not refer
// to IRIs at all
// XXX address blank node issues with iris
return create(prefix);
} else {
int index = XMLUtils.getNCNameSuffixIndex(prefix);
int test = XMLUtils.getNCNameSuffixIndex(suffix);
if (index == -1 && test == 0) {
// the prefix does not contain an ncname character and there is
// no illegal character in the suffix
// the split is therefore correct
return new IRI(prefix, suffix);
}
// otherwise the split is wrong; we could obtain the right split by
// using index and test, but it's just as easy to use the other
// constructor
return create(prefix + suffix);
}
}
/** @param file
* the file to create the IRI from. Cannot be null.
* @return file.toURI() IRI */
public static IRI create(File file) {
if (file == null) {
throw new IllegalArgumentException("file cannot be null");
}
return new IRI(file.toURI());
}
/** @param uri
* the uri to create the IRI from. Cannot be null
* @return the IRI wrapping the uri */
public static IRI create(java.net.URI uri) {
if (uri == null) {
throw new IllegalArgumentException("uri cannot be null");
}
return new IRI(uri);
}
/**
* @param uri the uri to create the IRI from. Cannot be null
* @return the IRI wrapping the uri
*/
public static IRI create(org.openrdf.model.URI uri) {
if (uri == null) {
throw new IllegalArgumentException("uri cannot be null");
}
return new IRI(uri.stringValue());
}
/** @param url
* the url to create the IRI from. Cannot be null.
* @return an IRI wraopping url.toURI()
* @throws URISyntaxException
* if the URL is ill formed */
public static IRI create(URL url) throws URISyntaxException {
if (url == null) {
throw new IllegalArgumentException("url cannot be null");
}
return new IRI(url.toURI());
}
/** Gets an auto-generated ontology document IRI.
*
* @return An auto-generated ontology document IRI. The IRI has the form
* owlapi:ontologyTIMESTAMP
*/
public static IRI generateDocumentIRI() {
return create("owlapi:ontology" + System.nanoTime());
}
// ///////////////////////////////////////////////////////////////////////////////////////////////////////
// ///////////////////////////////////////////////////////////////////////////////////////////////////////
// //
// // Impl - All constructors are private - factory methods are used for
// public creation
// //
// ///////////////////////////////////////////////////////////////////////////////////////////////////////
// ///////////////////////////////////////////////////////////////////////////////////////////////////////
private static final long serialVersionUID = 30406L;
private static WeakCache prefixCache = new WeakCache();
private final String remainder;
private final String prefix;
private int hashCode = 0;
/** Constructs an IRI which is built from the concatenation of the specified
* prefix and suffix.
*
* @param prefix
* The prefix.
* @param fragment
* The suffix. */
protected IRI(String prefix, String fragment) {
this.prefix = prefixCache.cache(prefix);
remainder = fragment;
}
protected IRI(String s) {
this(XMLUtils.getNCNamePrefix(s), XMLUtils.getNCNameSuffix(s));
}
protected IRI(URI uri) {
this(uri.toString());
}
@Override
public int length() {
return prefix.length() + (remainder == null ? 0 : remainder.length());
}
@Override
public char charAt(int index) {
if (index < 0) {
throw new IndexOutOfBoundsException(Integer.toString(index));
}
if (index >= length()) {
throw new IndexOutOfBoundsException(Integer.toString(index));
}
if (index < prefix.length()) {
return prefix.charAt(index);
}
return remainder.charAt(index - prefix.length());
}
@Override
public CharSequence subSequence(int start, int end) {
StringBuilder sb = new StringBuilder();
sb.append(prefix);
sb.append(remainder);
return sb.subSequence(start, end);
}
@Override
public void accept(OWLObjectVisitor visitor) {
visitor.visit(this);
}
@Override
public O accept(OWLObjectVisitorEx visitor) {
return visitor.visit(this);
}
@Override
public void accept(OWLAnnotationSubjectVisitor visitor) {
visitor.visit(this);
}
@Override
public E accept(OWLAnnotationSubjectVisitorEx visitor) {
return visitor.visit(this);
}
@Override
public Set getClassesInSignature() {
return Collections.emptySet();
}
@Override
public Set getDataPropertiesInSignature() {
return Collections.emptySet();
}
@Override
public Set getIndividualsInSignature() {
return Collections.emptySet();
}
@Override
public Set getObjectPropertiesInSignature() {
return Collections.emptySet();
}
@Override
public Set getSignature() {
return Collections.emptySet();
}
@Override
public Set getAnonymousIndividuals() {
return Collections.emptySet();
}
@Override
public Set getDatatypesInSignature() {
return Collections.emptySet();
}
@Override
public Set getNestedClassExpressions() {
return Collections.emptySet();
}
@Override
public int compareTo(OWLObject o) {
if (o == this) {
return 0;
}
if (!(o instanceof IRI)) {
return -1;
}
IRI other = (IRI) o;
int diff = prefix.compareTo(other.prefix);
if (diff != 0) {
return diff;
}
String otherRemainder = other.remainder;
if (remainder == null) {
if (otherRemainder == null) {
return 0;
} else {
return -1;
}
} else {
if (otherRemainder == null) {
return 1;
} else {
return remainder.compareTo(otherRemainder);
}
}
}
@Override
public String toString() {
if (remainder != null) {
StringBuilder sb = new StringBuilder();
sb.append(prefix);
sb.append(remainder);
return sb.toString();
} else {
return prefix;
}
}
@Override
public int hashCode() {
if (hashCode == 0) {
hashCode = prefix.hashCode() + (remainder != null ? remainder.hashCode() : 0);
}
return hashCode;
}
@Override
public void accept(OWLAnnotationValueVisitor visitor) {
visitor.visit(this);
}
@Override
public O accept(OWLAnnotationValueVisitorEx visitor) {
return visitor.visit(this);
}
@Override
public boolean isTopEntity() {
return false;
}
@Override
public boolean isBottomEntity() {
return false;
}
@Override
public boolean equals(Object obj) {
if (obj == null) {
return false;
}
if (obj == this) {
return true;
}
if (!(obj instanceof IRI)) {
return false;
}
IRI other = (IRI) obj;
String otherRemainder = other.remainder;
if (remainder == null) {
return otherRemainder == null && prefix.equals(other.prefix);
} else {
return otherRemainder != null && remainder.equals(otherRemainder)
&& other.prefix.equals(prefix);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy