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

SAX needs from our point of view

  • From: David Megginson <ak117@f...>
  • To: "XML Developers' List" <xml-dev@i...>
  • Date: Thu, 23 Apr 1998 21:03:18 -0400

processing instruction sax
Michael Amster writes:

 > In our case, having embedded XML languages with our own language
 > controlling flow of execution, we have a real need for an accurate
 > reproduction of the XML elements parsed so they can be rewritten
 > correctly.

SAX reports all elements, together with character data, ignorable
whitespace, and processing instructions, so you won't lose anything
there.

 >  Specifically, the issue is important in distinguishing between text and
 > CDATA.  Let me illustrate with a simple example:
 > 
 > <WEIF COND="true">
 > 	<WETHEN>
 > 		<ARBITRARYXML/>
 > 		<![CDATA[
 > 			This is data with &references; which should not be parsed!
 > 		]]>
 > 		<MOREXML>
 > 			This is just text
 > 		</MOREXML>
 > 	</WETHEN>
 > </WEIF>
 > 
 > When this is reported up from a SAX parser, we do not differentiate between
 > text and the CDATA, but let's say that we want to output the subset of
 > arbitrary XML back out from our DOM or other object structure:
 > 
 > 		<ARBITRARYXML/>
 > 			This is data with &references; which should not be parsed!
 > 		<MOREXML>
 > 			This is just text
 > 		</MOREXML>

Your output routine is wrong: it should automatically escape all
instances of '&', '<', and '>':

  <ARBITRARYXML/>
   This is data with &amp;references; which should not be parsed!
  <MOREXML>
   This is just text
  </MOREXML>

or even

  <ARBITRARYXML/>
   This is data with &#x26;references; which should not be parsed!
  <MOREXML>
   This is just text
  </MOREXML>

 > Now you see that the CDATA will have all references made when it is
 > reparsed.  We really do want to preserve CDATA as different from
 > text in SAX.

If there's a semantic attached to your use of CDATA, you should
represent it with an element (which is guaranteed to make it through
processing):

  <listing><![CDATA[
    Here is a listing: 1 < 2
  ]]></listing>

  <listing>
    Here is a listing: 1 &lt; 2
  </listing>

There is no need for general XML processing tools _ever_ to know about
CDATA sections; authoring and repository tools (including tools for
authoring transforms) might want preserve them, but those fall out of
the target audience for SAX level 1.  

Think of the analogy of C: the preprocessor takes care of surface
things like macros and hides them from the compiler, which produces
exactly the same object code for

  #define FOO 1

  printf("%d", FOO + FOO);

and

  printf("%d", 1 + 1);



All the best, and thanks for the comments,


David

-- 
David Megginson                 ak117@f...
Microstar Software Ltd.         dmeggins@m...
      http://home.sprynet.com/sprynet/dmeggins/

xml-dev: A list for W3C XML Developers. To post, mailto:xml-dev@i...
Archived as: http://www.lists.ic.ac.uk/hypermail/xml-dev/
To (un)subscribe, mailto:majordomo@i... the following message;
(un)subscribe xml-dev
To subscribe to the digests, mailto:majordomo@i... the following message;
subscribe xml-dev-digest
List coordinator, Henry Rzepa (mailto:rzepa@i...)


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.