Home. 
.

transparent

transparent

transparent

Altova Mailing List Archives


Re: Conditional Schema Processing

From: "Andrew Welch" <andrew.j.welch@-----.--->
To: "Zac Harvey" <zachary.harvey@-----.--->
Date: 12/5/2008 5:45:00 PM
2008/12/5 Zac Harvey <zachary.harvey@g...>:
> This may be bad design, so if it is, then I guess what I'm looking for is an
> elegant alternative solution. However I don't believe the following to be a
> product of poor design, and so the following question should apply:
>
> I want a particular element, <widget> to force the user to define a foo
> attribute, which will be an enum type of three potential values: me, you or
> us. For example:
>
> <widget foo="me" />
> <widget foo="you" />
> <widget foo="us" />
>
> Would all be legal <widget> instantiations. And so I have the following so
> far in my XSD:
>
> <xs:element name="widget" minOccurs="1" maxOccurs="unbounded">
>     <xs:complexType>
>         <xs:attribute name="foo" type="xs:string" use="required">
>             <xs:simpleType>
>                 <xs:restriction base="xs:string">
>                     <xs:enumeration value="me" />
>                     <xs:enumeration value="you" />
>                     <xs:enumeration value="us" />
>                 </xs:restriction>
>             </xs:simpleType>
>         </xs:attribute>
>
>         <xs:sequence>
>             <!-- No definition yet ... -->
>         </xs:sequence>
>     </xs:complexType>
> </xs:element>
>
> What I am looking for is the ability to define <widget>'s sequence based on
> the value of foo.  If foo="me" I want it to contain, say, an <apple>
> element. Else if it is "you" or "us" I want it to contain an <orange> child
> element.  So for example:
>
> <widget foo="me">
>     <apple>Hello!</apple>
> </widget>
>
> <widget foo="us">
>     <orange>XSD!</orange>
> </widget>
>
> I have been pouring through the tutorials and cannot find a way to include
> this conditional functionality...

The only way you can do it in XSD 1.0 is to add an xsi:type to the
widget element to differentiate it eg:

<widget foo="you" xsi:type="you-widget">

<widget foo="me" xsi:type="me-widget">

...along with the specific types:

<xsl:complexType name="you-widget">

<xsl:complexType name="me-widget">

If you can use XSD 1.1 then you don't need the xsi:type attribute as
you can use xs:alternative:

http://ajwelch.blogspot.com/2008/07/validating-co-constrains-in-xml-schema.html



-- 
Andrew Welch
http://andrewjwelch.com
Kernow: http://kernowforsaxon.sf.net/

From mrglavas@c... Fri Dec 05 17:48:45 2008
Received: from bart.w3.org ([128.30.52.63])
	by frink.w3.org with esmtp (Exim 4


transparent
Print
Mail
Like It
Disclaimer
.

These Archives are provided for informational purposes only and have been generated directly from the Altova mailing list archive system and are comprised of the lists set forth on www.altova.com/list/index.html. Therefore, Altova does not warrant or guarantee the accuracy, reliability, completeness, usefulness, non-infringement of intellectual property rights, or quality of any content on the Altova Mailing List Archive(s), regardless of who originates that content. You expressly understand and agree that you bear all risks associated with using or relying on that content. Altova will not be liable or responsible in any way for any content posted including, but not limited to, any errors or omissions in content, or for any losses or damage of any kind incurred as a result of the use of or reliance on any content. This disclaimer and limitation on liability is in addition to the disclaimers and limitations contained in the Website Terms of Use and elsewhere on the site.

.
.

transparent

transparent