org.openrdf.sail.inferencer.InferencerConnection Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sesame-sail-inferencer Show documentation
Show all versions of sesame-sail-inferencer Show documentation
Stackable Sail implementation that adds RDF Schema inferencing to an RDF store.
/*
* Licensed to Aduna under one or more contributor license agreements.
* See the NOTICE.txt file distributed with this work for additional
* information regarding copyright ownership.
*
* Aduna licenses this file to you under the terms of the Aduna BSD
* License (the "License"); you may not use this file except in compliance
* with the License. See the LICENSE.txt file distributed with this work
* for the full License.
*
* 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.openrdf.sail.inferencer;
import org.openrdf.model.Resource;
import org.openrdf.model.URI;
import org.openrdf.model.Value;
import org.openrdf.sail.NotifyingSailConnection;
import org.openrdf.sail.SailConnection;
import org.openrdf.sail.SailConnectionListener;
import org.openrdf.sail.SailException;
/**
* An extension of the {@link SailConnection} interface offering methods that
* can be used by inferencers to store and remove inferred statements.
*/
public interface InferencerConnection extends NotifyingSailConnection {
/**
* Adds an inferred statement to a specific context.
*
* @param subj
* The subject of the statement to add.
* @param pred
* The predicate of the statement to add.
* @param obj
* The object of the statement to add.
* @param contexts
* The context(s) to add the statement to. Note that this parameter is
* a vararg and as such is optional. If no contexts are supplied the
* method operates on the entire repository.
* @throws SailException
* If the statement could not be added.
* @throws IllegalStateException
* If the connection has been closed.
*/
// FIXME: remove boolean result value to enable batch-wise processing
public boolean addInferredStatement(Resource subj, URI pred, Value obj, Resource... contexts)
throws SailException;
/**
* Removes an inferred statement from a specific context.
*
* @param subj
* The subject of the statement that should be removed.
* @param pred
* The predicate of the statement that should be removed.
* @param obj
* The object of the statement that should be removed.
* @param contexts
* The context(s) from which to remove the statements. Note that this
* parameter is a vararg and as such is optional. If no contexts are
* supplied the method operates on the entire repository.
* @throws SailException
* If the statement could not be removed.
* @throws IllegalStateException
* If the connection has been closed.
*/
// FIXME: remove boolean result value to enable batch-wise processing
public boolean removeInferredStatement(Resource subj, URI pred, Value obj, Resource... contexts)
throws SailException;
/**
* Removes all inferred statements from the specified/all contexts. If no
* contexts are specified the method operates on the entire repository.
*
* @param contexts
* The context(s) from which to remove the statements. Note that this
* parameter is a vararg and as such is optional. If no contexts are
* supplied the method operates on the entire repository.
* @throws SailException
* If the statements could not be removed.
* @throws IllegalStateException
* If the connection has been closed.
*/
public void clearInferred(Resource... contexts)
throws SailException;
/**
* Flushes any pending updates to be processed and the resulting changes to
* be reported to registered {@link SailConnectionListener}s.
*
* @throws SailException
* If the updates could not be processed.
* @throws IllegalStateException
* If the connection has been closed.
*/
public void flushUpdates()
throws SailException;
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy