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

org.hibernate.search.spi.BuildContext 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.spi;

import org.hibernate.search.engine.integration.impl.ExtendedSearchIntegrator;
import org.hibernate.search.engine.service.spi.ServiceManager;
import org.hibernate.search.exception.ErrorHandler;
import org.hibernate.search.indexes.impl.IndexManagerHolder;

/**
 * Build context that can be used by some services at initialization.
 *
 * @author Emmanuel Bernard
 * @author Hardy Ferentschik
 */
public interface BuildContext {
	/**
	 * Returns the {@code ExtendedSearchIntegrator} instance. Do not use until after the initialize and/or start method is
	 * fully executed.
	 *
	 * Implementations should not cache values provided by the {@code ExtendedSearchIntegrator}, but rather access them
	 * each time, because the configuration can be dynamically updated and new changes made available.
	 *
	 * For example, prefer:
	 * 
	 * {@code void method() {
	 *   int size = sfi.getDirectoryProviders().size();
	 * }
	 * }
	 * 
* over *
	 * {@code void method() {
	 * int size = directoryProviders.size();
	 * }
	 * }
	 * 
* where directoryProviders is a class variable. * @return the {@link ExtendedSearchIntegrator} instance */ ExtendedSearchIntegrator getUninitializedSearchIntegrator(); /** * @deprecated Scheduled for removal. Use {@link #getIndexingMode()} instead. * @return the indexing strategy */ @Deprecated String getIndexingStrategy(); /** * @return the current indexing strategy as specified via {@link org.hibernate.search.cfg.Environment#INDEXING_STRATEGY}. */ IndexingMode getIndexingMode(); /** * Access the {@code ServiceManager}. * * Clients should keep a reference to the {@code ServiceManager} to allow for cleanup, but should not keep a reference * to the {@code BuildContext}. * * @return the {@link ServiceManager} */ ServiceManager getServiceManager(); /** * @return a reference to the {@code IndexManagerHolder}, storing all {@code IndexManager} instances. */ IndexManagerHolder getAllIndexesManager(); /** * Back-ends processing work asynchronously should catch all eventual errors in the {@code ErrorHandler} * to avoid losing information about the failing index updates. * * @return the configured {@code ErrorHandler} */ ErrorHandler getErrorHandler(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy