ISaveablesSource.java :  » IDE-Eclipse » ui-workbench » org » eclipse » ui » Java Open Source

Java Open Source » IDE Eclipse » ui workbench 
ui workbench » org » eclipse » ui » ISaveablesSource.java
/*******************************************************************************
 * Copyright (c) 2006, 2007 IBM Corporation 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:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/

package org.eclipse.ui;

import org.eclipse.ui.part.EditorPart;

/**
 * Represents a source of Saveable objects (units of saveability). Workbench
 * parts that show more than one unit of saveability, or whose units of
 * saveability change over time, should implement this interface in order to
 * provide better integration with workbench facilities like the Save command,
 * prompts to save on part close or shutdown, etc.
 * <p>
 * IMPORTANT: As of 3.2, implementers of <code>ISaveablesSource</code> must
 * satisfy the following conditions:
 * <ul>
 * <li>If ISaveablesSource is implemented by an IWorkbenchPart:
 * <ul>
 * <li>the part must implement <code>ISaveablePart</code></li>
 * <li>if any of its Saveable objects are dirty, the part must return
 * <code>true</code> from {@link ISaveablePart#isDirty()}</li>
 * <li>the part must return <code>true</code> from
 * {@link ISaveablePart#isSaveOnCloseNeeded()} if it is dirty (the default
 * behaviour implemented by {@link EditorPart})</li>
 * <li>the part must not implement {@link ISaveablePart2}</li>
 * </ul>
 * </li>
 * <li>If ISaveablesSource is implemented by a non-part (possible as of 3.2.1 and 3.3):
 * <ul>
 * <li>the Workbench's {@link ISaveablesLifecycleListener} (obtained from the
 * Workbench by calling
 * <code>workbench.getService(ISaveablesLifecycleListener.class)</code>) must
 * be notified of any change to the result of {@link #getSaveables()} </li>
 * <li>getActiveSaveables() should be implemented to return an empty array
 * </li>
 * </ul>
 * </ul>
 * If any of these conditions are not met, it is undefined whether the Workbench
 * will prompt to save dirty Saveables when closing parts or the Workbench.
 * </p>
 * <p>
 * These conditions may be relaxed in future releases.
 * </p>
 * 
 * @since 3.2
 */
public interface ISaveablesSource {

  /**
   * Returns the saveables presented by the workbench part. If the return
   * value of this method changes during the lifetime of
   * this part (i.e. after initialization and control creation but before disposal)
   * the part must notify an implicit listener using
   * {@link ISaveablesLifecycleListener#handleLifecycleEvent(SaveablesLifecycleEvent)}.
   * <p>
   * Additions of saveables to the list of saveables of this part are
   * announced using an event of type
   * {@link SaveablesLifecycleEvent#POST_OPEN}. Removals are announced in a
   * two-stage process, first using an event of type
   * {@link SaveablesLifecycleEvent#PRE_CLOSE} followed by an event of type
   * {@link SaveablesLifecycleEvent#POST_CLOSE}. Since firing the
   * <code>PRE_CLOSE</code> event may trigger prompts to save dirty
   * saveables, the cancellation status of the event must be checked by the
   * part after the notification. When removing only non-dirty saveables,
   * <code>POST_CLOSE</code> notification is sufficient.
   * </p>
   * <p>
   * The listener is obtained from the part site by calling
   * <code>partSite.getService(ISaveablesLifecycleListener.class)</code>.
   * </p>
   * <p>
   * The part must not notify from its initialization methods (e.g. <code>init</code>
   * or <code>createPartControl</code>), or from its dispose method. Parts that
   * implement {@link IReusableEditor} must notify when their input is changed
   * through {@link IReusableEditor#setInput(IEditorInput)}.
   * </p>
   * 
   * @return the saveables presented by the workbench part
   * 
   * @see ISaveablesLifecycleListener
   */
  Saveable[] getSaveables();

  /**
   * Returns the saveables currently active in the workbench part.
   * <p>
   * Certain workbench actions, such as Save, target only the active saveables
   * in the active part. For example, the active saveables could be determined
   * based on the current selection in the part.
   * </p>
   * 
   * @return the saveables currently active in the workbench part
   */
  Saveable[] getActiveSaveables();
}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.