[ 
https://issues.apache.org/jira/browse/XERCESJ-1577?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13447627#comment-13447627
 ] 

Radu Coravu commented on XERCESJ-1577:
--------------------------------------

I found where the problem is:

In the method:

org.apache.xerces.impl.xs.traversers.XSAttributeCheckerXerces.checkAttributes(Element,
 boolean, XSDocumentInfo, boolean)

there is some code like:

if (oneAttr.valueIndex == ATTIDX_SUBSGROUP) {
.....
} else{
.....
}

If you look at the "else" branch, it contains a special fix for chameleon 
schemas with the comment:

 // kludge to handle chameleon includes/redefines...

That particular fix must be done also on the "if" branch.

                
> Error when referencing substitution group with chameleon namespace
> ------------------------------------------------------------------
>
>                 Key: XERCESJ-1577
>                 URL: https://issues.apache.org/jira/browse/XERCESJ-1577
>             Project: Xerces2-J
>          Issue Type: Bug
>          Components: XML Schema 1.0 Structures
>    Affects Versions: 2.11.0
>            Reporter: Radu Coravu
>
> Tested with the libraries from the Xerces-J 2.11.0-xml-schema-1.1-beta 
> release.
> If I have a small schema in no-namespace like:
> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"; 
> elementFormDefault="qualified">
>     <xs:element name="elem" substitutionGroup="p.trans"/>
>     <xs:element name="p.trans" abstract="true"/>
> </xs:schema>
> and a schema which has a target namespaces and includes it:
> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"; 
> elementFormDefault="qualified" targetNamespace="mainNS" xmlns:ns="mainNS">
>     <xs:include schemaLocation="test.xsd"/>
> </xs:schema>
> Validation of the main schema (or of an XML referencing the XML schema) 
> reports the following problem:
> src-resolve.4.1: Error resolving component 'p.trans'. It was detected that 
> 'p.trans' has no namespace, but components with no target namespace are not 
> referenceable from schema document 
> 'file:/C:/Users/radu_coravu/Desktop/xsdProblem/test.xsd'. If 'p.trans' is 
> intended to have a namespace, perhaps a prefix needs to be provided. If it is 
> intended that 'p.trans' has no namespace, then an 'import' without a 
> "namespace" attribute should be added to 
> 'file:/C:/Users/radu_coravu/Desktop/xsdProblem/test.xsd'.
> Basically the reference to a substitution group which is in a chameleon 
> schema is not properly binded once the schema is included from a schema which 
> has a target namespace.
> This worked in Xerces 2.9.1.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to