Mike Champion has a blog post entitled Why
does the world need another XML API? where he writes
One basic question keeps coming up, something like: "We have SAX, DOM,
XmlReader/Writer APIs (and the Java people have a bunch more), we have XSLT, we have
XQuery ... why do you think we need Yet Another XML API?"
...
-
XmlReader / XmlWriter can't go away because XLinq uses them to parse and serialize
between XLinq objects and XML text. Also, while we are making XLinq as streaming-friendly
as possible (see the XStreamingElement class in the CTP release for a taste of where
we are going), we're only aiming at hitting the 80/20 point...
-
DOM can't go away because there are important use cases for API-level interoperability,
most notably in the browser...DOM doesn't make code truly interoperable across implementations
(especially on other languages), but there is enough conceptual similarity that porting
is generally not terribly difficult...
-
XSLT definitely won't go away. The Microsoft XML team was promoting XQuery
as a "better XSLT than XSLT 2.0" a few years ago (before I came, don't hurt me!),
and got set straight by the large and vocal XSLT user community on why this is not
going to fly. While it may be true in some abstract way that XQuery or XLinq might
logically be able to do everything that XSLT does, as a practical matter it won't...
-
XQuery won't go away, at least for its original use case as a database query language.
Microsoft supports a draft of XQuery in SQL Server 2005, contributes to the work of
the XQuery working group at W3C, and will continue to invest in finalizing the XQuery
Recommendation and implementing it in our DBMS..
we believe that the overall LINQ story is going to have a pretty profound impact
on data programmability, and we want to make sure that LINQ has a good story for XML...For
XML users, I see a few really powerful implications:
-
The ability to query data by declaraing the characterics of the result set rather
than imperatively navigating through and filtering out all the data...
-
The ability to join across diverse data sources, be they XML documents, objects,
or DBMS queries
-
The ability to "functionally" reshape data within the same language as the application
is written. XSLT pioneered the functional transformation approach to XML processing,
but it is difficult for many developers to learn and requires a processing pipeline
architecture to combine XSLT transforms with conventional application logic...
This brings back memories of my days on the XML team at Microsoft. We went back and
forth a lot about building the "perfect XML API", the one problem we had was that
there one too many diverse user bases which had different ideas of what was important
to expose in an API. We were always caught between a rock and a hard place when it
came to customer requests for fixing our APIs. To some people (e.g. Microsoft Office)
XML was a markup format for documents while to others (e.g. Windows Communications
Foundation aka Indigo) it was simply a serialization format for programming language
objects. Some of our customers were primarily interested in processing XML in a streaming
fashion (e.g. Biztalk) while others (e.g. Internet Explorer) always worked on in-memory
XML documents. Then there were the teams whose primarily interest was in strongly
typed XML (e.g. SQL Server, ADO.NET) since it would be stored in relational database
columns.
In trying to solve all of these problems with a single set of APIs, we went down the
road of prematurely declaring the death of certain XML APIs and technologies such
as the DOM (see Ode
to the XML DOM) and XSLT (see XSLT
2.0 Sir? or Why
You Won't See XSLT 2.0 or XPath 2.0 in the Next Version of the .NET Framework). At
the end of the day we saw the light and we eventually changed our tune by not deprecating
the System.Xml.XmlDocument
class and by reconsidering whether replacing XSLT with XQuery was the right way
forward.
When I was on the team there was a lot of infatuation with XQuery which
eventually turned to frustration. There were a number of technical and non-technical
reasons for this such as its dependence on W3C
XML Schema which significantly complicated its type system and how long the spec
was taking to become a standard (over
5 years and counting as I write this post). Since then a bunch of folks who were
were enamored with XQuery have taken some of its lessons (e.g. declaritiveness, simple
model for XML generation, etc) and integrated it into a mainstream programming environment
with the XLinq project. XML geeks everywhere should read Erik Meijer's paper, XLinq:
XML Programming Refactored (The Return Of The Monoids), it is a thing of
beauty if angle brackets are your thing. And even better, if you are one you are one
of those that chants rabid slogans like "XML
is the assembly language of Web 2.0", you'll still like XLinq because it
provides a easier and richer level of abstraction for working with XML.
Enjoy.