fAttrChecker.returnAttrArray(attrValues, schemaDoc);
return;
}
UniqueOrKey key = null;
IdentityConstraint ret = (IdentityConstraint)fSchemaHandler.getGlobalDecl(schemaDoc, XSDHandler.IDENTITYCONSTRAINT_TYPE, kName, krElem);
// if ret == null, we've already reported an error in getGlobalDecl
// we report an error only when ret != null, and the return type keyref
if (ret != null) {
if (ret.getCategory() == IdentityConstraint.IC_KEY ||
ret.getCategory() == IdentityConstraint.IC_UNIQUE) {
key = (UniqueOrKey)ret;
} else {
reportSchemaError("src-resolve", new Object[]{kName.rawname, "identity constraint key/unique"}, krElem);
}
}
if(key == null) {
fAttrChecker.returnAttrArray(attrValues, schemaDoc);
return;
}
KeyRef keyRef = new KeyRef(schemaDoc.fTargetNamespace, krName, element.fName, key);
// If errors occurred in traversing the identity constraint, then don't
// add it to the schema, to avoid errors when processing the instance.
if (traverseIdentityConstraint(keyRef, krElem, schemaDoc, attrValues)) {
//Schema Component Constraint: Identity-constraint Definition Properties Correct
//2 If the {identity-constraint category} is keyref, the cardinality of the {fields} must equal that of the {fields} of the {referenced key}.
if(key.getFieldCount() != keyRef.getFieldCount()) {
reportSchemaError("c-props-correct.2" , new Object [] {krName,key.getIdentityConstraintName()}, krElem);
} else {
// add key reference to element decl
// and stuff this in the grammar
if (grammar.getIDConstraintDecl(keyRef.getIdentityConstraintName()) == null) {
grammar.addIDConstraintDecl(element, keyRef);
}
// also add it to extended map
final String loc = fSchemaHandler.schemaDocument2SystemId(schemaDoc);
final IdentityConstraint idc = grammar.getIDConstraintDecl(keyRef.getIdentityConstraintName(), loc);
if (idc == null) {
grammar.addIDConstraintDecl(element, keyRef, loc);
}
// handle duplicates