mirror of https://github.com/apache/lucene.git
SOLR-7073: renamed PluginRegistry to PluginBag
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1665076 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6364cf7773
commit
8571b92efd
|
@ -107,13 +107,13 @@ public class CoreContainer {
|
||||||
public static final String COLLECTIONS_HANDLER_PATH = "/admin/collections";
|
public static final String COLLECTIONS_HANDLER_PATH = "/admin/collections";
|
||||||
public static final String INFO_HANDLER_PATH = "/admin/info";
|
public static final String INFO_HANDLER_PATH = "/admin/info";
|
||||||
|
|
||||||
private PluginRegistry<SolrRequestHandler> containerHandlers = new PluginRegistry<>(SolrRequestHandler.class, null);
|
private PluginBag<SolrRequestHandler> containerHandlers = new PluginBag<>(SolrRequestHandler.class, null);
|
||||||
|
|
||||||
public SolrRequestHandler getRequestHandler(String path) {
|
public SolrRequestHandler getRequestHandler(String path) {
|
||||||
return RequestHandlerBase.getRequestHandler(path, containerHandlers);
|
return RequestHandlerBase.getRequestHandler(path, containerHandlers);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PluginRegistry<SolrRequestHandler> getRequestHandlers() {
|
public PluginBag<SolrRequestHandler> getRequestHandlers() {
|
||||||
return this.containerHandlers;
|
return this.containerHandlers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,6 @@ import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
import org.apache.lucene.analysis.util.ResourceLoader;
|
import org.apache.lucene.analysis.util.ResourceLoader;
|
||||||
|
@ -42,11 +41,11 @@ public class MemClassLoader extends ClassLoader implements AutoCloseable, Resour
|
||||||
static final Logger log = LoggerFactory.getLogger(MemClassLoader.class);
|
static final Logger log = LoggerFactory.getLogger(MemClassLoader.class);
|
||||||
private boolean allJarsLoaded = false;
|
private boolean allJarsLoaded = false;
|
||||||
private final SolrResourceLoader parentLoader;
|
private final SolrResourceLoader parentLoader;
|
||||||
private List<PluginRegistry.RuntimeLib> libs = new ArrayList<>();
|
private List<PluginBag.RuntimeLib> libs = new ArrayList<>();
|
||||||
private Map<String, Class> classCache = new HashMap<>();
|
private Map<String, Class> classCache = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
public MemClassLoader(List<PluginRegistry.RuntimeLib> libs, SolrResourceLoader resourceLoader) {
|
public MemClassLoader(List<PluginBag.RuntimeLib> libs, SolrResourceLoader resourceLoader) {
|
||||||
this.parentLoader = resourceLoader;
|
this.parentLoader = resourceLoader;
|
||||||
this.libs = libs;
|
this.libs = libs;
|
||||||
}
|
}
|
||||||
|
@ -55,7 +54,7 @@ public class MemClassLoader extends ClassLoader implements AutoCloseable, Resour
|
||||||
public synchronized void loadJars() {
|
public synchronized void loadJars() {
|
||||||
if (allJarsLoaded) return;
|
if (allJarsLoaded) return;
|
||||||
|
|
||||||
for (PluginRegistry.RuntimeLib lib : libs) {
|
for (PluginBag.RuntimeLib lib : libs) {
|
||||||
try {
|
try {
|
||||||
lib.loadJar();
|
lib.loadJar();
|
||||||
} catch (Exception exception) {
|
} catch (Exception exception) {
|
||||||
|
@ -113,7 +112,7 @@ public class MemClassLoader extends ClassLoader implements AutoCloseable, Resour
|
||||||
|
|
||||||
String path = name.replace('.', '/').concat(".class");
|
String path = name.replace('.', '/').concat(".class");
|
||||||
ByteBuffer buf = null;
|
ByteBuffer buf = null;
|
||||||
for (PluginRegistry.RuntimeLib lib : libs) {
|
for (PluginBag.RuntimeLib lib : libs) {
|
||||||
try {
|
try {
|
||||||
buf = lib.getFileContent(path);
|
buf = lib.getFileContent(path);
|
||||||
if (buf != null) {
|
if (buf != null) {
|
||||||
|
@ -130,7 +129,7 @@ public class MemClassLoader extends ClassLoader implements AutoCloseable, Resour
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void close() throws Exception {
|
public void close() throws Exception {
|
||||||
for (PluginRegistry.RuntimeLib lib : libs) {
|
for (PluginBag.RuntimeLib lib : libs) {
|
||||||
try {
|
try {
|
||||||
lib.close();
|
lib.close();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|
|
@ -39,13 +39,11 @@ import org.apache.solr.util.plugin.SolrCoreAware;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import static java.util.Collections.singletonList;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This manages the lifecycle of a set of plugin of the same type .
|
* This manages the lifecycle of a set of plugin of the same type .
|
||||||
*/
|
*/
|
||||||
public class PluginRegistry<T> implements AutoCloseable {
|
public class PluginBag<T> implements AutoCloseable {
|
||||||
public static Logger log = LoggerFactory.getLogger(PluginRegistry.class);
|
public static Logger log = LoggerFactory.getLogger(PluginBag.class);
|
||||||
|
|
||||||
private Map<String, PluginHolder<T>> registry = new HashMap<>();
|
private Map<String, PluginHolder<T>> registry = new HashMap<>();
|
||||||
private Map<String, PluginHolder<T>> immutableRegistry = Collections.unmodifiableMap(registry);
|
private Map<String, PluginHolder<T>> immutableRegistry = Collections.unmodifiableMap(registry);
|
||||||
|
@ -54,7 +52,7 @@ public class PluginRegistry<T> implements AutoCloseable {
|
||||||
private SolrCore core;
|
private SolrCore core;
|
||||||
private SolrConfig.SolrPluginInfo meta;
|
private SolrConfig.SolrPluginInfo meta;
|
||||||
|
|
||||||
public PluginRegistry(Class<T> klass, SolrCore core) {
|
public PluginBag(Class<T> klass, SolrCore core) {
|
||||||
this.core = core;
|
this.core = core;
|
||||||
this.klass = klass;
|
this.klass = klass;
|
||||||
meta = SolrConfig.classVsSolrPluginInfo.get(klass.getName());
|
meta = SolrConfig.classVsSolrPluginInfo.get(klass.getName());
|
|
@ -35,7 +35,7 @@ public final class RequestHandlers {
|
||||||
|
|
||||||
protected final SolrCore core;
|
protected final SolrCore core;
|
||||||
|
|
||||||
final PluginRegistry<SolrRequestHandler> handlers;
|
final PluginBag<SolrRequestHandler> handlers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Trim the trailing '/' if it's there, and convert null to empty string.
|
* Trim the trailing '/' if it's there, and convert null to empty string.
|
||||||
|
@ -57,7 +57,7 @@ public final class RequestHandlers {
|
||||||
|
|
||||||
public RequestHandlers(SolrCore core) {
|
public RequestHandlers(SolrCore core) {
|
||||||
this.core = core;
|
this.core = core;
|
||||||
handlers = new PluginRegistry<>(SolrRequestHandler.class, core);
|
handlers = new PluginBag<>(SolrRequestHandler.class, core);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -88,7 +88,7 @@ public final class RequestHandlers {
|
||||||
/**
|
/**
|
||||||
* Returns an unmodifiable Map containing the registered handlers
|
* Returns an unmodifiable Map containing the registered handlers
|
||||||
*/
|
*/
|
||||||
public PluginRegistry<SolrRequestHandler> getRequestHandlers() {
|
public PluginBag<SolrRequestHandler> getRequestHandlers() {
|
||||||
return handlers;
|
return handlers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ import org.apache.solr.cloud.ZkSolrResourceLoader;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.SolrException.ErrorCode;
|
import org.apache.solr.common.SolrException.ErrorCode;
|
||||||
import org.apache.solr.common.cloud.ZkNodeProps;
|
import org.apache.solr.common.cloud.ZkNodeProps;
|
||||||
import org.apache.solr.common.util.NamedList;
|
|
||||||
import org.apache.solr.handler.component.SearchComponent;
|
import org.apache.solr.handler.component.SearchComponent;
|
||||||
import org.apache.solr.request.SolrRequestHandler;
|
import org.apache.solr.request.SolrRequestHandler;
|
||||||
import org.apache.solr.response.QueryResponseWriter;
|
import org.apache.solr.response.QueryResponseWriter;
|
||||||
|
@ -76,14 +75,11 @@ import java.util.Set;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import static java.util.Collections.unmodifiableMap;
|
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.NAME;
|
|
||||||
import static org.apache.solr.core.SolrConfig.PluginOpts.LAZY;
|
import static org.apache.solr.core.SolrConfig.PluginOpts.LAZY;
|
||||||
import static org.apache.solr.core.SolrConfig.PluginOpts.MULTI_OK;
|
import static org.apache.solr.core.SolrConfig.PluginOpts.MULTI_OK;
|
||||||
import static org.apache.solr.core.SolrConfig.PluginOpts.NOOP;
|
import static org.apache.solr.core.SolrConfig.PluginOpts.NOOP;
|
||||||
import static org.apache.solr.core.SolrConfig.PluginOpts.REQUIRE_CLASS;
|
import static org.apache.solr.core.SolrConfig.PluginOpts.REQUIRE_CLASS;
|
||||||
import static org.apache.solr.core.SolrConfig.PluginOpts.REQUIRE_NAME;
|
import static org.apache.solr.core.SolrConfig.PluginOpts.REQUIRE_NAME;
|
||||||
import static org.apache.solr.schema.FieldType.CLASS_NAME;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -311,7 +307,7 @@ public class SolrConfig extends Config implements MapSerializable{
|
||||||
// and even then -- only if there is a single SpellCheckComponent
|
// and even then -- only if there is a single SpellCheckComponent
|
||||||
// because of queryConverter.setIndexAnalyzer
|
// because of queryConverter.setIndexAnalyzer
|
||||||
.add(new SolrPluginInfo(QueryConverter.class, "queryConverter", REQUIRE_NAME, REQUIRE_CLASS))
|
.add(new SolrPluginInfo(QueryConverter.class, "queryConverter", REQUIRE_NAME, REQUIRE_CLASS))
|
||||||
.add(new SolrPluginInfo(PluginRegistry.RuntimeLib.class, "runtimeLib", REQUIRE_NAME, MULTI_OK))
|
.add(new SolrPluginInfo(PluginBag.RuntimeLib.class, "runtimeLib", REQUIRE_NAME, MULTI_OK))
|
||||||
// this is hackish, since it picks up all SolrEventListeners,
|
// this is hackish, since it picks up all SolrEventListeners,
|
||||||
// regardless of when/how/why they are used (or even if they are
|
// regardless of when/how/why they are used (or even if they are
|
||||||
// declared outside of the appropriate context) but there's no nice
|
// declared outside of the appropriate context) but there's no nice
|
||||||
|
|
|
@ -175,7 +175,7 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
|
|
||||||
private final long startTime;
|
private final long startTime;
|
||||||
private final RequestHandlers reqHandlers;
|
private final RequestHandlers reqHandlers;
|
||||||
private final PluginRegistry<SearchComponent> searchComponents = new PluginRegistry<>(SearchComponent.class, this);
|
private final PluginBag<SearchComponent> searchComponents = new PluginBag<>(SearchComponent.class, this);
|
||||||
private final Map<String,UpdateRequestProcessorChain> updateProcessorChains;
|
private final Map<String,UpdateRequestProcessorChain> updateProcessorChains;
|
||||||
private final Map<String, SolrInfoMBean> infoRegistry;
|
private final Map<String, SolrInfoMBean> infoRegistry;
|
||||||
private IndexDeletionPolicyWrapper solrDelPolicy;
|
private IndexDeletionPolicyWrapper solrDelPolicy;
|
||||||
|
@ -788,7 +788,7 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
directoryFactory = solrCoreState.getDirectoryFactory();
|
directoryFactory = solrCoreState.getDirectoryFactory();
|
||||||
this.isReloaded = true;
|
this.isReloaded = true;
|
||||||
}
|
}
|
||||||
memClassLoader = new MemClassLoader(PluginRegistry.RuntimeLib.getLibObjects(this, solrConfig.getPluginInfos(PluginRegistry.RuntimeLib.class.getName())), getResourceLoader());
|
memClassLoader = new MemClassLoader(PluginBag.RuntimeLib.getLibObjects(this, solrConfig.getPluginInfos(PluginBag.RuntimeLib.class.getName())), getResourceLoader());
|
||||||
initIndex(prev != null);
|
initIndex(prev != null);
|
||||||
|
|
||||||
initWriters();
|
initWriters();
|
||||||
|
@ -1249,7 +1249,7 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
/**
|
/**
|
||||||
* Returns an unmodifiable Map containing the registered handlers
|
* Returns an unmodifiable Map containing the registered handlers
|
||||||
*/
|
*/
|
||||||
public PluginRegistry<SolrRequestHandler> getRequestHandlers() {
|
public PluginBag<SolrRequestHandler> getRequestHandlers() {
|
||||||
return reqHandlers.handlers;
|
return reqHandlers.handlers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1305,7 +1305,7 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
* Accessor for all the Search Components
|
* Accessor for all the Search Components
|
||||||
* @return An unmodifiable Map of Search Components
|
* @return An unmodifiable Map of Search Components
|
||||||
*/
|
*/
|
||||||
public PluginRegistry<SearchComponent> getSearchComponents() {
|
public PluginBag<SearchComponent> getSearchComponents() {
|
||||||
return searchComponents;
|
return searchComponents;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2050,11 +2050,11 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
SolrException.log(log,null,e);
|
SolrException.log(log,null,e);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PluginRegistry<QueryResponseWriter> getResponseWriters() {
|
public PluginBag<QueryResponseWriter> getResponseWriters() {
|
||||||
return responseWriters;
|
return responseWriters;
|
||||||
}
|
}
|
||||||
|
|
||||||
private final PluginRegistry<QueryResponseWriter> responseWriters = new PluginRegistry<>(QueryResponseWriter.class, this);
|
private final PluginBag<QueryResponseWriter> responseWriters = new PluginBag<>(QueryResponseWriter.class, this);
|
||||||
public static final Map<String ,QueryResponseWriter> DEFAULT_RESPONSE_WRITERS ;
|
public static final Map<String ,QueryResponseWriter> DEFAULT_RESPONSE_WRITERS ;
|
||||||
static{
|
static{
|
||||||
HashMap<String, QueryResponseWriter> m= new HashMap<>();
|
HashMap<String, QueryResponseWriter> m= new HashMap<>();
|
||||||
|
@ -2119,15 +2119,15 @@ public final class SolrCore implements SolrInfoMBean, Closeable {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private final PluginRegistry<QParserPlugin> qParserPlugins = new PluginRegistry<>(QParserPlugin.class, this);
|
private final PluginBag<QParserPlugin> qParserPlugins = new PluginBag<>(QParserPlugin.class, this);
|
||||||
|
|
||||||
public QParserPlugin getQueryPlugin(String parserName) {
|
public QParserPlugin getQueryPlugin(String parserName) {
|
||||||
return qParserPlugins.get(parserName);
|
return qParserPlugins.get(parserName);
|
||||||
}
|
}
|
||||||
|
|
||||||
private final PluginRegistry<ValueSourceParser> valueSourceParsers = new PluginRegistry<>(ValueSourceParser.class, this);
|
private final PluginBag<ValueSourceParser> valueSourceParsers = new PluginBag<>(ValueSourceParser.class, this);
|
||||||
|
|
||||||
private final PluginRegistry<TransformerFactory> transformerFactories = new PluginRegistry<>(TransformerFactory.class, this);
|
private final PluginBag<TransformerFactory> transformerFactories = new PluginBag<>(TransformerFactory.class, this);
|
||||||
|
|
||||||
<T> Map<String, T> createInstances(Map<String, Class<? extends T>> map) {
|
<T> Map<String, T> createInstances(Map<String, Class<? extends T>> map) {
|
||||||
Map<String, T> result = new LinkedHashMap<>();
|
Map<String, T> result = new LinkedHashMap<>();
|
||||||
|
|
|
@ -22,7 +22,7 @@ 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.core.PluginInfo;
|
import org.apache.solr.core.PluginInfo;
|
||||||
import org.apache.solr.core.PluginRegistry;
|
import org.apache.solr.core.PluginBag;
|
||||||
import org.apache.solr.core.SolrCore;
|
import org.apache.solr.core.SolrCore;
|
||||||
import org.apache.solr.core.SolrInfoMBean;
|
import org.apache.solr.core.SolrInfoMBean;
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
|
@ -35,7 +35,6 @@ import org.apache.solr.util.stats.Timer;
|
||||||
import org.apache.solr.util.stats.TimerContext;
|
import org.apache.solr.util.stats.TimerContext;
|
||||||
|
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.concurrent.atomic.AtomicLong;
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
import static org.apache.solr.core.RequestParams.USEPARAM;
|
import static org.apache.solr.core.RequestParams.USEPARAM;
|
||||||
|
@ -214,7 +213,7 @@ public abstract class RequestHandlerBase implements SolrRequestHandler, SolrInfo
|
||||||
*
|
*
|
||||||
* This function is thread safe.
|
* This function is thread safe.
|
||||||
*/
|
*/
|
||||||
public static SolrRequestHandler getRequestHandler(String handlerName, PluginRegistry<SolrRequestHandler> reqHandlers) {
|
public static SolrRequestHandler getRequestHandler(String handlerName, PluginBag<SolrRequestHandler> reqHandlers) {
|
||||||
if(handlerName == null) return null;
|
if(handlerName == null) return null;
|
||||||
SolrRequestHandler handler = reqHandlers.get(handlerName);
|
SolrRequestHandler handler = reqHandlers.get(handlerName);
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
|
|
|
@ -22,7 +22,7 @@ import java.io.Writer;
|
||||||
|
|
||||||
import org.apache.solr.common.params.CommonParams;
|
import org.apache.solr.common.params.CommonParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.apache.solr.core.PluginRegistry;
|
import org.apache.solr.core.PluginBag;
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
import org.apache.solr.response.QueryResponseWriter;
|
import org.apache.solr.response.QueryResponseWriter;
|
||||||
import org.apache.solr.response.SolrQueryResponse;
|
import org.apache.solr.response.SolrQueryResponse;
|
||||||
|
@ -91,12 +91,12 @@ public class OutputWriterTest extends SolrTestCaseJ4 {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLazy() {
|
public void testLazy() {
|
||||||
PluginRegistry.PluginHolder<QueryResponseWriter> qrw = h.getCore().getResponseWriters().getRegistry().get("useless");
|
PluginBag.PluginHolder<QueryResponseWriter> qrw = h.getCore().getResponseWriters().getRegistry().get("useless");
|
||||||
assertTrue("Should be a lazy class", qrw instanceof PluginRegistry.LazyPluginHolder);
|
assertTrue("Should be a lazy class", qrw instanceof PluginBag.LazyPluginHolder);
|
||||||
|
|
||||||
qrw = h.getCore().getResponseWriters().getRegistry().get("xml");
|
qrw = h.getCore().getResponseWriters().getRegistry().get("xml");
|
||||||
assertTrue("Should not be a lazy class", qrw.isLoaded());
|
assertTrue("Should not be a lazy class", qrw.isLoaded());
|
||||||
assertTrue("Should not be a lazy class", qrw.getClass() == PluginRegistry.PluginHolder.class);
|
assertTrue("Should not be a lazy class", qrw.getClass() == PluginBag.PluginHolder.class);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class RequestHandlersTest extends SolrTestCaseJ4 {
|
||||||
@Test
|
@Test
|
||||||
public void testLazyLoading() {
|
public void testLazyLoading() {
|
||||||
SolrCore core = h.getCore();
|
SolrCore core = h.getCore();
|
||||||
PluginRegistry.PluginHolder<SolrRequestHandler> handler = core.getRequestHandlers().getRegistry().get("lazy");
|
PluginBag.PluginHolder<SolrRequestHandler> handler = core.getRequestHandlers().getRegistry().get("lazy");
|
||||||
assertFalse(handler.isLoaded());
|
assertFalse(handler.isLoaded());
|
||||||
|
|
||||||
assertU(adoc("id", "42",
|
assertU(adoc("id", "42",
|
||||||
|
|
Loading…
Reference in New Issue