mirror of https://github.com/apache/lucene.git
SOLR-1696 : Deprecate old <highlighting> syntax and move configuration to HighlightComponent
git-svn-id: https://svn.apache.org/repos/asf/lucene/solr/trunk@899572 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
aadfd47c8b
commit
2f81c73035
|
@ -28,6 +28,8 @@ Upgrading from Solr 1.4
|
||||||
|
|
||||||
* Using solr.xml is recommended for single cores also (SOLR-1621)
|
* Using solr.xml is recommended for single cores also (SOLR-1621)
|
||||||
|
|
||||||
|
* Old syntax of <highlighting> is deprecated (SOLR-1696)
|
||||||
|
|
||||||
|
|
||||||
Versions of Major Components
|
Versions of Major Components
|
||||||
---------------------
|
---------------------
|
||||||
|
@ -203,6 +205,8 @@ Other Changes
|
||||||
* SOLR-1588: Removed some very old dead code.
|
* SOLR-1588: Removed some very old dead code.
|
||||||
(Chris A. Mattmann via hossman)
|
(Chris A. Mattmann via hossman)
|
||||||
|
|
||||||
|
* SOLR-1696 : Deprecate old <highlighting> syntax and move configuration to HighlightComponent (noble)
|
||||||
|
|
||||||
Build
|
Build
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -928,7 +928,7 @@
|
||||||
<str name="echoHandler">true</str>
|
<str name="echoHandler">true</str>
|
||||||
</lst>
|
</lst>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<!-- This could most likely be commented out in the "default" case -->
|
<!-- This could most likely be commented out in the "default" case -->
|
||||||
|
@ -964,6 +964,7 @@
|
||||||
<!-- multi-colored tag FragmentsBuilder -->
|
<!-- multi-colored tag FragmentsBuilder -->
|
||||||
<fragmentsBuilder name="colored" class="org.apache.solr.highlight.MultiColoredScoreOrderFragmentsBuilder" default="true"/>
|
<fragmentsBuilder name="colored" class="org.apache.solr.highlight.MultiColoredScoreOrderFragmentsBuilder" default="true"/>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- An example dedup update processor that creates the "id" field on the fly
|
<!-- An example dedup update processor that creates the "id" field on the fly
|
||||||
based on the hash code of some other fields. This example has overwriteDupes
|
based on the hash code of some other fields. This example has overwriteDupes
|
||||||
|
|
|
@ -103,5 +103,6 @@ public class PluginInfo {
|
||||||
for (PluginInfo child : children) if(type.equals(child.type)) result.add(child);
|
for (PluginInfo child : children) if(type.equals(child.type)) result.add(child);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
public static final PluginInfo EMPTY_INFO = new PluginInfo("",Collections.<String,String>emptyMap(), new NamedList(),Collections.<PluginInfo>emptyList());
|
||||||
private static final HashSet<String> NL_TAGS = new HashSet<String>(Arrays.asList("lst","str","int","bool","arr","float","double"));
|
private static final HashSet<String> NL_TAGS = new HashSet<String>(Arrays.asList("lst","str","int","bool","arr","float","double"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -193,7 +193,12 @@ public class SolrConfig extends Config {
|
||||||
loadPluginInfo(IndexDeletionPolicy.class,"mainIndex/deletionPolicy",false, true);
|
loadPluginInfo(IndexDeletionPolicy.class,"mainIndex/deletionPolicy",false, true);
|
||||||
loadPluginInfo(IndexReaderFactory.class,"indexReaderFactory",false, true);
|
loadPluginInfo(IndexReaderFactory.class,"indexReaderFactory",false, true);
|
||||||
loadPluginInfo(UpdateRequestProcessorChain.class,"updateRequestProcessorChain",false, false);
|
loadPluginInfo(UpdateRequestProcessorChain.class,"updateRequestProcessorChain",false, false);
|
||||||
|
|
||||||
|
//TODO deprecated remove it later
|
||||||
loadPluginInfo(SolrHighlighter.class,"highlighting",false, false);
|
loadPluginInfo(SolrHighlighter.class,"highlighting",false, false);
|
||||||
|
if( pluginStore.containsKey( SolrHighlighter.class.getName() ) )
|
||||||
|
log.warn( "Deprecated syntax found. <highlighting/> should move to <searchComponent/>" );
|
||||||
|
|
||||||
updateHandlerInfo = loadUpdatehandlerInfo();
|
updateHandlerInfo = loadUpdatehandlerInfo();
|
||||||
|
|
||||||
Config.log.info("Loaded SolrConfig: " + name);
|
Config.log.info("Loaded SolrConfig: " + name);
|
||||||
|
|
|
@ -96,7 +96,6 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
private final UpdateHandler updateHandler;
|
private final UpdateHandler updateHandler;
|
||||||
private final long startTime;
|
private final long startTime;
|
||||||
private final RequestHandlers reqHandlers;
|
private final RequestHandlers reqHandlers;
|
||||||
private final SolrHighlighter highlighter;
|
|
||||||
private final Map<String,SearchComponent> searchComponents;
|
private final Map<String,SearchComponent> searchComponents;
|
||||||
private final Map<String,UpdateRequestProcessorChain> updateProcessorChains;
|
private final Map<String,UpdateRequestProcessorChain> updateProcessorChains;
|
||||||
private final Map<String, SolrInfoMBean> infoRegistry;
|
private final Map<String, SolrInfoMBean> infoRegistry;
|
||||||
|
@ -463,10 +462,7 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
return createInstance(className, UpdateHandler.class, "Update Handler");
|
return createInstance(className, UpdateHandler.class, "Update Handler");
|
||||||
}
|
}
|
||||||
|
|
||||||
private SolrHighlighter createHighlighter(String className) {
|
|
||||||
return createInstance(className, SolrHighlighter.class, "Highlighter");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the last core initialized. If you are using multiple cores,
|
* @return the last core initialized. If you are using multiple cores,
|
||||||
* this is not a function to use.
|
* this is not a function to use.
|
||||||
|
@ -565,7 +561,6 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
reqHandlers = new RequestHandlers(this);
|
reqHandlers = new RequestHandlers(this);
|
||||||
reqHandlers.initHandlersFromConfig( solrConfig );
|
reqHandlers.initHandlersFromConfig( solrConfig );
|
||||||
|
|
||||||
highlighter = initHighlighter();
|
|
||||||
|
|
||||||
// Handle things that should eventually go away
|
// Handle things that should eventually go away
|
||||||
initDeprecatedSupport();
|
initDeprecatedSupport();
|
||||||
|
@ -615,19 +610,6 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
resourceLoader.inform(infoRegistry);
|
resourceLoader.inform(infoRegistry);
|
||||||
}
|
}
|
||||||
|
|
||||||
private SolrHighlighter initHighlighter() {
|
|
||||||
SolrHighlighter highlighter = null;
|
|
||||||
PluginInfo pluginInfo = solrConfig.getPluginInfo(SolrHighlighter.class.getName());
|
|
||||||
if(pluginInfo != null){
|
|
||||||
highlighter = createInitInstance(pluginInfo,SolrHighlighter.class,null, DefaultSolrHighlighter.class.getName());
|
|
||||||
highlighter.initalize(solrConfig);
|
|
||||||
} else{
|
|
||||||
highlighter = new DefaultSolrHighlighter();
|
|
||||||
highlighter.initalize(solrConfig);
|
|
||||||
}
|
|
||||||
return highlighter;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load the request processors
|
* Load the request processors
|
||||||
|
@ -805,8 +787,10 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
/**
|
/**
|
||||||
* Get the SolrHighlighter
|
* Get the SolrHighlighter
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public SolrHighlighter getHighlighter() {
|
public SolrHighlighter getHighlighter() {
|
||||||
return highlighter;
|
HighlightComponent hl = (HighlightComponent) searchComponents.get(HighlightComponent.COMPONENT_NAME);
|
||||||
|
return hl==null? null: hl.getHighlighter();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -838,10 +822,20 @@ public final class SolrCore implements SolrInfoMBean {
|
||||||
{
|
{
|
||||||
Map<String, SearchComponent> components = new HashMap<String, SearchComponent>();
|
Map<String, SearchComponent> components = new HashMap<String, SearchComponent>();
|
||||||
initPlugins(components,SearchComponent.class);
|
initPlugins(components,SearchComponent.class);
|
||||||
|
for (Map.Entry<String, SearchComponent> e : components.entrySet()) {
|
||||||
|
SearchComponent c = e.getValue();
|
||||||
|
if (c instanceof HighlightComponent) {
|
||||||
|
HighlightComponent hl = (HighlightComponent) c;
|
||||||
|
if(!HighlightComponent.COMPONENT_NAME.equals(e.getKey())){
|
||||||
|
components.put(HighlightComponent.COMPONENT_NAME,hl);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
addIfNotPresent(components,HighlightComponent.COMPONENT_NAME,HighlightComponent.class);
|
||||||
addIfNotPresent(components,QueryComponent.COMPONENT_NAME,QueryComponent.class);
|
addIfNotPresent(components,QueryComponent.COMPONENT_NAME,QueryComponent.class);
|
||||||
addIfNotPresent(components,FacetComponent.COMPONENT_NAME,FacetComponent.class);
|
addIfNotPresent(components,FacetComponent.COMPONENT_NAME,FacetComponent.class);
|
||||||
addIfNotPresent(components,MoreLikeThisComponent.COMPONENT_NAME,MoreLikeThisComponent.class);
|
addIfNotPresent(components,MoreLikeThisComponent.COMPONENT_NAME,MoreLikeThisComponent.class);
|
||||||
addIfNotPresent(components,HighlightComponent.COMPONENT_NAME,HighlightComponent.class);
|
|
||||||
addIfNotPresent(components,StatsComponent.COMPONENT_NAME,StatsComponent.class);
|
addIfNotPresent(components,StatsComponent.COMPONENT_NAME,StatsComponent.class);
|
||||||
addIfNotPresent(components,DebugComponent.COMPONENT_NAME,DebugComponent.class);
|
addIfNotPresent(components,DebugComponent.COMPONENT_NAME,DebugComponent.class);
|
||||||
return components;
|
return components;
|
||||||
|
|
|
@ -25,12 +25,18 @@ import org.apache.solr.common.params.SolrParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.apache.solr.common.util.SimpleOrderedMap;
|
import org.apache.solr.common.util.SimpleOrderedMap;
|
||||||
import org.apache.solr.highlight.SolrHighlighter;
|
import org.apache.solr.highlight.SolrHighlighter;
|
||||||
|
import org.apache.solr.highlight.DefaultSolrHighlighter;
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
|
import org.apache.solr.util.plugin.PluginInfoInitialized;
|
||||||
|
import org.apache.solr.util.plugin.SolrCoreAware;
|
||||||
|
import org.apache.solr.core.PluginInfo;
|
||||||
|
import org.apache.solr.core.SolrCore;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO!
|
* TODO!
|
||||||
|
@ -38,22 +44,44 @@ import java.util.Map;
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
* @since solr 1.3
|
* @since solr 1.3
|
||||||
*/
|
*/
|
||||||
public class HighlightComponent extends SearchComponent
|
public class HighlightComponent extends SearchComponent implements PluginInfoInitialized, SolrCoreAware
|
||||||
{
|
{
|
||||||
public static final String COMPONENT_NAME = "highlight";
|
public static final String COMPONENT_NAME = "highlight";
|
||||||
|
private PluginInfo info = PluginInfo.EMPTY_INFO;
|
||||||
|
private SolrHighlighter highlighter;
|
||||||
|
|
||||||
|
|
||||||
|
public void init(PluginInfo info) {
|
||||||
|
this.info = info;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void prepare(ResponseBuilder rb) throws IOException
|
public void prepare(ResponseBuilder rb) throws IOException {
|
||||||
{
|
|
||||||
SolrHighlighter highlighter = rb.req.getCore().getHighlighter();
|
|
||||||
rb.doHighlights = highlighter.isHighlightingEnabled(rb.req.getParams());
|
rb.doHighlights = highlighter.isHighlightingEnabled(rb.req.getParams());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void inform(SolrCore core) {
|
||||||
|
List<PluginInfo> children = info.getChildren("highlighting");
|
||||||
|
if(children.isEmpty()) {
|
||||||
|
PluginInfo pluginInfo = core.getSolrConfig().getPluginInfo(SolrHighlighter.class.getName()); //TODO deprecated configuration remove later
|
||||||
|
if (pluginInfo != null) {
|
||||||
|
highlighter = core.createInitInstance(pluginInfo, SolrHighlighter.class, null, DefaultSolrHighlighter.class.getName());
|
||||||
|
highlighter.initalize(core.getSolrConfig());
|
||||||
|
} else {
|
||||||
|
DefaultSolrHighlighter defHighlighter = new DefaultSolrHighlighter(core);
|
||||||
|
defHighlighter.init(PluginInfo.EMPTY_INFO);
|
||||||
|
highlighter = defHighlighter;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
highlighter = core.createInitInstance(children.get(0),SolrHighlighter.class,null, DefaultSolrHighlighter.class.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void process(ResponseBuilder rb) throws IOException {
|
public void process(ResponseBuilder rb) throws IOException {
|
||||||
SolrQueryRequest req = rb.req;
|
SolrQueryRequest req = rb.req;
|
||||||
if (rb.doHighlights) {
|
if (rb.doHighlights) {
|
||||||
SolrHighlighter highlighter = req.getCore().getHighlighter();
|
|
||||||
SolrParams params = req.getParams();
|
SolrParams params = req.getParams();
|
||||||
|
|
||||||
String[] defaultHighlightFields; //TODO: get from builder by default?
|
String[] defaultHighlightFields; //TODO: get from builder by default?
|
||||||
|
@ -158,6 +186,9 @@ public class HighlightComponent extends SearchComponent
|
||||||
return nl;
|
return nl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public SolrHighlighter getHighlighter() {
|
||||||
|
return highlighter;
|
||||||
|
}
|
||||||
////////////////////////////////////////////
|
////////////////////////////////////////////
|
||||||
/// SolrInfoMBean
|
/// SolrInfoMBean
|
||||||
////////////////////////////////////////////
|
////////////////////////////////////////////
|
||||||
|
|
|
@ -353,7 +353,7 @@
|
||||||
<str>spellcheck</str>
|
<str>spellcheck</str>
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -376,6 +376,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -362,6 +362,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -384,6 +385,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -378,6 +378,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -400,7 +401,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
<requestDispatcher handleSelect="true" >
|
<requestDispatcher handleSelect="true" >
|
||||||
|
|
|
@ -375,6 +375,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -397,6 +398,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -365,6 +365,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -387,6 +388,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -357,6 +357,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -379,7 +380,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
<requestDispatcher handleSelect="true" >
|
<requestDispatcher handleSelect="true" >
|
||||||
|
|
|
@ -266,6 +266,7 @@
|
||||||
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
||||||
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -288,7 +289,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
<requestDispatcher handleSelect="true" >
|
<requestDispatcher handleSelect="true" >
|
||||||
|
|
|
@ -301,29 +301,30 @@
|
||||||
|
|
||||||
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
||||||
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
|
<highlighting class="org.apache.solr.highlight.DummyHighlighter">
|
||||||
|
<!-- Configure the standard fragmenter -->
|
||||||
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
<lst name="defaults">
|
||||||
|
<int name="hl.fragsize">100</int>
|
||||||
|
</lst>
|
||||||
|
</fragmenter>
|
||||||
|
|
||||||
<highlighting class="org.apache.solr.highlight.DummyHighlighter">
|
<fragmenter name="regex" class="org.apache.solr.highlight.RegexFragmenter">
|
||||||
<!-- Configure the standard fragmenter -->
|
<lst name="defaults">
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<int name="hl.fragsize">70</int>
|
||||||
<lst name="defaults">
|
</lst>
|
||||||
<int name="hl.fragsize">100</int>
|
</fragmenter>
|
||||||
</lst>
|
|
||||||
</fragmenter>
|
<!-- Configure the standard formatter -->
|
||||||
|
<formatter name="html" class="org.apache.solr.highlight.HtmlFormatter" default="true">
|
||||||
<fragmenter name="regex" class="org.apache.solr.highlight.RegexFragmenter">
|
<lst name="defaults">
|
||||||
<lst name="defaults">
|
<str name="hl.simple.pre"><![CDATA[<em>]]></str>
|
||||||
<int name="hl.fragsize">70</int>
|
<str name="hl.simple.post"><![CDATA[</em>]]></str>
|
||||||
</lst>
|
</lst>
|
||||||
</fragmenter>
|
</formatter>
|
||||||
|
</highlighting>
|
||||||
<!-- Configure the standard formatter -->
|
</searchComponent>
|
||||||
<formatter name="html" class="org.apache.solr.highlight.HtmlFormatter" default="true">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="hl.simple.pre"><![CDATA[<em>]]></str>
|
|
||||||
<str name="hl.simple.post"><![CDATA[</em>]]></str>
|
|
||||||
</lst>
|
|
||||||
</formatter>
|
|
||||||
</highlighting>
|
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -397,6 +397,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -419,6 +420,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -266,6 +266,7 @@
|
||||||
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler" />
|
||||||
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy" />
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -288,7 +289,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
<requestDispatcher handleSelect="true" >
|
<requestDispatcher handleSelect="true" >
|
||||||
|
|
|
@ -407,6 +407,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -429,7 +430,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
<requestDispatcher handleSelect="true" >
|
<requestDispatcher handleSelect="true" >
|
||||||
|
|
|
@ -407,6 +407,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -429,6 +430,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -394,6 +394,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -416,6 +417,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -371,6 +371,7 @@
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -393,6 +394,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -396,7 +396,7 @@
|
||||||
<str>tvComponent</str>
|
<str>tvComponent</str>
|
||||||
</arr>
|
</arr>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
||||||
|
@ -427,6 +427,7 @@
|
||||||
|
|
||||||
<fragmentsBuilder name="scoreOrder" class="org.apache.solr.highlight.ScoreOrderFragmentsBuilder" default="true"/>
|
<fragmentsBuilder name="scoreOrder" class="org.apache.solr.highlight.ScoreOrderFragmentsBuilder" default="true"/>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
|
|
||||||
|
|
||||||
<!-- enable streaming for testing... -->
|
<!-- enable streaming for testing... -->
|
||||||
|
|
|
@ -763,6 +763,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</requestHandler>
|
</requestHandler>
|
||||||
|
|
||||||
|
<searchComponent class="solr.HighlightComponent" name="highlight">
|
||||||
<highlighting>
|
<highlighting>
|
||||||
<!-- Configure the standard fragmenter -->
|
<!-- Configure the standard fragmenter -->
|
||||||
<!-- This could most likely be commented out in the "default" case -->
|
<!-- This could most likely be commented out in the "default" case -->
|
||||||
|
@ -792,7 +793,7 @@
|
||||||
</lst>
|
</lst>
|
||||||
</formatter>
|
</formatter>
|
||||||
</highlighting>
|
</highlighting>
|
||||||
|
</searchComponent>
|
||||||
<!-- An example dedup update processor that creates the "id" field on the fly
|
<!-- An example dedup update processor that creates the "id" field on the fly
|
||||||
based on the hash code of some other fields. This example has overwriteDupes
|
based on the hash code of some other fields. This example has overwriteDupes
|
||||||
set to false since we are using the id field as the signatureField and Solr
|
set to false since we are using the id field as the signatureField and Solr
|
||||||
|
|
Loading…
Reference in New Issue