Search in sources :

Example 1 with IndexingDaemonListener

use of org.apache.stanbol.entityhub.indexing.core.impl.IndexingDaemon.IndexingDaemonListener in project stanbol by apache.

the class IndexerImpl method startAndWait.

/**
     * Internally used to start the indexing/post-processing daemons and wait
     * until they have finished.
     * @param activeIndexingDeamons the deamos to start
     */
private void startAndWait(final SortedSet<IndexingDaemon<?, ?>> activeIndexingDeamons) {
    //We need an listener for the IndexingDaemons we are about to start!
    final IndexingDaemonListener listener = new IndexingDaemonListener() {

        @Override
        public void indexingDaemonFinished(IndexingDaemonEventObject indexingDaemonEventObject) {
            //looks like one has finished
            IndexingDaemon<?, ?> indexingDaemon = indexingDaemonEventObject.getSource();
            //handle the finished indexing daemon
            handleFinishedIndexingDaemon(activeIndexingDeamons, indexingDaemon);
            //finally remove the listener
            indexingDaemon.removeIndexingDaemonListener(this);
        }
    };
    //now start the IndexingDaemons in their own Threads
    Set<IndexingDaemon<?, ?>> deamonCopy = new HashSet<IndexingDaemon<?, ?>>(activeIndexingDeamons);
    for (IndexingDaemon<?, ?> deamon : deamonCopy) {
        //add the listener
        deamon.addIndexingDaemonListener(listener);
        // create the thread
        Thread thread = new Thread(deamon);
        //ensure that the JVM can terminate
        thread.setDaemon(true);
        // set the name of the thread
        thread.setName(deamon.getName());
        //start the Thread
        thread.start();
    }
    //now we need to wait until all Threads have finished ...
    while (!activeIndexingDeamons.isEmpty()) {
        synchronized (activeIndexingDeamons) {
            try {
                activeIndexingDeamons.wait();
            } catch (InterruptedException e) {
            //year ... looks like we are done
            }
        }
    }
//done!
}
Also used : IndexingDaemonListener(org.apache.stanbol.entityhub.indexing.core.impl.IndexingDaemon.IndexingDaemonListener) IndexingDaemonEventObject(org.apache.stanbol.entityhub.indexing.core.impl.IndexingDaemon.IndexingDaemonEventObject) HashSet(java.util.HashSet)

Aggregations

HashSet (java.util.HashSet)1 IndexingDaemonEventObject (org.apache.stanbol.entityhub.indexing.core.impl.IndexingDaemon.IndexingDaemonEventObject)1 IndexingDaemonListener (org.apache.stanbol.entityhub.indexing.core.impl.IndexingDaemon.IndexingDaemonListener)1