org.hibernate.search.backend.impl.WorkQueue Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate-search-engine Show documentation
Show all versions of hibernate-search-engine Show documentation
Core of the Object/Lucene mapper, query engine and index management
/*
* 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.backend.impl;
import java.util.List;
import org.hibernate.search.backend.LuceneWork;
import org.hibernate.search.backend.spi.Work;
import org.hibernate.search.engine.integration.impl.ExtendedSearchIntegrator;
import org.hibernate.search.engine.impl.WorkPlan;
import org.hibernate.search.exception.AssertionFailure;
import org.hibernate.search.util.logging.impl.Log;
import org.hibernate.search.util.logging.impl.LoggerFactory;
import java.lang.invoke.MethodHandles;
/**
* @author Emmanuel Bernard
* @author Sanne Grinovero
*/
public class WorkQueue {
private static final Log log = LoggerFactory.make( MethodHandles.lookup() );
private WorkPlan plan;
private List sealedQueue;
//flag indicating if data has been sealed and not modified since
private boolean sealedAndUnchanged;
private final ExtendedSearchIntegrator extendedIntegrator;
public WorkQueue(ExtendedSearchIntegrator extendedIntegrator) {
this.extendedIntegrator = extendedIntegrator;
this.plan = new WorkPlan( extendedIntegrator );
}
public WorkQueue(ExtendedSearchIntegrator extendedIntegrator, WorkPlan plan) {
this.extendedIntegrator = extendedIntegrator;
this.plan = plan;
}
public void add(Work work) {
this.sealedAndUnchanged = false;
plan.addWork( work );
}
public WorkQueue splitQueue() {
if ( log.isTraceEnabled() ) {
log.tracef( "Splitting work queue with %d works", (Integer) plan.size() );
}
WorkQueue subQueue = new WorkQueue( extendedIntegrator, plan );
this.plan = new WorkPlan( extendedIntegrator );
this.sealedAndUnchanged = false;
return subQueue;
}
public List getSealedQueue() {
if ( sealedQueue == null ) {
throw new AssertionFailure( "Access a WorkQueue which has not been sealed" );
}
this.sealedAndUnchanged = false;
return sealedQueue;
}
private void setSealedQueue(List sealedQueue) {
//invalidate the working queue for serializability
/*
* FIXME workaround for flush phase done later
*
* Due to sometimes flush applied after some beforeCompletion phase
* we cannot safely seal the queue, keep it opened as a temporary measure.
* This is not the proper fix unfortunately as we don't optimize the whole work queue but rather two subsets
*
* when the flush ordering is fixed, add the following line
* queue = Collections.EMPTY_LIST;
*/
this.sealedAndUnchanged = true;
this.sealedQueue = sealedQueue;
}
public void clear() {
if ( log.isTraceEnabled() ) {
log.trace( "Clearing current work queue" );
}
plan.clear();
this.sealedAndUnchanged = false;
if ( sealedQueue != null ) {
sealedQueue.clear();
}
}
/**
* Returns an estimate of the to be performed operations
*
* @return the approximate size
*
* @see org.hibernate.search.engine.impl.WorkPlan#size()
*/
public int size() {
return plan.size();
}
/**
* Compiles the work collected so far in an optimal execution plan,
* storing the list of lucene operations to be performed in the sealedQueue.
*/
public void prepareWorkPlan() {
if ( !sealedAndUnchanged ) {
plan.processContainedInAndPrepareExecution();
List luceneWorkPlan = plan.getPlannedLuceneWork();
setSealedQueue( luceneWorkPlan );
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy