/******************************************************************************* * Copyright (c) 2006-2013 The RCP Company 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: * The RCP Company - initial API and implementation *******************************************************************************/ package com.rcpcompany.uibindings.utils; import com.rcpcompany.uibindings.IDisposable; import com.rcpcompany.uibindings.IManager; import com.rcpcompany.uibindings.internal.utils.ManagerRunnableManager; /** * The manager interface for {@link IManagerRunnable}. * * @author Tonny Madsen, The RCP Company */ public interface IManagerRunnableManager extends IDisposable { /** * Factory for a number of objects including the manager itself. */ final class Factory { private Factory() { } /** * Returns the manager singleton. * * @return the manager */ public static IManagerRunnableManager getManager() { final IManager manager = IManager.Factory.getManager(); IManagerRunnableManager smanager = manager.getService(IManagerRunnableManager.class); if (smanager == null) { smanager = new ManagerRunnableManager(); } return smanager; } } /** * The max time the manager will execute runnables from the run-queue before. */ public static final int MAX_TIME = 50; /** * Queues a {@link IManagerRunnable} or {@link Runnable} to be run at the first possible moment * on the UI event queue of the workbench. * <p> * Each Runnable is keyed by a combination of a type (a <code>String</code>) and an object and * any new addition will replace any older Runnable with the same key. This behavior can be * disabled by using the type <code>null</code>. * <p> * The addition to the run-queue can be canceled with <code>cancelAsyncExec</code>. * <p> * If the runnable is a {@link IManagerRunnable}, the operations on the runnable can be * monitored with {@link IManagerRunnableListener listeners}. * * @param type the type of the runnable or <code>null</code> * @param key the key object * @param runnable the runnable */ void asyncExec(String type, Object key, Runnable runnable); /** * Cancels a previously registered runnable from {@link #asyncExec(String, Object, Runnable)}. * * @param type the type of the runnable or <code>null</code> * @param key the key object */ void cancelAsyncExec(String type, Object key); /** * Returns whether the run-queue of the manager is empty. * * @return <code>true</code> if the queue is empty */ boolean isEmpty(); }