- From: Pete Cordell <petexmldev@codalogic.com>
- Date: Thu, 30 Oct 2008 22:13:44 -0000
- To: <xmlschema-dev@w3.org>, <Jeffrey.Kramer@dds.net>
Original Message From: Jeffrey.Kramer > We were hoping to get a definitive answer on how the <choice> element is > supposed to behave. > > We observed kind of a counter intuitive result of choice in a test. i.e., > we'd think it was going to be mutually exclusive across it's elements, > although when we provided >1 types it actually spit out both ( see below ) The result you are getting for the XSD segment you show is correct. You've effectively allowing multiple instances of the choice, where each choice is independent, much as if you had: ChoiceClass[] myChoices; If you wanted one option or the other, but wanted to allow multiple instances of which ever one was chosen, you would do something like the following XSD segment: <xs:choice> <xs:element name="foo" type="xs:string" maxOccurs="unbounded"/> <xs:element name="bar" type="xs:string" maxOccurs="unbounded"/> </xs:choice> HTH, Pete Cordell Codalogic Ltd Interface XML to C++ the easy way using XML C++ data binding to convert XSD schemas to C++ classes. Visit http://www.codalogic.com/lmx/ for more info ----- Original Message ----- From: <Jeffrey.Kramer@dds.net> To: <xmlschema-dev@w3.org> Sent: Thursday, October 30, 2008 6:45 PM Subject: inquiry into the <choice> element behavior > We were hoping to get a definitive answer on how the <choice> element is > supposed to behave. > > We observed kind of a counter intuitive result of choice in a test. i.e., > we'd think it was going to be mutually exclusive across it's elements, > although when we provided >1 types it actually spit out both ( see below ) > > i.e., > > providing > .... > <foo>1</foo> > <foo>2</foo> > <bar>3</bar> > ... > to > .. > <xs:choice maxOccurs="unbounded"> > <xs:element name="foo" type="xs:string" /> > <xs:element name="bar" type="xs:string" /> > </xs:choice> > > yields: > > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #startElement: > foo > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #characters: 1 > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #endElement: foo > > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #startElement: > foo > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #characters: 2 > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #endElement: foo > > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #startElement: > bar > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #characters: 3 > 2008-10-30 11:55:17,726 main DEBUG xml.UnmarshalHandler - #endElement: bar > > > We were kind of thinking the choice would somehow be limited to only one > of nested elements. Perhaps we're misusing the maxOccurs? Any insights > greatly appreciated. Thanks in advance. > > - Jeff > > >
Received on Thursday, 30 October 2008 22:14:33 UTC