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

org.refcodes.jobbus.SimpleJobBus Maven / Gradle / Ivy

// /////////////////////////////////////////////////////////////////////////////
// REFCODES.ORG
// =============================================================================
// This code is copyright (c) by Siegfried Steiner, Munich, Germany, distributed
// on an "AS IS" BASIS WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, and licen-
// sed under the following (see "http://en.wikipedia.org/wiki/Multi-licensing")
// licenses:
// =============================================================================
// GNU General Public License, v3.0 ("http://www.gnu.org/licenses/gpl-3.0.html")
// together with the GPL linking exception applied; as being applied by the GNU
// Classpath ("http://www.gnu.org/software/classpath/license.html")
// =============================================================================
// Apache License, v2.0 ("http://www.apache.org/licenses/TEXT-2.0")
// =============================================================================
// Please contact the copyright holding author(s) of the software artifacts in
// question for licensing issues not being covered by the above listed licenses,
// also regarding commercial licensing models or regarding the compatibility
// with other open source licenses.
// /////////////////////////////////////////////////////////////////////////////

package org.refcodes.jobbus;

import java.io.IOException;
import java.util.function.BiConsumer;
import java.util.function.Consumer;

import org.refcodes.command.Undoable;
import org.refcodes.component.HandleGenerator;

/**
 * The {@link SimpleJobBus} is a ready to use implementation of a composite
 * {@link JobBus} wrapping a {@link JobBusDirectory} (actually a {@link JobBus}
 * is sufficient) and delegating the method calls to the wrapped instances. The
 * {@link JobBusDirectory} is considered to be the master from which multiple
 * {@link JobBus} instances can be derived. In case none {@link JobBusDirectory}
 * is considered to be required, use the empty constructor which creates its
 * internal {@link JobBusDirectory}.
 * 

* In case you want to extend the {@link SimpleJobBus} with setting concrete * parameters for the generic types, please also overwrite the hook method * * @param The context type to use, can by any component, service or POJO. */ public class SimpleJobBus implements JobBus { // ///////////////////////////////////////////////////////////////////////// // VARIABLES: // ///////////////////////////////////////////////////////////////////////// private final JobBus _jobBus; // ///////////////////////////////////////////////////////////////////////// // CONSTRUCTORS: // ///////////////////////////////////////////////////////////////////////// /** * Instantiates the {@link SimpleJobBus} by using the provided * {@link JobBus} to which the method calls are delegated. Usually this * constructor is used when you created a master {@link JobBusDirectory} * from which client {@link JobBus} instances are to be derived. In case you * do not require a master {@link JobBusDirectory}, please use the * constructor {@link #SimpleJobBus(Object)}, which constructs the * {@link JobBus} delegate with the the provided context. * * @param aJobBus The {@link JobBus} to delegate the method calls to. */ public SimpleJobBus( JobBus aJobBus ) { _jobBus = aJobBus; } /** * Instantiates the {@link SimpleJobBus} with the provided context and and a * pre-defined {@link String} objects generating {@link HandleGenerator}. It * is up to you which context (service, * {@link org.refcodes.component.Component}, POJO) you want to provide to a * job ({@link Undoable}) when being executed. * * @param aContext The context which is passed to the job ({@link Undoable}) * instances when being executed. */ public SimpleJobBus( CTX aContext ) { _jobBus = createJobBus( aContext ); } // ///////////////////////////////////////////////////////////////////////// // METHODS: // ///////////////////////////////////////////////////////////////////////// /** * {@inheritDoc} */ @Override public boolean hasHandle( String aHandle ) { return _jobBus.hasHandle( aHandle ); } /** * {@inheritDoc} */ @Override public boolean hasProgress( String aHandle ) { return _jobBus.hasProgress( aHandle ); } /** * {@inheritDoc} */ @Override public boolean hasReset( String aHandle ) { return _jobBus.hasReset( aHandle ); } /** * {@inheritDoc} */ @Override public boolean hasFlush( String aHandle ) { return _jobBus.hasFlush( aHandle ); } /** * {@inheritDoc} */ @Override public float getProgress( String aHandle ) { return _jobBus.getProgress( aHandle ); } /** * {@inheritDoc} */ @Override public Undoable lookupHandle( String aHandle ) { return _jobBus.lookupHandle( aHandle ); } /** * {@inheritDoc} */ @Override public void reset( String aHandle ) { _jobBus.reset( aHandle ); } /** * {@inheritDoc} */ @Override public void flush( String aHandle ) throws IOException { _jobBus.flush( aHandle ); } /** * {@inheritDoc} */ @Override public Undoable removeHandle( String aHandle ) { return _jobBus.removeHandle( aHandle ); } /** * {@inheritDoc} */ @Override public String execute( Undoable aJob ) { return _jobBus.execute( aJob ); } /** * {@inheritDoc} */ @Override public void execute( Undoable aJob, Consumer aResultConsumer ) { _jobBus.execute( aJob, aResultConsumer ); } /** * {@inheritDoc} */ @Override public void execute( Undoable aJob, BiConsumer aResultConsumer ) { _jobBus.execute( aJob, aResultConsumer ); } /** * {@inheritDoc} */ @Override public void waitForExecution( String aHandle ) { _jobBus.waitForExecution( aHandle ); } /** * {@inheritDoc} */ @Override public void waitForExecution( String aHandle, long aTimeoutMillis ) { _jobBus.waitForExecution( aHandle, aTimeoutMillis ); } /** * {@inheritDoc} */ @Override public , RET> RET getResult( JOB aJob ) { return _jobBus.getResult( aJob ); } /** * {@inheritDoc} */ @Override public , RET> RET getResult( JOB aJob, long aTimeoutMillis ) { return _jobBus.getResult( aJob, aTimeoutMillis ); } /** * {@inheritDoc} */ @Override public boolean isExecuted( String aHandle ) { return _jobBus.isExecuted( aHandle ); } /** * {@inheritDoc} */ @Override public boolean hasResult( String aHandle ) { return _jobBus.hasResult( aHandle ); } /** * {@inheritDoc} */ @Override public boolean hasException( String aHandle ) { return _jobBus.hasException( aHandle ); } /** * {@inheritDoc} */ @Override public RET getResult( String aHandle ) { return _jobBus.getResult( aHandle ); } /** * {@inheritDoc} */ @Override public E getException( String aHandle ) { return _jobBus.getException( aHandle ); } // ///////////////////////////////////////////////////////////////////////// // HOOKS: // ///////////////////////////////////////////////////////////////////////// /** * Hook method pre-implemented useful when extending this class. * * @param aContext The context to be passed to the job ({@link Undoable}) * instances when being executed. * * @return The ready to use {@link JobBus}. */ protected JobBus createJobBus( CTX aContext ) { return new SimpleJobBusDirectory( aContext ); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy