fix NPE in solr rss where snippet contains only the title text

and adjusted xslt, for solr snippets (&hl=true) to decode the xml encoded html <b> tag by adding disable-output-escaping
(still open item description may be double as dc: tag and rss.description tag)
pull/1/head
reger 11 years ago
parent 09dcdb9b19
commit 1f94df29e7

@ -28,7 +28,7 @@
<xsl:template match='item'> <xsl:template match='item'>
<div class="searchresults"> <div class="searchresults">
<h4 class="linktitle"><a href="{link}" ><xsl:value-of select='title'/></a></h4> <h4 class="linktitle"><a href="{link}" ><xsl:value-of select='title'/></a></h4>
<p class="snippet"><span class="snippetLoaded"><xsl:value-of select='description'/></span></p> <p class="snippet"><span class="snippetLoaded"><xsl:value-of select='description' disable-output-escaping="yes"/></span></p>
<p class="url"><a href="{link}" ><xsl:value-of select='link' /></a></p> <p class="url"><a href="{link}" ><xsl:value-of select='link' /></a></p>
<p class="urlinfo"><xsl:value-of select='pubDate' /></p> <p class="urlinfo"><xsl:value-of select='pubDate' /></p>
</div> </div>

@ -34,7 +34,7 @@
<maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target> <maven.compiler.target>1.7</maven.compiler.target>
<!-- the Solr version used in dependency section for all related dependencies --> <!-- the Solr version used in dependency section for all related dependencies -->
<solr.version>4.8.1</solr.version> <solr.version>4.9.0</solr.version>
<!-- properties used for filtering yacyBuildProperties.java --> <!-- properties used for filtering yacyBuildProperties.java -->
<REPL_DATE>${DSTAMP}</REPL_DATE> <REPL_DATE>${DSTAMP}</REPL_DATE>

@ -239,16 +239,14 @@ public class OpensearchResponseWriter implements QueryResponseWriter {
LinkedHashSet<String> snippet = urlhash == null ? null : snippets.get(urlhash); LinkedHashSet<String> snippet = urlhash == null ? null : snippets.get(urlhash);
String tagname = RSSMessage.Token.description.name(); String tagname = RSSMessage.Token.description.name();
if (snippet == null || snippet.size() == 0) { if (snippet == null || snippet.size() == 0) {
for (String d: descriptions) {
writer.write("<"); writer.write(tagname); writer.write('>'); writer.write("<"); writer.write(tagname); writer.write('>');
for (String d: descriptions) {
XML.escapeCharData(d, writer); XML.escapeCharData(d, writer);
writer.write("</"); writer.write(tagname); writer.write(">\n");
} }
} else {
OpensearchResponseWriter.removeSubsumedTitle(snippet, title);
writer.write("<"); writer.write(tagname); writer.write('>');
XML.escapeCharData(OpensearchResponseWriter.getLargestSnippet(snippet), writer);
writer.write("</"); writer.write(tagname); writer.write(">\n"); writer.write("</"); writer.write(tagname); writer.write(">\n");
} else {
removeSubsumedTitle(snippet, title);
solitaireTag(writer, tagname, getLargestSnippet(snippet)); // snippet may be size=0
} }
// open: where do we get the subject? // open: where do we get the subject?
//solitaireTag(writer, DublinCore.Subject.getURIref(), ""); // TODO: fill with actual data //solitaireTag(writer, DublinCore.Subject.getURIref(), ""); // TODO: fill with actual data

Loading…
Cancel
Save