/* * The Apache Software License, Version 1.1 * * * Copyright (c) 2001-2003 The Apache Software Foundation. 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 end-user documentation included with the redistribution, * if any, must include the following acknowledgment: * "This product includes software developed by the * Apache Software Foundation (http://www.apache.org/)." * Alternately, this acknowledgment may appear in the software itself, * if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must * not be used to endorse or promote products derived from this * software without prior written permission. For written * permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache", * nor may "Apache" appear in their name, without prior written * permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS 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. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation and was * originally based on software copyright (c) 2001, International * Business Machines, Inc., http://www.apache.org. For more * information on the Apache Software Foundation, please see * . */ package com.sun.org.apache.xerces.internal.impl.xs; import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo; import com.sun.org.apache.xerces.internal.xs.XSAnnotation; import com.sun.org.apache.xerces.internal.xs.XSAttributeGroupDefinition; import com.sun.org.apache.xerces.internal.xs.XSAttributeUse; import com.sun.org.apache.xerces.internal.xs.XSConstants; import com.sun.org.apache.xerces.internal.xs.XSNamespaceItem; import com.sun.org.apache.xerces.internal.xs.XSObjectList; import com.sun.org.apache.xerces.internal.xs.XSWildcard; import com.sun.org.apache.xerces.internal.impl.xs.util.XSObjectListImpl; /** * The XML representation for an attribute group declaration * schema component is a global element information item * * @author Sandy Gao, IBM * @author Rahul Srivastava, Sun Microsystems Inc. * * @version $Id: XSAttributeGroupDecl.java,v 1.16 2003/11/11 20:14:58 sandygao Exp $ */ public class XSAttributeGroupDecl implements XSAttributeGroupDefinition { // name of the attribute group public String fName = null; // target namespace of the attribute group public String fTargetNamespace = null; // number of attribute uses included by this attribute group int fAttrUseNum = 0; // attribute uses included by this attribute group private static final int INITIAL_SIZE = 5; XSAttributeUseImpl[] fAttributeUses = new XSAttributeUseImpl[INITIAL_SIZE]; // attribute wildcard included by this attribute group public XSWildcardDecl fAttributeWC = null; // whether there is an attribute use whose type is or is derived from ID. public String fIDAttrName = null; // optional annotation public XSAnnotationImpl fAnnotation; protected XSObjectListImpl fAttrUses = null; // add an attribute use // if the type is derived from ID, but there is already another attribute // use of type ID, then return the name of the other attribute use; // otherwise, return null public String addAttributeUse(XSAttributeUseImpl attrUse) { if (fAttrUseNum == fAttributeUses.length) { fAttributeUses = resize(fAttributeUses, fAttrUseNum*2); } fAttributeUses[fAttrUseNum++] = attrUse; // if this attribute use is prohibited, then don't check whether it's // of type ID if (attrUse.fUse == SchemaSymbols.USE_PROHIBITED) return null; if (attrUse.fAttrDecl.fType.isIDType()) { // if there is already an attribute use of type ID, return it' sname if (fIDAttrName == null) fIDAttrName = attrUse.fAttrDecl.fName; else return fIDAttrName; } return null; } public XSAttributeUse getAttributeUse(String namespace, String name) { for (int i=0; i 0) { OUTER: for (int i = 0; i < fAttrUseNum; i++) { if (fAttributeUses[i].fUse == SchemaSymbols.USE_PROHIBITED) continue; for (int j = 1; j <= pCount; j++) { if (fAttributeUses[i].fAttrDecl.fName == pUses[fAttrUseNum-pCount].fAttrDecl.fName && fAttributeUses[i].fAttrDecl.fTargetNamespace == pUses[fAttrUseNum-pCount].fAttrDecl.fTargetNamespace) { continue OUTER; } } pUses[newCount++] = fAttributeUses[i]; } fAttributeUses = pUses; fAttrUseNum = newCount; } } /** * Check that the attributes in this group validly restrict those from a base group. * If an error is found, an Object[] is returned. This contains the arguments for the error message * describing the error. The last element in the array (at index arr.length - 1) is the the error code. * Returns null if there is no error. * * REVISIT: is there a better way of returning the appropriate information for the error? * * @param typeName the name of the type containing this attribute group, used for error reporting purposes * @param baseGroup the XSAttributeGroupDecl that is the base we are checking against */ public Object[] validRestrictionOf(String typeName, XSAttributeGroupDecl baseGroup) { Object[] errorArgs = null; XSAttributeUseImpl attrUse = null; XSAttributeDecl attrDecl = null; XSAttributeUseImpl baseAttrUse = null; XSAttributeDecl baseAttrDecl = null; for (int i=0; iname of this XSObject depending on the * XSObject type. */ public String getName() { return fName; } /** * The namespace URI of this node, or null if it is * unspecified. defines how a namespace URI is attached to schema * components. */ public String getNamespace() { return fTargetNamespace; } /** * {attribute uses} A set of attribute uses. */ public XSObjectList getAttributeUses() { if (fAttrUses == null){ fAttrUses = new XSObjectListImpl(fAttributeUses, fAttrUseNum); } return fAttrUses; } /** * {attribute wildcard} Optional. A wildcard. */ public XSWildcard getAttributeWildcard() { return fAttributeWC; } /** * Optional. Annotation. */ public XSAnnotation getAnnotation() { return fAnnotation; } /** * @see com.sun.org.apache.xerces.internal.xs.XSObject#getNamespaceItem() */ public XSNamespaceItem getNamespaceItem() { //REVISIT: implement return null; } } // class XSAttributeGroupDecl