org.hibernate.search.analyzer.impl.LuceneAnalyzerBuilder Maven / Gradle / Ivy
/*
* Hibernate Search, full-text search for your domain model
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.search.analyzer.impl;
import java.io.IOException;
import java.util.Map;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.core.KeywordTokenizer;
import org.apache.lucene.analysis.core.KeywordTokenizerFactory;
import org.apache.lucene.analysis.util.ResourceLoader;
import org.apache.lucene.analysis.util.ResourceLoaderAware;
import org.apache.lucene.util.Version;
import org.apache.lucene.analysis.util.CharFilterFactory;
import org.apache.lucene.analysis.util.TokenFilterFactory;
import org.apache.lucene.analysis.util.TokenizerFactory;
import org.hibernate.search.analyzer.definition.impl.LuceneAnalysisDefinitionRegistry;
import org.hibernate.search.annotations.AnalyzerDef;
import org.hibernate.search.annotations.CharFilterDef;
import org.hibernate.search.annotations.NormalizerDef;
import org.hibernate.search.annotations.Parameter;
import org.hibernate.search.annotations.TokenFilterDef;
import org.hibernate.search.annotations.TokenizerDef;
import org.hibernate.search.backend.impl.lucene.analysis.HibernateSearchNormalizerWrapper;
import org.hibernate.search.cfg.spi.ParameterAnnotationsReader;
import org.hibernate.search.engine.impl.TokenizerChain;
import org.hibernate.search.engine.service.spi.ServiceManager;
import org.hibernate.search.exception.SearchException;
import org.hibernate.search.util.impl.HibernateSearchResourceLoader;
import static org.hibernate.search.util.impl.ClassLoaderHelper.instanceFromClass;
/**
* Instances of this class are used to build Lucene analyzers.
*
* @author Emmanuel Bernard
* @author Hardy Ferentschik
*/
final class LuceneAnalyzerBuilder {
private static final String LUCENE_VERSION_PARAM = "luceneMatchVersion";
private static final Parameter[] EMPTY_PARAMETERS = new Parameter[]{};
private final Version luceneMatchVersion;
private final ResourceLoader resourceLoader;
private final LuceneAnalysisDefinitionRegistry definitionRegistry;
public LuceneAnalyzerBuilder(Version luceneMatchVersion, ServiceManager serviceManager,
LuceneAnalysisDefinitionRegistry definitionRegistry) {
super();
this.luceneMatchVersion = luceneMatchVersion;
this.resourceLoader = new HibernateSearchResourceLoader( serviceManager );
this.definitionRegistry = definitionRegistry;
}
/**
* Build a Lucene {@link Analyzer} for the given analyzer name.
*
* @param name The name of the definition, which should match the name defined in an {@code AnalyzerDef} annotation
* as found in the annotated domain class.
* @return a Lucene {@code Analyzer}
*/
public Analyzer buildAnalyzer(String name) {
AnalyzerDef analyzerDefinition = definitionRegistry.getAnalyzerDefinition( name );
if ( analyzerDefinition == null ) {
throw new SearchException( "Lucene analyzer found with an unknown definition: " + name );
}
try {
return buildAnalyzer( analyzerDefinition );
}
catch (IOException e) {
throw new SearchException( "Could not initialize Analyzer definition " + analyzerDefinition, e );
}
}
/**
* Build a Lucene {@link Analyzer} for the given normalizer name.
*
* @param name The name of the definition, which should match the name defined in a {@code NormalizerDef} annotation
* as found in the annotated domain class.
* @return a Lucene {@code Analyzer} with a {@link KeywordTokenizer}, but otherwise matching the the matching {@link NormalizerDef}.
*/
public Analyzer buildNormalizer(String name) {
NormalizerDef definition = definitionRegistry.getNormalizerDefinition( name );
if ( definition == null ) {
throw new SearchException( "Lucene normalizer found with an unknown definition: " + name );
}
try {
return buildNormalizer( definition );
}
catch (IOException e) {
throw new SearchException( "Could not initialize normalizer definition " + definition, e );
}
}
private Analyzer buildAnalyzer(AnalyzerDef analyzerDef) throws IOException {
TokenizerDef tokenizer = analyzerDef.tokenizer();
TokenizerFactory tokenizerFactory = buildAnalysisComponent(
TokenizerFactory.class, tokenizer.factory(), tokenizer.params() );
return buildAnalyzer( tokenizerFactory, analyzerDef.charFilters(), analyzerDef.filters() );
}
private Analyzer buildNormalizer(NormalizerDef normalizerDef) throws IOException {
TokenizerFactory tokenizerFactory = buildAnalysisComponent( TokenizerFactory.class,
KeywordTokenizerFactory.class, EMPTY_PARAMETERS );
Analyzer normalizer = buildAnalyzer(
tokenizerFactory, normalizerDef.charFilters(), normalizerDef.filters() );
return new HibernateSearchNormalizerWrapper( normalizer, normalizerDef.name() );
}
private Analyzer buildAnalyzer(TokenizerFactory tokenizerFactory,
CharFilterDef[] charFilterDefs, TokenFilterDef[] filterDefs) throws IOException {
final int tokenFiltersLength = filterDefs.length;
TokenFilterFactory[] filters = new TokenFilterFactory[tokenFiltersLength];
for ( int index = 0; index < tokenFiltersLength; index++ ) {
TokenFilterDef filterDef = filterDefs[index];
filters[index] = buildAnalysisComponent( TokenFilterFactory.class,
filterDef.factory(),
filterDef.params() );
}
final int charFiltersLength = charFilterDefs.length;
CharFilterFactory[] charFilters = new CharFilterFactory[charFiltersLength];
for ( int index = 0; index < charFiltersLength; index++ ) {
CharFilterDef charFilterDef = charFilterDefs[index];
charFilters[index] = buildAnalysisComponent( CharFilterFactory.class,
charFilterDef.factory(), charFilterDef.params() );
}
return new TokenizerChain( charFilters, tokenizerFactory, filters );
}
private T buildAnalysisComponent(Class expectedFactoryClass,
Class extends T> factoryClass,
Parameter[] parameters) throws IOException {
final Map tokenMapsOfParameters = getMapOfParameters( parameters, luceneMatchVersion );
T tokenizerFactory = instanceFromClass(
expectedFactoryClass,
factoryClass,
"Tokenizer factory",
tokenMapsOfParameters
);
injectResourceLoader( tokenizerFactory, tokenMapsOfParameters );
return tokenizerFactory;
}
private void injectResourceLoader(Object processor, Map mapOfParameters) throws IOException {
if ( processor instanceof ResourceLoaderAware ) {
( (ResourceLoaderAware) processor ).inform( resourceLoader );
}
}
private static Map getMapOfParameters(Parameter[] params, Version luceneMatchVersion) {
Map mapOfParams = ParameterAnnotationsReader.toNewMutableMap( params );
mapOfParams.put( LUCENE_VERSION_PARAM, luceneMatchVersion.toString() );
return mapOfParams;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy