[XML-DEV Mailing List Archive Home] [By Thread] [By Date] [Recent Entries] [Reply To This Message]

Re: xsi:type and broken contracts


replace xsi type
amyzing@t... (Amelia A Lewis) writes:

> xsi:type is a scab.
> 
> If the union of instances agrees to a contract (the schema) with management
> (the parser), xsi:type is the badge of the scab.
> 
> For example, suppose that a system is designed such that a few thousand
> licensed franchisees are going to collect some information, which they are
> going to submit (over secured, authenticated links) to a battery of one
> hundred validating servers, which in turn all feed into a single process
> server.  The idea is to offload validation from the main processing server,
> but still have control over the input, to guarantee its correctness.
> 
> Imagine, then, that a portion of the schema which is to be used for
> submission looks like this:
> 
> <xs:element name="registrant" minOccurs="1" maxOccurs="1">
>   <xs:complexContent>
>     <xs:sequence>
>       <xs:element name="personalName" type="xs:string" minOccurs="1"
>         maxOccurs="1" minLength="2" />
>       <xs:element name="familyName" type="xs:string" minOccurs="1"
>         maxOccurs="1" minLength="2" />
>       <!-- more information here, also very strongly typed -->
>     </xs:sequence>
>   </xs:complexContent>
> </xs:element>

<snip/>

> And here's an excerpt from a valid instance:

An invalid instance, see below.

> <registrant xsi:type="xs:string">No information provided</registrant>
> 
> I hope that my understanding is incorrect, and someone can point out that
> one or more of the following are true (or that there is some other saving
> grace somewhere in the system):
> 
> 1) xsi:type must always be a "narrowing cast"

False -- it can extend by adding more, but cannot remove required parts.

> 2) xsi:type cannot replace a complex type with a simple one

False, but only if the complex type is 'mixed' and _all_ its element
content is optional.

> 3) xsi:type overrides can be disabled in the parser

False.

> But I don't think that they are true, which means that validation is
> effectively worthless, because no matter how complex the schema created, I
> can always replace it with:
> 
> <rootElement xsi:type="xs:string">Neener, neener!  Look, ma, I'm
> valid!</rootElement>

Invalid, see above

Hope this helps.

ht
-- 
  Henry S. Thompson, HCRC Language Technology Group, University of Edinburgh
          W3C Fellow 1999--2002, part-time member of W3C Team
     2 Buccleuch Place, Edinburgh EH8 9LW, SCOTLAND -- (44) 131 650-4440
	    Fax: (44) 131 650-4587, e-mail: ht@c...
		     URL: http://www.ltg.ed.ac.uk/~ht/
 [mail really from me _always_ has this .sig -- mail without it is forged spam]

PURCHASE STYLUS STUDIO ONLINE TODAY!

Purchasing Stylus Studio from our online shop is Easy, Secure and Value Priced!

Buy Stylus Studio Now

Download The World's Best XML IDE!

Accelerate XML development with our award-winning XML IDE - Download a free trial today!

Don't miss another message! Subscribe to this list today.
Email
First Name
Last Name
Company
Subscribe in XML format
RSS 2.0
Atom 0.3
 

Stylus Studio has published XML-DEV in RSS and ATOM formats, enabling users to easily subcribe to the list from their preferred news reader application.


Stylus Studio Sponsored Links are added links designed to provide related and additional information to the visitors of this website. they were not included by the author in the initial post. To view the content without the Sponsor Links please click here.

Site Map | Privacy Policy | Terms of Use | Trademarks
Free Stylus Studio XML Training:
W3C Member
Stylus Studio® and DataDirect XQuery ™are products from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2013 All Rights Reserved.