blob: a33374de188d84d8e01e7c5a866f661a4c547941 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013 Ericsson and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Miles Parker (Tasktop Technologies) - initial API and implementation
*******************************************************************************/
package org.eclipse.mylyn.reviews.core.spi.remote;
/**
* Specifies a contract for a service that supports managed execution against remote (or other asynchronous or
* unpredictable) APIs and/or resources.
*
* @author Miles Parker
*/
public abstract class AbstractRemoteService {
/**
* Implementors should invoke the the
* {@link AbstractRemoteConsumer#pull(boolean, org.eclipse.core.runtime.IProgressMonitor)} and
* {@link AbstractRemoteConsumer#applyModel(boolean)} methods for the supplied process in the following well defined
* way. This method is expected to return very quickly and <em>must not block</em> under any circumstances, as it
* must be safely callable from the UI thread. Implementors should support one full cycle of invocation:
* <ol>
* <li>The pull phase of the process is invoked. This invocation must be asynchronous if
* {@link AbstractRemoteConsumer#isAsynchronous()} is true.</li>
* <li>If a failure occurs or a core exception is thrown during the pull phase,
* {@link AbstractRemoteConsumer#notifyDone(org.eclipse.core.runtime.IStatus)} is invoked with the exception.</li>
* <li>Otherwise, when the request process returns, the {@link AbstractRemoteConsumer#applyModel(boolean)} phase of
* the process is invoked. (In the case of the UI implementations, this might occur on the UI thread.)</li>
* <li>If a failure occurs during the create phase, notifyDone may optionally be invoked to report the failure.</li>
* <li>If both phases complete successfully,
* {@link AbstractRemoteConsumer#notifyDone(org.eclipse.core.runtime.IStatus)} is invoked on the process with an OK
* status.</li>
* </ol>
*
* @param process
* The consumer process to execute
* @param force
* Invoke the pull and apply processes even if the relevant APIs indicate that they are not needed.
*/
public abstract void retrieve(final AbstractRemoteConsumer process, boolean force);
/**
* Implementors should invoke the the {@link AbstractRemoteConsumer#push(org.eclipse.core.runtime.IProgressMonitor)}
* and {@link AbstractRemoteConsumer#applyRemote(boolean)} methods for the supplied process in the following well
* defined way. This method is expected to return very quickly and <em>must not block</em> under any circumstances,
* as it must be safely callable from the UI thread. Implementors should support one full cycle of invocation:
* <ol>
* <li>The updateRemote phase of the process is invoked. This method is expected to execute very quickly and
* synchronously. (In the case of the UI implementations, this might occur on the UI thread.)</li>
* <li>The push phase of the process is invoked.</li> This invocation must be asynchronous if
* {@link AbstractRemoteConsumer#isAsynchronous()} is true.</li>
* <li>If a failure occurs or a core exception is thrown during the push phase,
* {@link AbstractRemoteConsumer#notifyDone(org.eclipse.core.runtime.IStatus)} is invoked with the exception.</li>
* <li>If a failure occurs during the create phase, notifyDone may optionally be invoked to report the failure.</li>
* <li>If both phases complete successfully,
* {@link AbstractRemoteConsumer#notifyDone(org.eclipse.core.runtime.IStatus)} is invoked on the process with an OK
* status.</li>
* </ol>
*
* @param process
* The consumer process to execute
* @param force
* Invoke the push and apply processes even if the relevant APIs indicate that they are not needed.
*/
public abstract void send(final AbstractRemoteConsumer process, boolean force);
/**
* Fail fast if we aren't in current model thread.
*/
public abstract void ensureModelThread();
/**
* Supports apply and notification services executed against a specific thread. (For example, the Remote Ui Service
* overrides this to force all model update events to occur on the UI thread, as best EMF practices require.)
*
* @param runnable
* @param block
* true if the model execution should block until complete, false if it can complete in seperate thread
*/
public abstract void modelExec(Runnable runnable, boolean block);
/**
* Supports apply and notification services executed against a specific thread. (For example, the Remote Ui Service
* overrides this to force all model update events to occur on the UI thread, as best EMF practices require.)
*
* @param runnable
*/
public final void modelExec(Runnable runnable) {
modelExec(runnable, true);
}
/**
* Returns true if any consumers are currently being managed.
*
* @return
*/
public abstract boolean isActive();
/**
* Dispose of all resources and listeners used by the service.
*/
public abstract void dispose();
}