Altova Mailing List Archives>Archive Index >xmlschema-dev Archive Home >Recent entries >Thread Prev - Re: A schema that uses attribute values to enforce content structure rules? [Thread Next] Re: A schema that uses attribute values to enforce content structure rules?To: Boris Kolpackov <boris@-------------.---> Date: 1/27/2009 8:45:00 AM
I tried several variations on this but ended up painted into a corner
every time. In the end I refactored the representation entirely so
that each type has it's own type:
<document xmlns:a="http://my.namespace/url">
<a:Xml>
<foo:B />
<bar:C />
</a:Xml>
<a:Container>
<a:Xml>
<foo:B />
<bar:C />
</a:Xml>
<a:Container>
<a:Xml>
<bar:C />
</a:Xml>
</a:Container>
<Values>
<a:value>foo</a:value>
<a:value>foofy</a:value>
<a:value>food</a:value>
</a:Values>
</a:Container>
</document>
And was able to explicitly define the content of each type. Michael
Kay's point about XSD 1.0 and "conditional type assignment" really
helped me reevaluate the problem space.
Thanks for all your help,
Nathan
On Jan 18, 2009, at 10:24 PM, Boris Kolpackov wrote:
>
> Hi Nathan,
>
> Nathan Potter <ndp@c...> writes:
>
>> I am trying to express the semantics of our content model in an XML
>> schema. I have a type whose allowed content is function of the values
>> of an attribute. Here's a simplified "sketch" of the problem:
>>
>> An element <A> has a required attribute "type", if A@type=="xml" then
>> <A> may contain any (other namespace) XML:
>>
>> <A type="xml">
>> <foo:B />
>> <bar:C />
>> </A>
>>
>> If A@type=="Container" then <A> may any number of other <A> elements:
>>
>> <A type="Container">
>> <A type="xml">
>> <foo:B />
>> </A>
>> <A type="Container">
>> <A type="xml">
>> <bar:C />
>> </A>
>> </A>
>> </A>
>>
>> If A@type=="values" then <A> must contain one or more <value>
>> elements:
>>
>> <A type="values">
>> <value>1234</value>
>> </A>
>
> You can do this but you will need to use the special xsi:type
> attribute
> instead of just type. You will need to define an abstract base type
> for
> element A:
>
> <complexType name="base" abstract="true"/>
>
> Then you would define three types, xml, container, and values, that
> derive from this type and define the corresponding content models.
>
> You may also want to consider embedding the type information directly
> into the element name, for example:
>
> <Container>
> <xml>
> <foo:B />
> </xml>
> <Container>
> <xml>
> <bar:C />
> </xml>
> </Container>
> </Container>
>
> This gives you a much cleaner vocabulary. You can do this in an
> extensible manner using substitution groups.
>
> Boris
>
> --
> Boris Kolpackov, Code Synthesis Tools http://codesynthesis.com/~boris/blog
> Open source XML data binding for C++: http://codesynthesis.com/products/xsd
> Mobile/embedded validating XML parsing: http://codesynthesis.com/products/xsde
>
============================================================
Nathan Potter Oregon State University, COAS
ndp at coas.oregonstate.edu 104 Ocean. Admin. Bldg.
541 737 2293 voice Corvallis, OR 97331-5503
541 737 2064 fax
From george@o... Wed Jan 28 07:01:14 2009
Received: from maggie.w3.org ([193.51.208.68])
by frink.w3.org with esmtp (Exim 4.63)
(envelope-from <geo | ||||||
| Company | Legal | Press | Partners | Careers | Sitemap | Contact Us | Altova Blog | Mobile | Full Site | |||
|
