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

Structured attributes

  • From: ht@c... (Henry S. Thompson)
  • To: "XML Developers' list" <xml-dev@x...>
  • Date: 02 Mar 2000 22:40:58 +0000

structured attributes
[A moment's thought will lead to realisation that this is displacement 
activity on the part of the XML Schema: Structures editor, who
certainly has better things to do, but I need to get this off my
chest.]

Why not structured attributes in XML?  _Why_ structured attributes?
Well, we all know the comparison between elements and attributes as
they stand:

Elements      Attributes
ordered       unordered
non-unique    unique
structured    unstructured

There are a lot of contexts in which the first two properties of
attributes are desireable, but the third is a serious constraint.

Here's a design sketch for adding structured attributes:

  1) Reserve a family of hitherto unusable names as the names of
  structured attributes: On balnace I favour names with an initial
  full-stop (.), but there are arguments in favour of using an initial
  colon (:) instead;

  2) Use element syntax, at the beginning of all element content, with 
     the following restrictions:
     2a) No attributes on structured attributes;
     2b) Contents is either all structured attributes or all text;
     2c) Order doesn't matter;
     2d) Uniqueness of names among sibling structured _and_, for children of
         elements, vanilla old-style attributes.

Example:

  <person age='49'>
   <.name>
    <.first>Henry</.first>
    <.last>Thompson</.last>
    <.middle>Swift</.middle>
  </.name>
  <children otherParent='p33'>
   . . .
  </children>
 </person>

The constraints above are equivalent to allowing 'attribute' children
to the 'attribute' element in XML Schema, along with making the
attribute name uniqueness constraint cumulative:

 <element name='person'>
  <complexType>
   <attribute name='age' type='integer'/>
   <attribute name='name'>
     <attribute name='first'/>
     <attribute name='middle/>
     <attribute name='last/>
   </attribute>
   <element name='children'>...</children>
  </complexType>
 </element>

Back to my day job :-)

ht
-- 
  Henry S. Thompson, HCRC Language Technology Group, University of Edinburgh
          W3C Fellow 1999--2001, 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/

***************************************************************************
This is xml-dev, the mailing list for XML developers.
To unsubscribe, mailto:majordomo@x...&BODY=unsubscribe%20xml-dev
List archives are available at http://xml.org/archives/xml-dev/
***************************************************************************

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.