All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hibernate.search.analyzer.spi.AnalyzerStrategy Maven / Gradle / Ivy

There is a newer version: 5.11.12.Final
Show newest version
/*
 * 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.spi;

import java.util.Collection;
import java.util.Map;

import org.hibernate.search.annotations.AnalyzerDef;
import org.hibernate.search.annotations.NormalizerDef;

/**
 * A strategy for applying analyzers.
 *
 * @author Gunnar Morling
 * @author Yoann Rodiere
 * @hsearch.experimental This type is under active development as part of the Elasticsearch integration. You
 * should be prepared for incompatible changes in future releases.
 */
public interface AnalyzerStrategy {

	/**
	 * @return a reference to the default analyzer, the one to be used when no specific configuration is set
	 * on a given field.
	 */
	AnalyzerReference createDefaultAnalyzerReference();

	/**
	 * @return a reference to an analyzer that applies no operation whatsoever to the flux.
	 * This is useful for queries operating on non-tokenized fields.
	 */
	AnalyzerReference createPassThroughAnalyzerReference();

	/**
	 * @return a map of named references to provided analyzers, i.e. those that we know for sure will be available.
	 */
	Map createProvidedAnalyzerReferences();

	/**
	 * @param name The name of the analyzer to be referenced.
	 * @return a reference that will be {@link #initializeReferences(Collection, Map, Collection, Map) initialized later}.
	 */
	AnalyzerReference createNamedAnalyzerReference(String name);

	/**
	 * @param analyzerClass The analyzer class the reference should reference.
	 * @return a reference to an instance of the given analyzer class that will be
	 * {@link #initializeReferences(Collection, Map, Collection, Map) initialized later}.
	 */
	AnalyzerReference createLuceneClassAnalyzerReference(Class analyzerClass);

	/**
	 * @return a map of named references to provided normalizers, i.e. those that we know for sure will be available.
	 */
	Map createProvidedNormalizerReferences();

	/**
	 * @param name The name of the normalizer to be referenced.
	 * @return a reference that will be {@link #initializeReferences(Collection, Map, Collection, Map) initialized later}.
	 */
	AnalyzerReference createNamedNormalizerReference(String name);

	/**
	 * @param analyzerClass The analyzer class the reference should reference.
	 * @return a reference to an instance of the given analyzer class that will be
	 * {@link #initializeReferences(Collection, Map, Collection, Map) initialized later}.
	 */
	AnalyzerReference createLuceneClassNormalizerReference(Class analyzerClass);

	/**
	 * Initializes references created by this strategy, i.e. make them point to the actual analyzer/normalizer definition.
	 * @param analyzerReferences The analyzer references to initialize, gathered through calls to methods of this strategy.
	 * @param mappingAnalyzerDefinitions The analyzer definitions gathered through the Hibernate Search mappings.
	 * @param normalizerReferences The normalizer references to initialize, gathered through calls to methods of this strategy.
	 * @param mappingNormalizerDefinitions The normalizer definitions gathered through the Hibernate Search mappings.
	 */
	void initializeReferences(Collection analyzerReferences,
			Map mappingAnalyzerDefinitions,
			Collection normalizerReferences,
			Map mappingNormalizerDefinitions);

	/**
	 * Creates a {@link ScopedAnalyzerReference} builder.
	 * @param initialGlobalAnalyzerReference The global analyzer to set initially on the builder.
	 * @return A {@link ScopedAnalyzerReference} builder. The returned reference will be
	 * {@link #initializeReferences(Collection, Map, Collection, Map) initialized later}.
	 */
	ScopedAnalyzerReference.Builder buildScopedAnalyzerReference(AnalyzerReference initialGlobalAnalyzerReference);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy