[jdom-interest] XOM
Dennis Sosnoski
dms at sosnoski.com
Tue Sep 24 15:14:35 PDT 2002
When do you expect to have a reasonably firm API defined for XOM,
Elliotte? I downloaded 1.0d2 a few days ago and used it to prepare some
code samples for a talk I'm giving this weekend, only to find that the
API has already changed considerably in 1.0d3 (only a few changes, but
they effected about half the lines in my code samples). And by the way,
what does the "d" mean in the versioning?
It'll be interesting to try XOM out more once the API is stable.
Personally I see it as closer to DOM than JDOM in usage, with abstract
base classes used in place of DOM's interfaces. The comotose lists are a
nice simplification, but with the downside that a new list has to be
constructed for every access call (or at least the first one after any
change). The LGPL license also bothers me, since it's considerably more
restrictive than the Apache-style licensing used by JDOM and dom4j. Do
you care to comment on why you chose LGPL?
Thanks,
- Dennis
Elliotte Rusty Harold wrote:
> At 4:56 PM -0400 9/24/02, New, Cecil (GEAE) wrote:
>
>> speaking of JDOM problems... anyone notice the XOM announcement.
>> Reactions?
>
>
> When changing the subject so abruptly, it's nice to change the subject
> line. :-)
>
>> XOM: New tree-based XML API
>> http://xmlhack.com/read.php?item=1783
>>
>> Elliotte Rusty Harold has announced a new tree-based XML API, XOM
>> (from the generic term XML object model), which he describes as
>> "closest in spirit to JDOM" and representing an "effort to synthesize
>> the best features of the existing APIs while eliminating the worst".
>> (Java, Tools: 01:46 21 Sep 2002 UTC)
>>
>
> Well, I was waiting till I had a little more of the documentation
> finished, but here's the semi-official XOM word on the subject:
>
> XOM and JDOM are almost completely separate products. Originally, I had
> thought I could build XOM by forking JDOM, but it quickly became
> apparent that it would be simpler to start over from scratch. XOM does
> use one class from JDOM (Verifier) in its internal, non-public parts.
> This class has been rewritten substantially. The rest of the API is
> completely free of JDOM code.
>
> Conceptually, XOM definitely did adopt a number of ideas from JDOM,
> including:
>
> * Using a SAX parser to build the object model.
> * Using a NodeFactory to support subclasses through the builder.
> * Subclassing SAXSource and SAXResult to support TrAX.
>
> However, XOM also freely borrowed good ideas from DOM, XPath, and other
> systems, and invented not a few new ones of its own. Features in XOM
> that have no real equivalent in JDOM include:
>
> * A common Node superclass
>
> * The getValue method that returns the XPath value of any node.
>
> * The getStringForm method that returns a string containing the XML
> serialization of that node. (JDOM actually did use the toString method
> for this in the first few betas. However, when JDOM decided to use the
> toString method for debugging info instead, they never replaced it with
> another method.)
>
> * Direct node-to-node navigation using getNextSibling,
> getPreviousSibling,
> getParent, and getFirstChild.
>
> * Well-formedness safe subclassing.
>
> There are also many features that JDOM and XOM share, but that are
> implemented very differently in the two APIs:
>
> * In XOM namespaces are just strings. In JDOM namespaces are instances of
> the Namespace class.
>
> * In JDOM, an Element contains a list. In XOM, an Element is a list. This
> makes for very different styles of navigation.
>
> * JDOM exposes lists using the java.util.List class to expose live lists
> of attributes and content. XOM uses comatose, read-only lists
> implemented with custom classes. Unlike standard lists, XOM lists expose
> the types of the nodes they contain. That is, there are separate lists
> for attributes, elements, namespaces, and so forth.
>
> * Internally, JDOM uses a very sophisticated filter list that knows a
> great deal about the types of nodes it contains. However, this
> information is not exposed in the public API. XOM is almost exactly
> backwards from this. Internally, it uses very simple lists that know
> nothing about the types of the things they contain. Externally, however,
> it exposes lists that contain nodes of very specific types.
>
> * JDOM passes prefixes and local parts separately to setter methods. XOM
> expects them to be passed as a single qualified name.
>
> * JDOM supports skipped entity references. XOM requires all entity
> references to be resolved.
>
> * JDOM reports CDATA sections. XOM automatically merges them with their
> surrounding text.
>
> Finally, XOM hews closely to the motto that "Less is more." It
> deliberately eschews the many convenience methods that make the JDOM
> API so cluttered such as
> getChildText/getChildTextTrim/getChildTextNormalize/getText/getTextTrim/getTextNormalize.
>
> If overloaded variants are included, JDOM has nine separate methods for
> reading the text of an element. XOM has one, getValue. If you need to
> trim or normalize the value, you can use the methods of the String class.
>
>> Watch out, Jason's getting philosophical...
>>
>> We've been slowly but steadily increasing the number of protected fields
>> in the input/output classes to the point where nearly the entire
>> internals are exposed. It's one of the things I dislike most about
>
>
> In XOM, I hide much more, and the stuff that is exposed is very
> carefully thought out. This does limit what subclasses can do, but it
> makes for much more robust XML. Preconditions and postconditions are
> enforced on subclasses. If you can sneak malformed XML through XOM,
> even by subclassing, then it's a bug and I will fix it.
More information about the jdom-interest
mailing list