com.hp.hpl.jena.ontology.BooleanClassDescription Maven / Gradle / Ivy
Show all versions of jena Show documentation
/*****************************************************************************
* Source code information
* -----------------------
* Original author Ian Dickinson, HP Labs Bristol
* Author email [email protected]
* Package Jena 2
* Web http://sourceforge.net/projects/jena/
* Created 28-Apr-2003
* Filename $RCSfile: BooleanClassDescription.java,v $
* Revision $Revision: 1.2 $
* Release status $State: Exp $
*
* Last modified on $Date: 2009/10/06 13:04:34 $
* by $Author: ian_dickinson $
*
* (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Hewlett-Packard Development Company, LP
* (see footer for full conditions)
*****************************************************************************/
// Package
///////////////
package com.hp.hpl.jena.ontology;
// Imports
///////////////
import com.hp.hpl.jena.rdf.model.*;
import com.hp.hpl.jena.util.iterator.ExtendedIterator;
import java.util.*;
/**
*
* Encapsulates a class description formed from a boolean combination of other
* class descriptions (ie union, intersection or complement).
*
*
* @author Ian Dickinson, HP Labs
* (email)
* @version CVS $Id: BooleanClassDescription.java,v 1.2 2009/10/06 13:04:34 ian_dickinson Exp $
*/
public interface BooleanClassDescription
extends OntClass
{
// Constants
//////////////////////////////////
// External signature methods
//////////////////////////////////
// operand
/**
* Assert that the operands for this boolean class expression are the classes
* in the given list. Any existing
* statements for the operator will be removed.
* @param operands The list of operands to this expression.
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public void setOperands( RDFList operands );
/**
* Add a class the operands of this boolean expression.
* @param cls A class that will be added to the operands of this Boolean expression
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public void addOperand( Resource cls );
/**
* Add all of the classes from the given iterator to the operands of this boolean expression.
* @param classes A iterator over classes that will be added to the operands of this Boolean expression
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public void addOperands( Iterator extends Resource> classes );
/**
* Answer the list of operands for this Boolean class expression.
* @return A list of the operands of this expression.
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public RDFList getOperands();
/**
* Answer an iterator over all of the classes that are the operands of this
* Boolean class expression. Each element of the iterator will be an {@link OntClass}.
* @return An iterator over the operands of the expression.
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public ExtendedIterator extends OntClass> listOperands();
/**
* Answer true if this Boolean class expression has the given class as an operand.
* @param cls A class to test
* @return True if the given class is an operand to this expression.
* @exception OntProfileException If the operand property is not supported in the current language profile.
*/
public boolean hasOperand( Resource cls );
/**
* Remove the given resource from the operands of this class expression.
* @param res An resource to be removed from the operands of this class expression
*/
public void removeOperand( Resource res );
/**
* Answer the property that is used to construct this boolean expression, for example
* {@link Profile#UNION_OF()}.
* @return The property used to construct this Boolean class expression.
*/
public Property operator();
}
/*
(c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Hewlett-Packard Development Company, LP
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
3. The name of the author may not be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/