Processing instructions (was XSchema: Sections 5.0 and 5.1)
Paul Prescod
papresco at technologist.com
Fri Sep 25 16:44:54 BST 1998
Michael Kay wrote:
>
> That gives me the opportunity to ask a question that's been
> bugging me for a while.
>
> I'm designing a document type. Is there any circumstance
> when you would advise me to use a Processing Instruction
> rather than an empty element with attributes? I can't think
> of one myself, but I'm sure the XML designers must have had
> something in mind.
Processing instructions are more for the use of people who are NOT
document type designers. Let's say your XML-smart HTTP server has a
replacement function for doing server-side variable includes (e.g. time,
date, last modified). Obviously that function cannot be tied to any
particular document type, because they can't force one document type on
all of their users. So they could specify it as a processing instruction
instead. The PI is "invisible" to DTD validation and thus doesn't
interfere with the doctype.
That was why namespaces originally used processing instructions. They
weren't supposed to interfere with document types (beyond the problems
with the prefixes, etc.). That's also why XML's own declarations are often
processing instructions.
Paul Prescod - http://itrc.uwaterloo.ca/~papresco
How many of the Congresspeople who voted for the CDA do you suppose
also voted to release the report that reads like a borderline por-
nographic dime-store romance written by a Texas preacher's son?
- Keith Dawson, TBTF
http://www.tbtf.com/archive/09-14-98.html
http://www.tbtf.com/resource/hypocrites.html
xml-dev: A list for W3C XML Developers. To post, mailto:xml-dev at ic.ac.uk
Archived as: http://www.lists.ic.ac.uk/hypermail/xml-dev/
To (un)subscribe, mailto:majordomo at ic.ac.uk the following message;
(un)subscribe xml-dev
To subscribe to the digests, mailto:majordomo at ic.ac.uk the following message;
subscribe xml-dev-digest
List coordinator, Henry Rzepa (mailto:rzepa at ic.ac.uk)
More information about the Xml-dev
mailing list