diff --git a/htroot/IndexControlRWIs_p.java b/htroot/IndexControlRWIs_p.java index 6c06e1e8f..8a5d5caf8 100644 --- a/htroot/IndexControlRWIs_p.java +++ b/htroot/IndexControlRWIs_p.java @@ -61,6 +61,7 @@ import net.yacy.peers.Seed; import net.yacy.repository.Blacklist; import net.yacy.repository.Blacklist.BlacklistType; import net.yacy.search.Switchboard; +import net.yacy.search.SwitchboardConstants; import net.yacy.search.index.Segment; import net.yacy.search.query.QueryGoal; import net.yacy.search.query.QueryModifier; @@ -331,34 +332,38 @@ public class IndexControlRWIs_p { } } - // generate list - if ( post.containsKey("keyhashsimilar") ) { - try { - final Iterator> containerIt = - segment.termIndex().referenceContainer(keyhash, true, false, 256, false).iterator(); - ReferenceContainer container; - - int i = 0, rows = 0, cols = 0; - prop.put("keyhashsimilar", "1"); - while ( containerIt.hasNext() && i < 256 ) { - container = containerIt.next(); - prop.put( - "keyhashsimilar_rows_" + rows + "_cols_" + cols + "_wordHash", - container.getTermHash()); - cols++; - if ( cols == 8 ) { - prop.put("keyhashsimilar_rows_" + rows + "_cols", cols); - cols = 0; - rows++; + // generate list (if RWI connected, otherwise NPE) + if (sb.getConfigBool(SwitchboardConstants.CORE_SERVICE_RWI, true)) { + if ( post.containsKey("keyhashsimilar") ) { + try { + final Iterator> containerIt = + segment.termIndex().referenceContainer(keyhash, true, false, 256, false).iterator(); + ReferenceContainer container; + + int i = 0, rows = 0, cols = 0; + prop.put("keyhashsimilar", "1"); + while ( containerIt.hasNext() && i < 256 ) { + container = containerIt.next(); + prop.put( + "keyhashsimilar_rows_" + rows + "_cols_" + cols + "_wordHash", + container.getTermHash()); + cols++; + if ( cols == 8 ) { + prop.put("keyhashsimilar_rows_" + rows + "_cols", cols); + cols = 0; + rows++; + } + i++; } - i++; + prop.put("keyhashsimilar_rows_" + rows + "_cols", cols); + prop.put("keyhashsimilar_rows", rows + 1); + prop.put("result", ""); + } catch (final IOException e ) { + ConcurrentLog.logException(e); } - prop.put("keyhashsimilar_rows_" + rows + "_cols", cols); - prop.put("keyhashsimilar_rows", rows + 1); - prop.put("result", ""); - } catch (final IOException e ) { - ConcurrentLog.logException(e); } + } else { + prop.put("result", "RWI index not connected (see Index Sources & Targets -> Peer-to-Peer Operation)"); } if ( post.containsKey("blacklist") ) { diff --git a/source/net/yacy/document/Document.java b/source/net/yacy/document/Document.java index a9ced37c6..ed3ec6e5b 100644 --- a/source/net/yacy/document/Document.java +++ b/source/net/yacy/document/Document.java @@ -985,9 +985,11 @@ dc_rights } StringBuilder sb = new StringBuilder(60); sb.append(d.dc_title()); - if (!d.dc_description().equals(d.dc_title()) && sb.length() < Request.descrLength - tagname.length()) { - sb.append(' '); - sb.append(d.dc_description()); + if (d.dc_description().length > 0) { + if (!d.dc_description()[0].equals(d.dc_title()) && sb.length() < Request.descrLength - tagname.length()) { + sb.append(' '); + sb.append(d.dc_description()[0]); + } } if (sb.length() < Request.descrLength - tagname.length()) { sb.append(' ');