All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.clerezza.Graph Maven / Gradle / Ivy

Go to download

Apache Clerezza API implements the RDF data model as defined by http://www.w3.org/TR/rdf11-concepts/

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor  license  agreements.  See the NOTICE file distributed
 * with this work  for  additional  information  regarding  copyright
 * ownership.  The ASF  licenses  this file to you 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.apache.clerezza;

import java.util.Collection;
import java.util.Iterator;
import java.util.concurrent.locks.ReadWriteLock;


/**
 * A set of triples (as it doesn't allow duplicates), it does however
 * not extend {@link java.util.Set} as it doesn't inherit its
 * specification for hashCode() and equals.
 * It is possible to add GraphListener to listen for modifications
 * in the triples.
 *
 * @author reto
 */
public interface Graph extends Collection {

    /**
     * Filters triples given a pattern.
     * filter(null, null, null) returns the same as iterator()
     *
     * @param subject
     * @param predicate
     * @param object
     * @return Iterator
     */
    public Iterator filter(BlankNodeOrIRI subject, IRI predicate,
                                   RDFTerm object);

    /**
     * Returns true if other describes the same graph and will
     * always describe the same graph as this instance, false otherwise.
     * It returns true if this == other or if it
     * is otherwise guaranteed that changes to one of the instances are
     * immediately reflected in the other or if both graphs are immutable.
     *
     * @param other
     * @return true if other == this
     */
    @Override
    public boolean equals(Object other);

    /**
     * Returns an ImutableGraph describing the graph at the current point in
     * time. if this is an instance of ImmutableGraph this can
     * safely return this.
     *
     * @return the current time slice of the possibly mutable graph represented by the instance.
     */
    public ImmutableGraph getImmutableGraph();

    /**
     * The lock provided by this methods allows to create read- and write-locks
     * that span multiple method calls. Having a read locks prevents other
     * threads from writing to this Graph, having a write-lock prevents other
     * threads from reading and writing. Implementations would typically
     * return a java.util.concurrent.locks.ReentrantReadWriteLock.
     * Immutable instances (such as instances of ImmutableGraph)
     * or instances used in transaction where concurrent acces of the same
     * instance is not an issue may return a no-op ReadWriteLock (i.e. one
     * which returned ReadLock and WriteLock instances of which the methods do
     * not do anything)
     *
     * @return the lock of this Graph
     */
    ReadWriteLock getLock();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy