<ahref="http://maven.apache.org/"title="Built by Maven"class="poweredBy">
<imgclass="poweredBy"alt="Built by Maven"src="./images/logos/maven-feather.png"/>
</a>
</div>
</div>
<divid="bodyColumn">
<divid="contentBox">
<divclass="section">
<h2>What's wrong with other existing RSS parsing libraries?<aname="Whats_wrong_with_other_existing_RSS_parsing_libraries"></a></h2>
<p>Before we started with Rome we've evaluated other Java syndication management libraries to see if they'd fit our criteria. Feel free to update this evaluation if we forgot or mischaracterized your favorite library: this is a wiki after all:-)</p>
<divclass="section">
<h3>Informa<aname="Informa"></a></h3>
<p>The <aclass="externalLink"href="http://informa.sourceforge.net/">Informa: RSS Library for Java</a> which exists since 2002 is too complicated to grasp and use. As of this writing it has <aclass="externalLink"href="http://informa.sourceforge.net/apidocs/de/nava/informa/core/package-summary.html">19 interfaces and 12 marker interfaces</a>. It supports all RSS flavors in input, and only 1.0 and 0.91 in output.</p>
<p>No RSS 2.0 output.</p>
<p>No support for Atom at all.</p>
<p>They have some interesting features such as Hibernate and Castor based database serialization, and JSP taglibs, which are useful paraphernalia for server side application development. This seems to be their main focus of development today.</p>
<p>But we prefer to focus on our ESCAPE design criteria, so that our library does one thing really well: syndication parsing, abstract representation and conversion from/to all formats.</p>
<p>Thus our library will be useful for both client and server side developers.</p>
<p>We will develop the server side add-on later when the basics will be well oiled.</p>
<divclass="section">
<h4>RSS4J<aname="RSS4J"></a></h4>
<p><aclass="externalLink"href="http://www.churchillobjects.com/c/13005.html">RSS4J</a> was released in version 0.92 in april 2002. It did not evolve since then.</p>
<p>The web site explains:</p>
<p><i>This toolkit supports the three most commonly used RSS standards - 0.90 (the original), 0.91 and 1.0. RSS 0.92 and 0.93 are not supported due to the dramatic changes it makes to the format and the fact that 1.0 is already finalized.</i></p>
<p>No need to say more: it seems to be a dead project and doesn't even start to address our requirements.</p></div>
<divclass="section">
<h4>RSS Utilities<aname="RSS_Utilities"></a></h4>
<p><aclass="externalLink"href="http://java.sun.com/developer/technicalArticles/javaserverpages/rss_utilities/">RSS Utilities</a> seems like a one-shot project from Rodrigo Oliveira, released in august 2003. It is a taglib to display RSS in JSPs, and includes a small parser for RSS 0.91, 0.92 and 2.0.</p>
<p>It does not seem to be maintained, does not address RSS 1.0 and Atom.</p>
<p>I would encourage Rodrigo to rewrite his taglibs using Rome as the parser, and eventually to contribute them to Rome.</p></div>
<divclass="section">
<h4>RSSLibJ<aname="RSSLibJ"></a></h4>
<p><aclass="externalLink"href="http://enigmastation.com/rsslibj">RSSLibJ</a> is a full-Java RSS generation and consumption library, primarily centering on generating RSS feeds but able to consume them as well. It's maintained, but undergoing a refactoring to change a rather undesirable dependency.</p>
<p>(This isn't a review - this was added by one of RSSLibJ 's authors.)</p></div>
<divclass="section">
<h4>Sandler<aname="Sandler"></a></h4>
<p>Sandler is yet another parser except that it only supports Atom feeds. I can't say more than that because I haven't used it. And now I won't have to.</p></div>
<divclass="section">
<h4>Conclusion<aname="Conclusion"></a></h4>
<p>These are the only RSS or Syndication management libraries we found in Java when we reviewed what was available and wether it was worth starting a new project. Feel free to add to it if we forgot something.</p></div></div></div>