Class AbstractMultiEditor
- All Implemented Interfaces:
IAdaptable,IExecutableExtension,IEditorPart,ISaveablePart,IWorkbenchPart,IWorkbenchPart2,IWorkbenchPart3,IWorkbenchPartOrientation
- Direct Known Subclasses:
MultiEditor
- Since:
- 3.5
-
Field Summary
Fields inherited from interface org.eclipse.ui.IEditorPart
PROP_DIRTY, PROP_INPUTFields inherited from interface org.eclipse.ui.IWorkbenchPart
PROP_TITLE -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidactivateEditor(IEditorPart part) Activates the given nested editor.voiddispose()Release the added listener.voiddoSave(IProgressMonitor monitor) Saves the contents of this part.voiddoSaveAs()Saves the contents of this part to another object.final IEditorPartReturns the active inner editor.protected intgetIndex(IEditorPart editor) Returns the index of the given nested editor.abstract CompositegetInnerEditorContainer(IEditorReference innerEditorReference) This method is called after createPartControl has been executed and should return the container for the given inner editor.final IEditorPart[]Returns an array with all inner editors.protected voidhandlePropertyChange(int propId) Handles a property change notification from a nested editor.voidinit(IEditorSite site, IEditorInput input) Initializes this editor with the given editor site and input.voidinit(IEditorSite site, MultiEditorInput input) protected abstract voidCalled as soon as the inner editors have been created and are available.booleanisDirty()Returns whether the contents of this part have changed since the last save operation.booleanReturns whether the "Save As" operation is supported by this part.final voidsetChildren(IEditorPart[] children) Set the inner editors.voidsetFocus()Asks this part to take focus within the workbench.Methods inherited from class org.eclipse.ui.part.EditorPart
checkSite, getEditorInput, getEditorSite, getTitleToolTip, isSaveOnCloseNeeded, setContentDescription, setInitializationData, setInput, setInputWithNotify, setPartNameMethods inherited from class org.eclipse.ui.part.WorkbenchPart
addPartPropertyListener, addPropertyListener, createPartControl, firePartPropertyChanged, firePropertyChange, getAdapter, getConfigurationElement, getContentDescription, getDefaultImage, getOrientation, getPartName, getPartProperties, getPartProperty, getSite, getTitle, getTitleImage, removePartPropertyListener, removePropertyListener, setPartProperty, setSite, setTitle, setTitleImage, setTitleToolTip, showBusyMethods inherited from class org.eclipse.core.commands.common.EventManager
addListenerObject, clearListeners, getListeners, isListenerAttached, removeListenerObjectMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.eclipse.core.runtime.IAdaptable
getAdapterMethods inherited from interface org.eclipse.ui.IWorkbenchPart
addPropertyListener, createPartControl, getSite, getTitle, getTitleImage, removePropertyListener
-
Constructor Details
-
AbstractMultiEditor
public AbstractMultiEditor()Constructs an editor to contain other editors.
-
-
Method Details
-
handlePropertyChange
protected void handlePropertyChange(int propId) Handles a property change notification from a nested editor. The default implementation simply forwards the change to listeners on this multi editor by callingfirePropertyChangewith the same property id. For example, if the dirty state of a nested editor changes (property idISaveablePart.PROP_DIRTY), this method handles it by firing a property change event forISaveablePart.PROP_DIRTYto property listeners on this multi editor.Subclasses may extend or reimplement this method.
- Parameters:
propId- the id of the property that changed- Since:
- 3.6
-
doSave
Description copied from interface:ISaveablePartSaves the contents of this part.If the save is successful, the part should fire a property changed event reflecting the new dirty state (
PROP_DIRTYproperty).If the save is cancelled through user action, or for any other reason, the part should invoke
setCancelledon theIProgressMonitorto inform the caller.This method is long-running; progress and cancellation are provided by the given progress monitor.
- Specified by:
doSavein interfaceISaveablePart- Specified by:
doSavein classEditorPart- Parameters:
monitor- the progress monitor
-
doSaveAs
public void doSaveAs()Description copied from interface:ISaveablePartSaves the contents of this part to another object.Implementors are expected to open a "Save As" dialog where the user will be able to select a new name for the contents. After the selection is made, the contents should be saved to that new name. During this operation a
IProgressMonitorshould be used to indicate progress.If the save is successful, the part fires a property changed event reflecting the new dirty state (
PROP_DIRTYproperty).- Specified by:
doSaveAsin interfaceISaveablePart- Specified by:
doSaveAsin classEditorPart
-
init
Description copied from interface:IEditorPartInitializes this editor with the given editor site and input.This method is automatically called shortly after the part is instantiated. It marks the start of the part's lifecycle. The
IWorkbenchPart.disposemethod will be called automically at the end of the lifecycle. Clients must not call this method.Implementors of this method must examine the editor input object type to determine if it is understood. If not, the implementor must throw a
PartInitException- Specified by:
initin interfaceIEditorPart- Specified by:
initin classEditorPart- Parameters:
site- the editor siteinput- the editor input- Throws:
PartInitException- if this editor was not initialized successfully
-
init
- Parameters:
site- the editor siteinput- the editor input- Throws:
PartInitException- if this editor was not initialized successfully- See Also:
-
isDirty
public boolean isDirty()Description copied from interface:ISaveablePartReturns whether the contents of this part have changed since the last save operation. If this value changes the part must fire a property listener event withPROP_DIRTY.Note: this method is called often on a part open or part activation switch, for example by actions to determine their enabled status.
- Specified by:
isDirtyin interfaceISaveablePart- Specified by:
isDirtyin classEditorPart- Returns:
trueif the contents have been modified and need saving, andfalseif they have not changed since the last save
-
isSaveAsAllowed
public boolean isSaveAsAllowed()Description copied from interface:ISaveablePartReturns whether the "Save As" operation is supported by this part.- Specified by:
isSaveAsAllowedin interfaceISaveablePart- Specified by:
isSaveAsAllowedin classEditorPart- Returns:
trueif "Save As" is supported, andfalseif not supported
-
setFocus
public void setFocus()Description copied from interface:IWorkbenchPartAsks this part to take focus within the workbench. Parts must assign focus to one of the controls contained in the part's parent composite.Clients should not call this method (the workbench calls this method at appropriate times). To have the workbench activate a part, use
IWorkbenchPage.activate(IWorkbenchPart) instead.- Specified by:
setFocusin interfaceIWorkbenchPart- Specified by:
setFocusin classWorkbenchPart
-
getActiveEditor
Returns the active inner editor.- Returns:
- the active editor
-
getInnerEditors
Returns an array with all inner editors.- Returns:
- the inner editors
-
setChildren
Set the inner editors. Should not be called by clients.- Parameters:
children- the inner editors of this multi editor- Restriction:
- This method is not intended to be referenced by clients.
-
innerEditorsCreated
protected abstract void innerEditorsCreated()Called as soon as the inner editors have been created and are available. -
activateEditor
Activates the given nested editor.- Parameters:
part- the nested editor- Since:
- 3.0
-
getIndex
Returns the index of the given nested editor.- Returns:
- the index of the nested editor
- Since:
- 3.0
-
dispose
public void dispose()Release the added listener.- Specified by:
disposein interfaceIWorkbenchPart- Overrides:
disposein classWorkbenchPart- Since:
- 3.2
-
getInnerEditorContainer
This method is called after createPartControl has been executed and should return the container for the given inner editor.- Parameters:
innerEditorReference- a reference to the inner editor that is being created.- Returns:
- the container in which the inner editor's pane and part controls are to be created.
-