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

Re: An incompatible CData idea

  • From: Toby Speight <tms@a...>
  • To: "XML developers' list" <xml-dev@i...>
  • Date: 27 Oct 1997 18:20:05 +0000

cdata sed
-----BEGIN PGP SIGNED MESSAGE-----

David> David G. Durand <URL:mailto:david@d...>

> In article <9710271217.ZM22092@i...>, David
> wrote:

David> It is. CDATA is not legal in XML DTDs at all (mostly because
David> it's rather broken -- any occurence of the "</" delimiters
David> closes the element).

David> Instead, you must use CDATA marked sections:
>>  <![ CDATA [ <contents> to </be> quoted ]]>

David> If you need the ]]> delimiter in the CDATA area, you must
David> escape it via the use of entities.

I thought you couldn't use entities within CDATA marked sections
(since '&' and '&#' are no longer recognised as markup).

IIRC, the only way to write ']]>' in a CDATA section is to re-write it
as two sections, with literal text in between:

>  <![ CDATA [ <contents> to </be> quoted, a literal]]> ]]><![ CDATA
>  [, and more <contents> to </be> quoted.]]>

(although I might choose to write the #PCDATA using entities if it
helps my editor's parenthesis-matching ;-)

If you want to automate this on stuff you're including into XML
source, try this sed incantation:

sed -e 's/]]>/]]>&<![ CDATA [/g'  -e '1s/^/<![ CDATA [/'  -e '$s/$/]]>/'
# I didn't use i (insert) or a (append), since they introduce
# line-breaks :-(

(Using entities may or may not be a better move, depending on one's
assessment of the source material.  It's an inescapable fact that all
included material needs a stage of processing before insertion.  In
fact, the more I think about it, the more dangerous I think CDATA
marked sections are, because they enable one to get away with it
*almost every time*, thus increasing the likelihood of a quick-fix
solution appearing to work despite containing an (obscure) bug.)



-----BEGIN PGP SIGNATURE-----
Version: 2.6.3i
Charset: noconv
Comment: Processed by Mailcrypt 3.4, an Emacs/PGP interface

iQB1AwUBNFTbJedsuUurvcRtAQFu7AL/UScZDEG/GLyff/TTP5H1gKCw3GB+FEZi
XfiSSi6NaktwRu8rgduuo4Lq7otWQDEHgUryGNug6oz19aq9XPMTF0r96MmpgUyL
5PaoW9zzXSRGrJ89+YFnygGdXJRCHjLG
=+UfT
-----END PGP SIGNATURE-----

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.