Slashdot is powered by your submissions, so send in your scoop

 



Forgot your password?
typodupeerror
Programming Books Media Book Reviews IT Technology

Inside XML 127

Years after the virtues of XML were first extolled (and plenty of uses both front-and-center and behind-the-scenes later), XML still isn't the do-all, be-all wonder we were led to believe. Book reviewing genius chromatic here dissects a book that sounds aimed at intermediate or advanced programmers (of other languages) who want extend their grasp with a greater understanding of the flexibility inherent to XML. How well it succeeds? Well, see what he's got to say about that.

Inside XML
author Steven Holzner
pages 1102
publisher New Riders
rating 7
reviewer chromatic
ISBN 0-7357-1020-1
summary A detailed but uneven treatment of XML and related topics.

The Scoop

People love it, but XML won't save the world. If properly applied, it will improve the transfer of information between different individuals, platforms, and programs. A language that describes languages, XML in the real world has spawned hundreds of applications. In Inside XML, Steven Holzner attempts to make sense of the basic principles and more popular implementations as things stand right now.

What's to Like?

Holzner's caught platform independence fever, and he imparts a healthy sense of respect for W3C standards to his readers. While the current state of XML handling, especially in web browsers, is mediocre at best, he varies platforms when possible. Though most examples use IE on Windows, the author occasionally examines offerings from Mozilla and IBM.

The book's strength is describing a technology. The first five chapters explore XML's essential concepts, including DTDs and schemas, in as good an explanation as you'll find anywhere. Later chapters cover XSL (used to format and to transform documents), XHTML (the successor to HTML), CSS (governing the presentation of XML and XHTML documents) and RDF and CDF (to describe available resources) in sufficient detail. The explanations here are good, with accurate information and plenty of examples.

Java programmers will appreciate the extended descriptions of the DOM and SAX parsing styles. Though the examples themselves are in Java, most concepts translate fairly well to other languages. JavaScript also gets some attention, mostly in the confines of IE5.

What's to Consider?

Though the cover blurb claims otherwise, most programming examples use Java. Perl earns a brief 13-page treatment, while ASP and Java Servlets share just eight pages in the same chapter. Exotic languages like C and C++ are conspicuously absent. A detailed description of the DOM and SAX approaches would benefit everyone, not just Java hackers.

This massive tome could have stood another round of editing. Many examples run up to a page and a half in length when only two to four lines have changed from the previous listing. Other material is arguably filler, such as four and a half pages of JavaScript events supported in IE, or fifteen pages detailing XML DOM objects and associated methods before giving a single example of DOM usage. The publisher could have cut between 100 and 200 pages, instead adding footnotes to authoritative sites.

Worse yet, the book's organization is questionable. After describing the basics of XML, it veers off into a 50-page JavaScript tutorial. Java soon suffers the same fate. These chapters break the flow of subjects, use no XML in their examples, and should be appendices. (They're decent, as far as tutorials go. They just don't belong in the middle of the book.) Readers will have difficulty finding useful reference material mixed in with tutorials.

English majors will also find Holzner's transitions awkward. Logical sections often conclude with a phrase such as "Now I will talk about the topic named in the heading immediately following this sentence." XML is not a serial radio cliffhanger, and most readers can find their way down the page by themselves. It occurs often enough to be distracting.

The Summary

Besides the reservations above, most of the information is solid and usable. Inside XML is at its best when describing technologies instead of how to work with them. Uneven presentation hinders (not hobbles) the book, making it a better introduction than a definitive guide. Though falling short of its claims, cautious readers will learn plenty.

Table of Contents

  1. Essential XML
  2. Creating Well-Formed XML Documents
  3. Valid XML Documents: Creating Document Type Definitions
  4. DTDs: Entities and Attributes
  5. Creating XML Schemas
  6. Understanding JavaScript
  7. Handling XML Documents with JavaScript
  8. XML and Data Binding
  9. Cascading Style Sheets
  10. Understanding Java
  11. Java and the XML DOM
  12. Java and SAX
  13. XSL Transformations
  14. XSL Formatting Objects
  15. XLinks and XPointers
  16. Essential XHTML
  17. XHTML at Work
  18. Resource Description Framework and Channel Definition Format
  19. Vector Markup Language
  20. WML, ASP, JSP, Servlets, and Perl
  1. The XML 1.0 Specification


You can purchase this book at FatBrain.

This discussion has been archived. No new comments can be posted.

Inside XML

Comments Filter:
  • by Anonymous Coward
    Oooo, there's another good one...XML is a great alternative to GUIs and Java properties files! Go XML!!!
  • The bit-stealing line is good, but I'm not sure where you are coming from with the ambiguity comment. Given an encoded data stream and the ASN.1 to decode it you can get back your data structure. No problems. Of course you have (some) choice in how you represent the data when you encode, but that is common (and useful).

    I don't think that the top-down/bottom-up thing is correct. In the case of both XML and ASN.1, certain 'tags' are set aside for unregistered use (PRIVATE tags in ASN.1) and if you use any such tags you need to agree with the person with whom you are exchanging data what format you are using. No difference I can see except the aforementioned 'religious' point of view with respect to the CCITT/ITU/ISO.

    The only (programmatic) advantage I can see that XML could have is that the data describes its own type. BER-encoded data doesn't - you need to know what kind of object to expect.

    However, this has been hobbled in XML by exactly the lack of central control of namespace you mention....I have no idea whose 'Invoice' DTD to use to interpret this object...so I don't see this as a practical advantage.
  • I don't agree that they are totally different domains. Both are ways of encoding a 'useful' set of primitive data types structured and nested to arbitrary complexity.

    Both can encode 'binary' data (is an integer binary? is a jpeg?), but with different levels of efficiency.

    Simple tools exist to dump BER in a very xml-like human readable format *given the ASN.1 definition*. Granted they have been traditionally used for different purposes (XML more text oriented, ASN.1 more 'binary' oriented) but the featureset of the two encoding methods in very similar.
  • Don't agree about the level. Have you seen X.400/X.500? (Last time I looked they weren't available on-line so it is reasonable if the answer is no :-)

    ASN.1 can be (and is) used to represent some very complex objects (an email message with lots of different header type, complicated address, with fourteen different types of attachment, lots of which are themselves structured messages...you get the idea).

    I may be missing something in XML but I don't see that it gives you anything except a "wire protocol" as well. It is a way to serialise an object into a platform-independent format.

    The design choices for the format are different (wordy...good for humans, bad for network transmission) but that seems to be the only difference, technically speaking. [Apart from the (important) fact that an XML object self-describes its type...but this doesn't seem to be that useful in practice because of namespace issues. ASN.1 data types in a given protocol generally deal with this by including some data early on which identifies how to interpret the rest. e.g. an LDAP operation has a 'type').
  • I agree about the human readability.

    I believe that this seemingly-small point is a major reason why early IETF protocols were implemented more easily. It is just so easy to debug SMTP with telnet...debugging an X.400 connection is worlds more difficult.

    However, I have been impressed by ASN.1 'pretty printing' tools which take some BER (and the definition of the ASN.1) and dump it out in a nice human-readable format. This takes away XML's main advantage I can see (apart from the fact that XML is popular and the way of the future that is :-)
  • Well, XML can handle binary data encoded as base64 I believe.

    The 'combination of the two' is what I was alluding to above. I guess that there should be an automatic way of taking an XML DTD and translating to an ASN.1 definition (and vice versa). This would then allow particular objects to be translated between XML and BER.

    Would this be the best of all possible worlds?
  • I do work with XML for a living, but I use Python for my DOM/SAX work. Python 2.0 and 4Suite [4suite.org] are really the best for rapid XML programming. However, most of the documentation for DOM, SAX, and XSLT apply to all implentations . . . I can read the Java examples and can translate that into Python. Granted, they are pretty similiar languages, but this should work for plenty of other programmers working this into their language of choice.

    It is fishy that C and C++ aren't really mentioned, but there really doesn't seem to be much out there for XML-type stuff. Maybe someone here will post the URL's for more info on that.

    Off the Python topic, I just bought ORA's new "XML in a Nutshell". I haven't had a chance to put it through the trenches yet, but it seems to be the best general XML book out there. Which I am glad, because I want to retire Kay's "XSLT Programmer's Reference" in a hurry. What ORA did to sum-up XPATH and XSLT in 200 pages, it took Kay (no lie) 500 pages. And it's the exact same thing!!!!

  • The funny thing is . . .XSLT isn't that hard, once you figure out that how XSLT works with the document. That "how" is very important. Unfortunately, there isn't much out there, bookwise, about XSLT. I would try XSLT: Working with XML and HTML by Fung. Of course, that book wasn't out yet when I needed to bone-up on XSLT, so I had to use the other book that's out - XSLT Programmer's Reference by Michael Kay. It's way, way too detailed to get up and running fast on. And I still hate wading through it to look up something. Also, ORA's new XML in a Nutshell seems to have some promise in a reference for all things XML.

  • But that still doesn't say why you should use XML over just plaintext:

    KEY1="value1"
    KEY2="value2"

    works fine for me. Why XML?

    Geoff
  • Since when was C an "exotic" language?

    Let's face it, not many people are bloody minded enough to write a C or C++ CGI app to produce web pages. OK, it used to happen, but nowadays there are much better alternatives (eg. PERL, PHP, JavaScript).

    I like using C and C++, but to corrupt a famous phrase "a language has to know its limitations", and C is not the most friendly text processing language in the world.
  • Ever hear the phrase "tongue in cheek"?
    Yes, but I wasn't sure whether the reviewers or the commenters tongue was in his/her/each others cheek!
  • Chris, Len, Nick and Dan are okay, but somebody's gotta shut Glanville up.

    Oh, and where's the chapter on the cheerleaders?????
  • Can we have at least a hint of grammar checking/correction for stories? I mean how hard could it be to do a cursory clean up of submissions?

    For example the phrase "(and plenty of uses both front-and-center and behind-the-scenes later)" is damn near impenetrible. As for "How well it succeeds?", well that is best left alone. ;)

    -Shieldwolf
  • I haven't had any trouble with using DOM in the xerces-c library. It's pretty simple, actually, once you set up the parser. We wrote a wrapper to handle all that stuff, and other IO things. My only gripe is that they actually use static variables, and thus need ugly initializers for stuff like their transcoder. If they wanted to write C, they should have. Initializers are what constructors are for.
  • I'm glad somebody said it!

    Xerces is a sweet little library. Xalan is one big honking mess. I can't believe some of the same people wrote both. I hope TrAX will insulate people from all of that nonsense.
    --
    Bush's assertion: there ought to be limits to freedom
  • ASN.1 does what XML doesn't.

    What I mean by that is that XML doesn't represent low-level binary data well. ASN.1 would allow you to represent binary data more easily into an XML document. It is of course platformless (endian-ness/ size of primitives).

    I took a look at it when I was working at a telecoms company, but they still believe ATM is the next big thing! ;)

    I like XML a lot, and have been using XERCES-J to write a source control system. The human readable feature makes XML invaluable.
  • See framemaker and anything adobe-ish really. They LOVE XML. They got a load of Phds at my uni and nearly every one is doing XML related work.
  • <BUTTRICE type="flying"/>
  • I thought it was only the whitespace and well-formedness that was different.

    -Back to the drawing board.

    (Has anyone else noticed their HTML is well-formed since they started using XML?)

  • Ummm... Did you read my post? I did NOT say that there weren't any XML parsers for C/C++. What I said was that there is no COMMON INTERFACE for XML parsers. Very different things.

    If I start using xmlpp and then find that Xerces C++ is faster, better maintained, or has better standards support, can I alter my codebase simply and easily. The answer is 'no.' I would have to go into each and every file, change the class/struct name (or use typedef or #DEFINE ugliness) and change any variation in the function calling conventions or parameters. This may involve completely reworking underlying design decisions for the entire codebase.

    However on Python or Java, for example, I have a static set of interfaces that come directly from the W3C (the Java package org.w3c.dom for example) that would be used in my program. XML parsers in Java that implement this set of interfaces have only their document loading as parser specific. And Sun's JAXP package makes that a non-issue as well.

    Restated: There is no common API for XML in C/C++. There are multiple parsers, but no common set of interfaces. Period.
  • There is no equivalent in C/C++ to org.w3c.dom or XML::Parser. It has basically been MS's COM interfaces, the Xerces parser (which loosly follows the Java API), expat/libxml, etc. One of the advantages of the Java parsers are that they follow indentical interfaces.

    Especially when Sun's Java API for XML Parsing is brought into the mix, you have a realistic way of completely abstracting the parser in current use.

    Why is this important? No parser is perfect. Some have a better memory footprint while others are pure speed demons. No to mention the possibility of a dark horse in the future that blows everything else away (XML Schema or database interaction anyone?).

    As long as this common API is missing in C/C++, where the only thing necessary to update code is a relink (or no relink in the case of COM), C/C++ will continue to be overlooked by the XML community and its requisite publishing contingent.
  • No one says X does everything. Does a gui fairly decently, though. Besides which, X is not a language.


  • by tfb ( 49770 )
    This is just stupid. XML has some seriously significant advantages over SGML, the most obvious one being that you can find the structure of a document without knowing the DTD. In SGML you can't know if:
    <foo><bar></foo>
    parses as
    (foo (bar)) or (foo)(bar)(foo)
    unless you know the DTD. In XML you can. There are lots of other cases like this. Being able to find the structure without knowing the DTD is useful for the same reasons that Lisp's READ function is useful.

    I think XML is hopeless, but it's *much less* hopeless than SGML, which was completely losing.

  • Well, of course, Lisp (or Scheme) syntax really *is* XML, except without so much syntactic baggage -- it's a trivial operation to convert from, say
    (:foo ((:a :x "1") "data"))
    to
    <foo><a x='1'>data</a>&lt/foo>
    and only slightly less trivial to convert back.

    Lisp people tend to get a bit bitter about the reinvention of something they've known about for more than 40 years, but then we like to be bitter.

    As for using Lisp/scheme syntax for doing RPC-type things: yes, we do that too, it works pretty well.

  • (:foo ((:a :x (eval 'bar)) "data")) would depend on what the particular mapping did. Mine (which is really for HTML, but could do XML too) would treat the (eval 'bar) as a form to be evaluated, so you'd get the current dynamic value of BAR. There are other approaches of course.

    Lisp's 40th anniversary was 1998, the only older language in general use is FORTRAN. Of course there has abeen some (quite a lot!) of development over the 43 years.

  • I work for IBM e-business [ibm.com], and I'm currently learning XML for a project. I ordered the requisite round of books, and I'm starting with SAMS' [mcp.com] Teach Yourself XML in 21 Days [mcp.com]. So far it's ok. I had been playing with Xeena from IBM Alphaworks over the last month or two, so I had some idea of what I was getting into.

    The book is a bit too aggressive with the introduction for true beginners, but I hope that once I get through it, the rest of the books will make the introduction clearer. It's a big undertaking.
    --
  • I bought this book a few months ago, and I'm sad to say that I wouldn't buy it again. I couldn't get by the bad grammar, the contrived examples, and the shallow coverage of XSL.

    The author spends far too much time bashing MS on the one hand and then grudgingly acknowledging that IE has the best XML parser available. I'm no MS fanboy, but the hypocrisy made me sick.

    A lot of the content of this book is just repeated drivel. Things like "Here, I'm including an element for item price" [insert simple XML example] "And here, I'm adding the item part number" [insert simple XML example plus one line]

    Bah, sorry to go off on a rant, but save your money and learn this stuff online, or find another book.
  • I heard somewhere that there was this book called "Inside XML". Maybe that would be a good place to start?
  • No, it is a mark up language because you mark up your data using XML. The DTD or schema describes a template by setting rules about the order of tags and the types that they are allowed to contain. The specification does allow a standalone XML document without a DTD or schema.
  • <irony&gt
    But you use XML in your own post: see the <rant&gt tags?
    </irony&gt
  • Since when was C an "exotic" language?

    -Andy
    --
  • It's not actually a markup language, despite the "ML" in XML. It's just a template.
  • >> Sorry, but try adding a field/column to a csv file. All the programs using it would break.
    Now try adding a field/tag to an xml file. Older programs will ignore it, and new ones can use it. <<

    Inserting *anything* into the middle of a flat file is a pain in the butt unless you parse it first.

    BTW, what are other file formats out there:

    SDF, EDI (Edifact, and something else), DIF

    any more?
  • XML is a representation, but SQL is an interface (protocol). You are comparing apples to oranges it seems.

    You could in theory do queries on data stored in XML. (And maybe in practice soon.)
  • Should be:

    "You could in theory do SQL queries on data stored in XML."

    There are other "tree query" languages also.
  • >> you should have just asked them what they wanted to do about it instead of taking matters into your own hands.

    In this case the graphics department skipped town and took the graphics software with them.

    However, does it make sense to have a completely separate style sheet for just that element? (If even possible.) What about the other elements? If they change, then the custom one will not recogonize them.

    (This reminds me of OOP's method granularity problem: how do you override 1/3 of a method?)
  • >> Close the tag like this: </TAG> <<

    You also can have <TAG X="FOO" />

    Where there is no pairing, IIRC.

  • How is a language that is not even Turing Complete going to solve problems better than Turing Complete languages? Template-driven programming almost always falls on it's face when real-world exceptions and funny little rules start to hit. Example:

    Trade magazines often brag about how XML or style sheets "make format changes automatic" by having to only change a
    single place in order to have color or formatting changes propagate automatically throughout an application or web-site.
    Centralizing this information is a good idea, but the template approach (versus say a shared subroutine) has limits.

    For example, I once was building a web-page where the color did not seem to match the colors chosen by the graphics
    department. I verified that it matched using a screen "print" and some color tools. However, it was noticed that the color area
    in question was next to a very dark area, and thus appeared lighter, even though technically it wasn't. I decided to add a
    custom fudge that roughly resembled:

    if pageID=5 and section=6 then
    factor = 0.95 // darkening factor
    red = red * factor
    green = green * factor
    blue = blue * factor
    // or like "red *= factor" in some langs.
    end if
    ....

    However, it was harder to extract and return the color values from the template settings than it would have been if they came
    from "regular" code or SQL tables.
  • ....COBOL was at least Turing Complete.

    (re: "Now you can store your data with 1000% more words than before!")
  • Has anyone else noticed their HTML is well-formed since they started using XML?

    HTML is generally well-formed anyway, because unless you're deliberately using the XHTML doctype, then there's no reason for it to conform to XML well-formedness anyway. Non-XML well-formedness isn't bad, it's just SGML and not XML.

    I switched to authoring XHTML about 18 months ago and have never regretted it. Sometimes it just keeps the code neat, sometimes it's enormously useful (when I want to either read it or write it with XML tools) and it's always consistent with the rest of what I'm authoring.

    Swapping HTML to XHTML is full of pitfalls though. You can't just fix up the structural well-formedness, there's a load of character set and entity issues to fix too, especially if you use a range of character sets or encodings. Running it through Tidy will warn you on many of these, but it doesn't fix them for you automatically.

    BTW - Does Slashdot still ignore <br /> ?
    (If that was on one line, then yes it does)

  • At work, we've used DOM-like trees with SGML for years

    You're lucky then, and you're definitely the exception.

    I went shopping for SGML solutions in '97, and I couldn't afford them. Lots of nice suits, but there were no affordable toolkits and parsers to be had. - and don't mention DSSSL !

    Now XML is everywhere. There's a deployed and working client-side XSLT engine on nearly every desktop (if not web browser) and the cost of building XML apps is peanuts.

    If SGML was such a resounding and widespread success, then where is it all ?

  • In a world of terrible computer books, and XML books being notably worse than usual, this one is at the lower end of the scale.

    The RDF chapter misses the point completely, and given how stable (OK, moribund) the RDF spec was for a long time, it doesn't even have the usual excuses of a fast-changing field.

    Don't buy any books on XML alone. They're all pretty uninspred. Go to xml101.com [xml101.com] or somewhere for a tutorial instead. Download the Microsoft XML SDK [microsoft.com] - even if you're using a non-MS dev platform, it's a damn good desktop DOM & XSLT reference (although you'll need a Windows box to read it).

    The only book worth reading is Michael Kay's XSLT book [amazon.co.uk] from Wrox. You need to know XML pretty well beforehand, but it's a good XSLT tutorial and a decent reference.

  • ASN and XML (and that includes SGML) address different ends of the same problem, although they do overlap hugely.

    ASN is a "wire protocol", and that's all it is. It takes some pretty low-level data typing concepts and describes a serialization for them. It's a very good serialization, and it's robust against a whole range of platform variables, but they just never lift their heads out of the trenches to look over the parapet.

    SGML / XML are pretty low level too, but they're a whole level above ASN. Read the XML Infoset [w3.org] TR -- Can you imagine ASN describing that level of abstraction ? SGML (but not so much XML) let you deal with a bunch of structural issues by use of a DTD -- again, ASN would be left far behind.

  • Steven Holzner also wrote The VB6 Black Book by Coriolis Press (and the Perl Black Book which was reviewd here on /. if I remember rightly). In said VB6 black book Steven says he thinks VB is the best programming language ever. I know because I bought it (sigh - more of an off-white book than a black book). Seems like he's got his fingers in a few pies. Looking over at amazon.com [amazon.com] Steven has written the Java Black Book, The Perl Black Book, The VB6 Black Book, the XHTML Black Book, The HTML Black Book, the C++ Black book, various books on XML, ADO programming with VB, C++, MCSD books, J++ you name it. 55 books in total (some were out of print but I think you get my point). Either this man is
    a) an incredible polymath who never sleeps and writes like a demon
    b)A hack writer who just re-gurgitates the documentation for people too lazy to read it
    c) A pseudonym for a number of other writers
    What do you all think?
  • Communications between servers which should share similar information is nice, I have used it to update databases that are pretty much static from one side of the firewall to the other. WDDX [wddx.org] is usefull for this and its a nice way to get things from one type of server to another (for instance an ASP based webserver to a ColdFusion based web server)

    So as you can see, it has lots of real world uses.

  • Maybe I was not able to make my point clear. While your link to JVMs is a good one, it only covers devices that exist *today*. What if, there is a new device that want to user the services of a server which requires you to use the server's API/SDK/etc. to communicate with it and yet this new device does not need all of what JVM (or WinCE, or PalmOS, etc) has to offer and this device, must this new device make sure and support JVM? The answer, if you are not using XML, is a definite yes.

    With XML, all what the new device will have to support is the XML communication protocol and no more.

    As you can see, it's best for me to do things the way I know is best for my device, not the way the server, *believes* it should be. In order for such a solution to work, communication must be based on data-exchange-protocol, not API/SDK/etc. -- i.e.: programming languages.


    ---------------
    Sig
    abbr.
  • XML is so simple my son (16 months) understands the fundamental rule of XML tags:
    Open, Shut them

    Open, Shut them
    Give a little clap, clap, clap
    Philip Greenspun has a 21 Minute guide to HTML [greenspun.com]; here's the 3 minute guide to XML:
    1. Know HTML? Fine. Forget everything except <, > and /.
    2. There are no predefined tags
      (beyond the initial processing instructions which you'll just copy from a template when you need it)
    3. Open a tag like this: <TAG>
    4. Close the tag like this: </TAG>
    5. Case matters
    6. Group properly -- <A><B>DATA</B></A>
    What else do you need to know? Oh, to be useful, XML must be accompanied by DTDs or (better) XDRs. Find industry-standard ones -- if you roll your own, you either need fiat or luck.

    Now, the truly useful aspects of "XML" have little to do with XML itself. For example, you need to intelligently plan a XSLT for translation and presentation. The W3C DOM is a must for programming. XPATH! SAX... SAX2... oy vey....

  • BTW, in case the little ditty at the beginning left you saying WhatThe? This [google.com] Google search will be helpful...
  • That's true. I also left out the entity-crisis most HTML coders will encounter with XML, but, hey, it's a 3 minute guide! ;-)
  • what do you do with it?

    Umm, you could mark up data using XML making it self describing.

  • 1) XML gives you more than just label-value pairs. XML documents have an implicit heirarchical structure (e.g. parent-child and ancestor). You can use this to group and nest related data.

    2) With the inclusion of DTD's, to enforce a common layout, you can check to see if an XML document will fit your data model and work with your exisitng applications.

    3) Off the shelf parsers (e.g. SAX and DOM) will save you time generating and reading your data sets.

  • I first read Just XML, by John E Simpson, which is a little out of date, but covers the concepts behind XML. Now I'm working through Beginning XML by David Hunter, which is looking pretty good.

    I'm not a professional programmer or computer science student, so I found it helpful to read Just XML to 'get my head round things' before moving onto the more technical book.
  • We are talking about the Internet here, anything that cannot prove itself usefull in a moderate amount of time is doomed. In the case vcrs, cable tv, personal computers, cell phones i don't think people were doubting the usefullness, it's just that the price of the technology that prevented them from aquiring it.
  • Maybe XML should have been called SGML--
  • At work, we've used DOM-like trees with SGML for years. They make a very nice and flexible data structure, with their logical organization. For us, XML has been seen more as a simplification of what we already do, rather than a revolution. As a result, perhaps some of the revolution is happening far below the surface of what people normally see.

  • Sorry, but try adding a field/column to a csv file. All the programs using it would break.

    Now try adding a field/tag to an xml file. Older programs will ignore it, and new ones can use it.

    XML is more flexible and forgiving.
  • I have seen people jump through some high hoops just to say that they used XML in a project. IMHO XML is like the LASER, you know it's cool, but what do you do with it?
  • I think that was part of the critizim of the book, as it was JAVA centric.
  • I agree, XML isn't a magical solution for everything. XML is a plenty useful language, especially when it comes to documents. I'm also keeping my eyes on the possibilities for XHTML. But using it as a message-passing/RPC protocol? Can we say "bloated"? I had this idea of doing message-passing and RPC by connecting to a remote TCP port which drops you into a tiny embedded LISP or Scheme interpreter. You invoke your procedures in a Scheme-form-like syntax, e.g., "(func arg1 arg2 ...)" and it returns the result as an atom or a list. It's cross-platform and it's arguably easier to parse than the angle-bracket-laden XML syntax.
  • Since when was C an "exotic" language?

    Oh, since about 1987 [ioccc.org].

  • ...but only if you
    • open up your data to other patforms, programming languages (not markup languages) and tiers in the enterprise.
    • participate and adhere to a published and accepted DTD (Schema) for the XML data you are generating.
    • choose the right underlying protocol. Unfortunately the prime candidate for the "ideal" protocol for tranporting XML content is causing market segmentation mainly due to the disparity of environments into which XML data is used. SOAP (XML over HTTP) is viable only for a low volume of messages or very high speed networks. XML over IIOP is more efficient but lacks standardization (what does your IDL interface look like). Then you've got other proprietary solutions like MQSeries and other budding standards like XML-RPC which are muddying the waters.
    • Lastly, the cost of marshalling/unmarshalling XML documents using something like the DOM API is prohibitive. I know, I know, you can get your hands dirty by using SAX directly but it is extra work and usually ends up specific to a particular XML document DTD or Schema. JDOM is a decent enough API but is Java only.
    I'm not knocking XML - it a young specification with massive industry support which will hopefully give rise to mature systems. Lets keep those vendors from hijacking either the XML or vertical industry data specifications though. Otherwise you may as well use byte streams - same vendor lock-in but more efficient.
  • This book has served me well.
  • We use XML extensively to get data from remote sites, like movies.com and abcnews.com, and then display that data on wireless devices like web enabled cell phones.

    It was a huge advantage, but not because XML is some amazing breakthrough, no, just because it's a standard meta-syntax. So we can re-use the XML parser on each data source rather than having to write a whole new parser for each data source, which is the way that sort of thing used to go.

    So if MapQuest started offering a new data service that we subscribed to, like driving directions for flying cars, it would be very helpful if they offered the data served from their servers in XML -- just because we are already set up to use XML.

    So the whole magic of XML is just that it's standard and flexible. That makes it highly worthwhile.

    I have my doubts about other XML related subjects like XSL and XHTML, which may not ever get hugely popular. But XML itself is already hugely popular -- behind the scenes where you may never notice it, busily exchanging data with remote servers.

  • This usage predates XML. Many compilers are written this way, in fact. One could just as easily substitute any intermediate format for XML and get the same advantages.

    The main advantage of XML is that it gives you not a common document format (since DTDs differ) but a common syntax, so you can use a common parser. That's a win, but it's not the cure for all the world's problems.
  • [This is on-topic, honest...]

    I don't know if it is just me, but does anyone else here deal with that "interesting" data represenation language "ASN.1" (Abstract Syntax Notation 1) with its associated binary representation BER (Basic Encoding Rules)?

    ASN.1 defines a textual language for the representation of named primitive data types (strings, integers, real numbers, bitstrings, etc), structured ways of grouping them together (sequences, sets, etc).

    BER provides a machine-independent way for these to be represented 'on-the-wire'. These representations are also abritrary-precision and have other cool features.

    Fortunately or unfortunately (depending on your perspective and religion with respect to 'ISO/OSI' standards) ASN.1 never really caught on in the Internet world (SNMP and LDAP permitting).

    However, I see it as playing a very similar role as XML. (Machine-independent representation of arbitrarily complex structured/nested data).

    The main difference is that the BER represenation of ASN.1 is a (somewhat complex) binary format, whereas XML is text-based.

    This is both an advantage and a disadvantage (more compact, harder for humans to read).

    I'm wondering whether it is worth anyone's time writing up a BER XML translator to attack those 'but XML is too verbose' criticisms...
  • I'm glad you took the time to post that comment. Although it is fairly self-evident and completely non-controversial (you could post the same comment, unaltered, about almost any technology story on Slashdot), I guess some idiot had to say it. What would Slashdot be without incisive comments like that? Well put, my friend.

    Maybe I will write a Perl program to post that comment to Slashdot about every article that comes up. I'll call it "first_post.pl" It will do constant HTTP GET's of the webserver, and post that comment right away whenever there is a new article. I will be the first-post king!

  • of course it isn't. No language does EVERYTHING you want it to do as easily as you want it to. You have to put work into it. XML is a useful language just like every other language.

    It really irks me when people say that about "X", each language has something that it does especially well, XML has its place...
  • Several our products use XML as a scripting
    control language, parameter management, and
    report generation. It's not the core technology
    but useful. It is not necessarily the best
    featured way of performing these functions,
    but from a life-cycle maintenance point of view.
    We need things likely to be around for ten years.

  • Well, I'm currently reviewing O'Reilly's Learning XML, but I'd still say that Inside XML still seems to be a better book for beginners. Mainly because you can continue on with this book and increase your knowledge once it teaches you the basics, whereas advanced topics like XPointers and XLinks are pretty lacking in the O'Reilly book. O'Reilly's XML in a Nutshell is good, but if you choose Learning XML, it's pretty much a necessity (if you're into that fancy book learnin') because of Learning XML lack of advanced topics.

    Another book that I'd recommend for beginners just below Inside XML is the second edition of Just XML. It's not as thorough as Inside XML, but it still manages to delve into quite a bit, like XLinks and XPointers (and covers them well for beginners, slowing down for parts that the author knows his readers will have trouble wrapping their heads around). The cool thing about it is the author's very approachable style, which makes for a very quick read (plus, there's a lot of anecdotal fluff that you can skip if you're not up for being amused), and the best part is that throughout the book, you're working toward building a B-movie database. The hands-on approach is nice, as I know a lot of XML newbies are left thinking, "But what can I use this stuff for?" Do make sure that you get the second edition. Again, I've just started Learning XML, but it's not seeming like it'll top either of these two. (Not that I think it's a poor book.)

    Stay away from O'Reilly's XML Pocket Reference. It's too old. In the next month or two, they're coming out with a second edition of it, which I would expect to be a great pickup for the price. Wait 'til then.


    Cheers,

  • It's like the regular HTML, but we now have extra tags like:
    • <TAUNT>
    • <FLYING BUTTRICE>
    • <CHAIRWHIP>

    Uh, scotch that. "flying buttrice" won't fly as a tag name, as one can clearly see from the spec. [w3.org] The BNF (buttrice-naming form) clearly states that whitespace separates a tag name from an (optional) list of attributes or the final ">". Nobody wants a malformed buttrice. ;-)

  • XML does offer great portability of content across devices. IBM uses it to provide content to their website, wap site, bluetooth devices, etc. Using XML, XSL, XSLT, Apache's Coccoon [apache.org], and numerous other additions. The dynamic generation of PDFs is always nice too.
  • I think that one can offer great services processing XML data, but I can't seem to find a whole lot of it. As an example, some online TV guide could provide the information on what's on at what time simply in XML. I could retrieve that, add links to IMDB or whatever... Right now, one would have to download (messy) HTML, which is a pain to parse and likely to change its structure with the next site facelift (of whoever provides it).

    Is there a repository of XML data? A list of links, maybe?
  • There are virtual machines for almost every platform [geocities.com]. Some of them (esp. Kaffe [kaffe.org]) are free _and_ very portable.
  • That's what I should have said, "gives a common syntax".
  • At DMSO [dmso.mil] they are using xml for communication between different model systems. The XML defines a common format. Instead of having to support filters to convert each doc type to each other doc type you just have to be able to convert each to/from xml. If there are 3 doc types, you need 8 filters (3^2) to get to/from each. If you use XML you need 3 filters to get to/from xml. Assuming the filter is 2-way,from/to. If it is one way, to or from only, double the number of filters. This is what xml is really designed for. To get a common document format.

  • Wrox press has a really good book on XSLT, called XSLT, Programmer's Reference. Of course the key to XML is the Apache projects parser and transformer libs over at http://www.apache.org
  • Umm, you could mark up data using XML making it self describing.

    Or don't, since arguably, you're the only person/company that'll ever use that data. Just send the data.

    XML describes the syntax only, not the content. I would argue that the syntax is never the important part of the message. Hence regardless of whether the reader can figure out the syntax of the XML encoded data that describes itself (woo.) your reader would still have to be partial to information about what to do with it.

    Since the bulk of your data is content, and the bulk of what must be done with it cannot be described through XML and syntax descriptions, then the bulk of your work will be writing your reader, and your writer. Whom does it aid in that case that the data is in the almost human unreadable XML format, as opposed to being either more readable or more compact as per your inevitable specifications?

    -Daniel

    don't believe the hype - zootv [U2]

  • Ignoring the minor problem that ASN.1's binary representations are the ugliest thing since Intercal [tuxedo.org] or maybe PGP [ietf.org] and that people who try too hard to steal bits should be locked up in padded rooms, and that in spite of its ugliness it's still offers incompleteness and ambiguity, the important difference between the two standards is that ASN.1 is a top-down centrally-controlled standard where anybody who wants to define an object type has to either negotiate with a committee to get namespace or buy a hunk of private vendor namespace, while XML is decentralized and anybody can define any object type they like that doesn't start with [Xx][Mm][Ll] and propagate the definitions. The good part about centralization is that it's unambiguous, doesn't lead to conflicts, and reduces portability problems, but it's slow, cumbersome, and often not worth the bother (though the slowness and cumbersomeness does encourage you to get the design right before going through the pain of registration.) Decentralized groups who want to do reusable interoperable XML DTDs still have to negotiate namespace with each other, but you can resolve much of that with naming conventions like FooProjectWidget1 instead of just calling your object Widget1, so you only need to discuss with other FooProject makers what kinds of widgets you need.
  • I agree that XML does have some similarities to Unix tab-delimited text files, but I think a better analog is SQL databases - the database is a bunch of tuples, and the database schema is also a bunch of tuples.
  • any XML book that's any larger than a post-it note, to largely be filled with useless information on unrelated topics.

    My "XML Book" is mainly double-sided prints of TR's from the W3C site in a ring-binder. It recently spilled over into a second 2" thick binder. I use all of this stuff on a regular basis - I also have most of it available as off-line webbage on my laptop.

    Do you understand HTML tags

    There's more to it than that. If you said SGML, then you might be closer to it.

    Try this - Is a "naked ampersand" (i.e. not ) valid HTML ? Is it valid XML ? If anyone still reads Usenet, and the webmastering groups, then follow the recent thread in there on just this subject (where I had my butt spanked for getting it wrong). It's not as simple as you think, and it's not all the same as HTML.

  • It saddens me when ever I see people talk about XML as if it is "just a markup language" while this is true, but that is only small part of what XML is "really" about.

    Lets face it. When Java was interdicted, its goal was to have Applet running in your home refrigerator, and toaster to name a few -- this was the basic goal of Java. With the arrival of the browsers, this goal was extended to computers so that you can write your program once and it will run on any computer (the "write once run everywhere" slogan.)

    While the underlying principle of Java is very powerful, achieving it is so hard. The main reason is due to the fact that you will need a JVM, without which the idea of run "everywhere" is useless.

    While for a full fledge PC this is not much of a problem (almost every flavor of an OS out there today has some version of JVM), this is a serious problem for new devices and as well as for companies that want to use Java. Here is why:

    1) In order for Java to run on a new device, a JVM must exits for it.

    2) In order for an existing application to run in a Java environment (using JVM) the application must be re-written in Java

    Sure those issues can be addressed, but doing so you end up by making the new device and the new language "tightly coupled" to Java and JVM. In a client/server environment, this is a limited design such that it means the client part must be bounded to the server part.

    XML frees you from this "tight coupling". All that I need to do is publish my Schema using XML and any application written in any language running on any device can now communicate with my application. So if my application provides a service to process patient record and I publish my API to my server-application via a Schema and XML-SOAP, than the client can get my service by simply adhering to my Schema -- the client can be written in any language and running on any device.

    In short, XML is all about "data exchange protocol" -- the communication between two XML enabled applications is happening at the data-encoding-level. This is the power of XML where an API or SDK based solution can't solve.

    So from now on, stop thinking about XML as "just a markup language" -- XML is a new way for which applications (and soon, components) well start communicating. The future of programming is based on data-communication not API or SDK or a language.

    -- George


    ---------------
    Sig
    abbr.
  • it's not even a language

    I think you mean it is not a programming language.

    XML = eXtensible Markup Language

    It is a language. It has a defined [w3.org] syntax and semantics.

  • Years after the virtues of XML were first extolled XML still isn't the do-all, be-all wonder we were led to believe.

    GNOME [gnome.org] wasn't built in a day.
  • I found several, from MS, Sun, W3C, and others:

    http://www.google.com/search?sourceid=navclient&q= xml+tutorial [google.com]

  • "Those who do not understand ASN.1 are condemned to reinvent it. Badly."
    --SM

    Seriously, after dealing with some of the butt-ugly binary encoding schemes out there, ASN.1 looks pretty darn good.

    As others have pointed out, however, ASN.1 and XML live in totally different domains. ASN.1 is not human-readable, and XML is useless for binary data.


    --
  • However, I don't think we need an 8 foot tall case of books on it at Borders.

    XML Certification Test:

    Question 1: Do you understand HTML tags?
    Answer: Yes.
    Result: You're certified.

    Anyways, you'd have to expect any XML book that's any larger than a post-it note, to largely be filled with useless information on unrelated topics.
  • I'm sure you could print a ream of paper about ANSI. Does that make it complex? No.

    The following are the only reasons I can think of about why somebody would have even one 2" binder on XML.

    They are writing a parser and want it to adhere to the specs.

    They are anal-retentive and absolutely have to know everything about everything or they feel they now nothing.

    They feel they're more professional if they have large binders full of "specs" to make them seem more intelligent to clients/PHBs/co-workers.

    They truly don't understand the simplicity of a given subject and make it more complex than it is.

    Sadly, it's the last bunch that seems to have the most influence and usually end up bastardizing everything they touch into something it should have never been.

    Let's get one thing straight. XML is nothing more than a fucking file format! If you need anything more than a basic structure of the format then you are stupid. If you need a book to tell you absolutely every way to use the format in every language, then you are also the laziest person on the planet. You want to parse an XML file in Perl, spend 3 minutes glancing over the XML::Parser mod. You want to do it for Windows, spend 10 minutes browsing the DOM reference on MSDN. Its so basic, don't try to turn it into something complex so you can impress others.

    If you can't understand it, then you must be a VB programmer probably on your way to upper management. If you would spend the time looking up how "&" is treated and discussing it in newsgroups instead of just putting one in an XML file and parsing it, then you already ARE upper management. Don't forget to mark on your time card, just exactly how much time you spent on research of a single character.

    Just what the world needed...
    ...something so simple, idiots can understand it well enough to make themselves look smarter to other idiots.

  • I'd like to point out that the CFL is much older than the NFL, and is still going strong.

    But I do hope your little XFL thing lasts. I believe that at long last the US soul has been mirrored in sport: a pefect mix of agression, vanity, and reductive dualism that reflects everything that Americans hold dear.

    We thieves, we liars, we vandals, and poets. Networked agents of Cthulhu Borealis.

  • Aside from what the other guy pointed out about your example, XML provides for much more than just simple x=y type data passing. The beauty is in the heirarchies that can be setup to make data passing so much easier.

    What if you're transmitting results from a database query in plain text? With your example, you might say, "put all data for one row on one line." Then what happens if some of the data is multi-line? Well, you have to escape that data somehow.

    With XML you can define a "row", and inside a row you can define a "column", and each value in your columns can have well-defined types.

    So, by all means use

    KEY1="value1"
    KEY2="value2"

    but if you want something more robust for passing data across standard implementations in many languages, use XML.
  • UNIX used to rely on tabular data a lot: that's what awk, grep, cut, paste, and other UNIX programs were designed to deal with. That was a great system, because it allowed you to deal with huge amounts of data on machines with very limited memory.

    The problem with tabular data is that it doesn't let you represent a lot of information in a convenient form: people often do need and want hierarchical/tree-structured data. And tabular data in UNIX isn't self-describing. Configuration files, package descriptions, bibliographic citatinos, etc. all need fairly complex descriptions.

    There are many ways of representing tree structured data. XML wouldn't be my favorite, but it is workable. And XML is getting a fairly complete set of tools for dealing with tree structured data: search, extraction, restructuring, etc.

    With this, maybe the Linux community will pick up some of that old UNIX spirit again. Today, the habit seems to be that when anything needs to get done on Linux, someone writes a big Gnome or command line program in C, or, on a good day, writes a monolithic Perl program. For example, something like "rpmfind" should really just be a collection of a few command line tools: something like the Xerces tools for extracting information, gunzip to uncompress the data, and curl to retrieve information. The same is true for a lot of other Linux applications.

    Oh, if you want to play around with XML, I found some of the Apache Xerces tools at http://xml.apache.org/ [apache.org] to be quite useful. They come in both Java and C++ flavors.

  • by CaseyB ( 1105 ) on Tuesday February 20, 2001 @07:55AM (#417770)
    What happens when there's a " character in value1? What values are valid for KEY2, and how do you check them? How many platforms are you prepared to write code on that can parse your format?

    The idea is that XML spares you the trouble of defining your own file format and managing all the grunt work of data files. It lets you use common parsing, validation, and document manipulation tools.

  • by Anonymous Commando ( 6326 ) on Tuesday February 20, 2001 @08:22AM (#417771)

    Hmmm.... let's try a little something here:

    s/XML/Java/
    Funny... it still sounds right. now let's try:
    s/Java/ActiveX/
    Spooky - sounds like a Microsoft press release. Now, for the grande finale:
    s/ActiveX/SlashDot/
    OK, well maybe that was pushing it just a little...
    ________________________
  • by geophile ( 16995 ) <jao@geophile.cEEEom minus threevowels> on Tuesday February 20, 2001 @07:44AM (#417772) Homepage
    XML is great if you have to specify something of moderate complexity and a GUI is not necessary. Instead of just hacking a parser of some little language invented for some specific purpose, or building the stupid GUI, you can just lay out your data in XML, and then use the SAX parser to deliver the data to your application.

    If you're using Java, then a properties file is a good alternative, but if your data gets too complex, (e.g. repeating fields), XML will be much simpler.

  • by orblee ( 66225 ) on Tuesday February 20, 2001 @08:23AM (#417773)
    The simplicity is an advantage. Yes, on its own XML is a bit pants, but because of its simplicity, many add-in facilities are available. XSLT allows you to turn an XML document into anything (a Postscript Document if you want) and certainly back to SGML if necessary. It is an object-oriented language which some people will hiss at, but it does settle really nicely when coding in most programming languages. Okay, XML isn't ideal for databases (because it is object oriented and most databases aren't - hence why OOP languages work on recordsets and pass SQL as strings to a connection object), however, there are ways around this.

    To me, the main advantage is the fact that it is both machine and human readable. An XML config file is normally instantly understandable and programming languages can manipulate it quite easily without having to worry about CR/LFs and the completely different formats in flat file databases.

    Also, the new XML Schemas allow a fully self-documenting, detailed explanation of what the content of an XML document should contain. You could use a stylesheet to turn the Schemas into DocBook documentation if you so desired. Certainly better than going over your application, taking notes, and writing up the documentation.

    To be honest, although all of here at Slashdot can think that XML hasn't had an effect. MS's .NET is going to be entirely XML based, which is a good thing as it will allow communication with their platform easily. Sun's released ONE, which is just a rebranding name against .NET for Java, but it works now and is being used now. GNOME uses XML heavily and why not? Anyone writing applications can easily read the config files and output of another application and know what to do with it.

    Okay, I've ranted a bit here, sorry, but it isn't just the future, it's the present. Of course, in the UNIX world we'll continue to use flat files and standard non-object oriented databases, but when we want to talk with the rest of the world, we will have a method of doing so now that doesn't involve reverse-engineering and so is a lot quicker to develop.

  • I have been doing XML in Java for over a year, and friends have extensively used it for 3 or 4 years. XML is one of those rare things, like Java, that has synergistic value.

    Prior to XML, we had used our own text based markup language (surprisingly similar to XML except only two levels of hierarchy) since 1989. We (30 year OLTP designers and coders) found it *much easier* to design, develop, debug, comunicate about, and communicate with than prior fixed field non-text formats

    List of Synergies in case of XML (and mostly true with our old approach) include:

    • Use of off the shelf editors to create debug messages.
    • Messages (documents to an XML purist) easy to generate from auxiliary programs for data loading.
    • Logging using the same XML as the original messages, and adding other XML message/subtree types for internal actions, is very easy, and you can use all sorts of available tools to work on the logs.This true for data export logs and debug logs.
    • >b>Use of XML display programs (the best I have used so far includes the dreaded M-word - Microsoft explorer). With Explorer 5.0 and above (and I think 4.0 and above), if you click on a .xml file, it will bring it up "pretty printed". I suspect there are similar tools under Linux but I haven't used them in my Linux work.
    • Synergistic use in programs: if you create an application that uses XML for input and-or output, it is trivial to also use XML for configuration files for that application. Furthermore, you can take the hierarchical DOM data structures and use sub-trees (from the original input message) to pass data to lower levels of your architecture, without having to convert it into instance variables or some other protocol (e.g. RMI, COM or just method calls).
    • Multiple implentations of parser/generator API's. As another post mentioned, in the case of Java, the standardized two API's - DOM and SAX - allow one to pick and choose parsers from a widely available set, and not change any code. This is a powerful feature, letting you use, for example, a parser with strong error handling for test, and then changing it to a parser that is very fast for production. This can be done with a runtime command line argument if you want!

      I would also point out that I have used SAX in some cases and DOMs in another. I had no problem quickly using SAX for message-based uses. It may be harder when using all the features of XML, but not all are needed for most data interchange usages.

  • by graniteMonkey ( 87619 ) on Tuesday February 20, 2001 @07:43AM (#417775)
    Of course you can't think of XML as some sort of godsend. It won't make your children's teeth straighter and whiter. It won't solve world hunger, and it won't create a tax law that is equally fair and acceptable to all.

    It's just a markup language. It's only strengths lie in the fact that 1)it clearly and easily represents heirarchical data and 2)could become a standard way of representing data in many applications.

    If XML finds its way into wide acceptance under certain industries(if it hasn't already), then its strength as a descriptive markup is perfectly valid. It will make business easier if you can unambiguously exchange information, rather than sifting through proprietary annotations or trying to convert a flat ASCII file into [proprietary language of your choice].

    <rant>
    I am sorry to see from the looks of the review that New Riders has gone the way of Sybex and Que, though. As far as books in "pop tech" go, you can usually go by this rule of thumb: thickness is inversely proportional to quality.

    Take two examples: My O'Reilly XML(before the standard) pocketbook, and our Que "Mastering Javascript" Special edition. My O'Reilly book is a scant 107 (small) pages, yet has proven to be a completely invaluable reference. I wouldn't trade it for anything but the next edition of the same book. Back when I was trying to learn Javascript, that freaking Que book wasted more of my time than anything else I've ever read. By the time I needed to know about the syntax for multi-dimensional arrays you could just forget it.
    </rant>
  • by cluge ( 114877 ) on Tuesday February 20, 2001 @07:21AM (#417776) Homepage
    According to many knowledgeable source, XML is my savior. You see, my new coffee machine has an ip address, and because of XML I can now program it to start my coffee before I get up!! People scoff at XML, and say what can it do, well here are some examples for the naw sayers

    • XML will soon be in most household appliances. Imagine not having to update the vacum cleaner OS with hard commands. Now with XML all your appliances have the updates "pushed" to them with XML.
    • XML will be installed into new super sneakers by Nike. It's a proven fact that little Asian girls are the best XML coders in the world. Nike is using this great source of talent to bring us the most technically advanced pair of running shoes.
    • XML can toast your toast on one side!! Toaster manufacturers have for years had to design to different toasters, one for the people that want toast only toasted on one side (Sting's preference) and the rest of the world. Now with XML, set your preference and voilla, toast YOUR way.

      People that explain XML carefully should be revered. These scholars are pointing the way to the future. WHO CARES if the book uses strange English. It is after all a technical document and should be as obfuscated as possible!

      Quote from early car manual (Subaru 360) "if one wish to engage first gear, one is pleased to depress clutch." Who needs clarity in writing and loginc when gems such as this are produced. I'm awaiting my XML update to that great old car

  • by pr0nbot ( 313417 ) on Tuesday February 20, 2001 @07:53AM (#417777)

    Wrok wrote: Of course the key to XML is the Apache projects parser and transformer libs over at http://www.apache.org

    Funnily enough I have been trying to use the Apache code (Xerces-C & Xalan) for 2 weeks with marginal success. It's a huge, sprawling library, abstracted to the point where you can't hope to do more than copy and paste the sample code. Clearly they've been having a lot of fun with the patterns book. E.g. before you even think about performing an XSLT transformation there are around 10 factory/liaison/environment objects that need to be set up, and without a deep knowledge of what each is, you've little choice but to just copy-and-pray.

    Besides, there has to be something iffy about a library that has 3 implementations of a string class...

    *sigh* oh for the days when slim, well-defined libraries were the norm.

  • by tenzig_112 ( 213387 ) on Tuesday February 20, 2001 @08:56AM (#417778) Homepage
    It's like the regular HTML, but we now have extra tags like:
    • <TAUNT>
    • <FLYING BUTTRICE>
    • <CHAIRWHIP>

    Some say that the XML isn't even a real language, that in spite of its proclaimed extensibility, it is "fixed." But I think they're cultural elitists.

    Applications for the XML [ridiculopathy.com]

Suburbia is where the developer bulldozes out the trees, then names the streets after them. -- Bill Vaughn

Working...