001: /*****************************************************************************
002: * Source code information
003: * -----------------------
004: * Original author Ian Dickinson, HP Labs Bristol
005: * Author email Ian.Dickinson@hp.com
006: * Package Jena 2
007: * Web http://sourceforge.net/projects/jena/
008: * Created 08-May-2003
009: * Filename $RCSfile: MinCardinalityRestrictionImpl.java,v $
010: * Revision $Revision: 1.9 $
011: * Release status $State: Exp $
012: *
013: * Last modified on $Date: 2008/01/02 12:08:02 $
014: * by $Author: andy_seaborne $
015: *
016: * (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008 Hewlett-Packard Development Company, LP
017: * (see footer for full conditions)
018: *****************************************************************************/package com.hp.hpl.jena.ontology.impl;
019:
020: // Imports
021: ///////////////
022: import com.hp.hpl.jena.enhanced.*;
023: import com.hp.hpl.jena.graph.*;
024: import com.hp.hpl.jena.ontology.*;
025:
026: /**
027: * <p>
028: * Implementation of the min cardinality restriction abstraction.
029: * </p>
030: *
031: * @author Ian Dickinson, HP Labs
032: * (<a href="mailto:Ian.Dickinson@hp.com" >email</a>)
033: * @version CVS $Id: MinCardinalityRestrictionImpl.java,v 1.9 2008/01/02 12:08:02 andy_seaborne Exp $
034: */
035: public class MinCardinalityRestrictionImpl extends RestrictionImpl
036: implements MinCardinalityRestriction {
037: // Constants
038: //////////////////////////////////
039:
040: // Static variables
041: //////////////////////////////////
042:
043: /**
044: * A factory for generating MinCardinalityRestriction facets from nodes in enhanced graphs.
045: * Note: should not be invoked directly by user code: use
046: * {@link com.hp.hpl.jena.rdf.model.RDFNode#as as()} instead.
047: */
048: public static Implementation factory = new Implementation() {
049: public EnhNode wrap(Node n, EnhGraph eg) {
050: if (canWrap(n, eg)) {
051: return new MinCardinalityRestrictionImpl(n, eg);
052: } else {
053: throw new ConversionException("Cannot convert node "
054: + n + " to MinCardinalityRestriction");
055: }
056: }
057:
058: public boolean canWrap(Node node, EnhGraph eg) {
059: // node will support being a MinCardinalityRestriction facet if it has rdf:type owl:Restriction or equivalent
060: // and the combination of owl:onProperty and owl:cardinality (or equivalents)
061: Profile profile = (eg instanceof OntModel) ? ((OntModel) eg)
062: .getProfile()
063: : null;
064: return (profile != null)
065: && profile.isSupported(node, eg,
066: MinCardinalityRestriction.class);
067: }
068: };
069:
070: // Instance variables
071: //////////////////////////////////
072:
073: // Constructors
074: //////////////////////////////////
075:
076: /**
077: * <p>
078: * Construct a min cardinality restriction node represented by the given node in the given graph.
079: * </p>
080: *
081: * @param n The node that represents the resource
082: * @param g The enh graph that contains n
083: */
084: public MinCardinalityRestrictionImpl(Node n, EnhGraph g) {
085: super (n, g);
086: }
087:
088: // External signature methods
089: //////////////////////////////////
090:
091: // minCardinality
092:
093: /**
094: * <p>Assert that this restriction restricts the property to have the given
095: * minimum cardinality. Any existing statements for <code>minCardinality</code>
096: * will be removed.</p>
097: * @param cardinality The minimum cardinality of the restricted property
098: * @exception OntProfileException If the {@link Profile#MIN_CARDINALITY()} property is not supported in the current language profile.
099: */
100: public void setMinCardinality(int cardinality) {
101: setPropertyValue(getProfile().MIN_CARDINALITY(),
102: "MIN_CARDINALITY", getModel().createTypedLiteral(
103: cardinality));
104: }
105:
106: /**
107: * <p>Answer the minimum cardinality of the restricted property.</p>
108: * @return The minimum cardinality of the restricted property
109: * @exception OntProfileException If the {@link Profile#MIN_CARDINALITY()} property is not supported in the current language profile.
110: */
111: public int getMinCardinality() {
112: return objectAsInt(getProfile().MIN_CARDINALITY(),
113: "MIN_CARDINALITY");
114: }
115:
116: /**
117: * <p>Answer true if this property restriction has the given minimum cardinality.</p>
118: * @param cardinality The cardinality to test against
119: * @return True if the given cardinality is the min cardinality of the restricted property in this restriction
120: * @exception OntProfileException If the {@link Profile#MIN_CARDINALITY()} property is not supported in the current language profile.
121: */
122: public boolean hasMinCardinality(int cardinality) {
123: return hasPropertyValue(getProfile().MIN_CARDINALITY(),
124: "MIN_CARDINALITY", getModel().createTypedLiteral(
125: cardinality));
126: }
127:
128: /**
129: * <p>Remove the statement that this restriction has the given minimum cardinality
130: * for the restricted property. If this statement
131: * is not true of the current model, nothing happens.</p>
132: * @param cardinality A min cardinality value to be removed from this restriction
133: */
134: public void removeMinCardinality(int cardinality) {
135: removePropertyValue(getProfile().MIN_CARDINALITY(),
136: "MIN_CARDINALITY", getModel().createTypedLiteral(
137: cardinality));
138: }
139:
140: // Internal implementation methods
141: //////////////////////////////////
142:
143: //==============================================================================
144: // Inner class definitions
145: //==============================================================================
146:
147: }
148:
149: /*
150: (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008 Hewlett-Packard Development Company, LP
151: All rights reserved.
152:
153: Redistribution and use in source and binary forms, with or without
154: modification, are permitted provided that the following conditions
155: are met:
156:
157: 1. Redistributions of source code must retain the above copyright
158: notice, this list of conditions and the following disclaimer.
159:
160: 2. Redistributions in binary form must reproduce the above copyright
161: notice, this list of conditions and the following disclaimer in the
162: documentation and/or other materials provided with the distribution.
163:
164: 3. The name of the author may not be used to endorse or promote products
165: derived from this software without specific prior written permission.
166:
167: THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
168: IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
169: OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
170: IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
171: INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
172: NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
173: DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
174: THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
175: (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
176: THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
177: */
|