Class IDE


  • public final class IDE
    extends Object
    Collection of IDE-specific APIs factored out of existing workbench. This class cannot be instantiated; all functionality is provided by static methods and fields.
    Since:
    3.0
    • Field Detail

      • EDITOR_KEY

        public static final QualifiedName EDITOR_KEY
        The persistent property key used on IFile resources to contain the preferred editor ID to use.

        Example of retrieving the persisted editor id:

         
          IFile file = ...
          IEditorDescriptor editorDesc = null;
          try {
                String editorID = file.getPersistentProperty(EDITOR_KEY);
                if (editorID != null) {
                        editorDesc = editorReg.findEditor(editorID);
                }
          } catch (CoreException e) {
                // handle problem accessing persistent property here
          }
         
         

        Example of persisting the editor id:

         
          IFile file = ...
          try {
                file.setPersistentProperty(EDITOR_KEY, editorDesc.getId());
          } catch (CoreException e) {
                // handle problem setting persistent property here
          }
         
         
      • EDITOR_ID_ATTR

        public static final String EDITOR_ID_ATTR
        An optional attribute within a workspace marker (IMarker) which identifies the preferred editor type to be opened.
        See Also:
        Constant Field Values
      • RESOURCE_PERSPECTIVE_ID

        public static final String RESOURCE_PERSPECTIVE_ID
        The resource based perspective identifier.
        See Also:
        Constant Field Values
      • UNASSOCIATED_EDITOR_STRATEGY_PREFERENCE_KEY

        public static final String UNASSOCIATED_EDITOR_STRATEGY_PREFERENCE_KEY
        A preference key to decide which IUnassociatedEditorStrategy to use when trying to open files without associated editors.
        Since:
        3.12
        See Also:
        Constant Field Values
    • Method Detail

      • getMarkerHelpRegistry

        public static IMarkerHelpRegistry getMarkerHelpRegistry()
        Returns the marker help registry for the workbench.
        Returns:
        the marker help registry
      • gotoMarker

        public static void gotoMarker​(IEditorPart editor,
                                      IMarker marker)
        Sets the cursor and selection state for the given editor to reveal the position of the given marker. This is done on a best effort basis. If the editor does not provide an IGotoMarker interface (either directly or via IAdaptable.getAdapter), this has no effect.
        Parameters:
        editor - the editor
        marker - the marker
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IEditorInput input,
                                             String editorId)
                                      throws PartInitException
        Opens an editor on the given object.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        editorId - the id of the editor extension to use
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             URI uri,
                                             String editorId,
                                             boolean activate)
                                      throws PartInitException
        Opens an editor on the given IFileStore object.

        Unlike the other openEditor methods, this one can be used to open files that reside outside the workspace resource set.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        uri - the URI of the file store representing the file to open
        editorId - the id of the editor extension to use
        activate - if true the editor will be activated opened
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if the editor could not be initialized
        Since:
        3.3
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String), EFS.getStore(URI)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IEditorInput input,
                                             String editorId,
                                             boolean activate)
                                      throws PartInitException
        Opens an editor on the given object.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened. If activate == true the editor will be activated.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        editorId - the id of the editor extension to use
        activate - if true the editor will be activated
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String, boolean)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IFile input,
                                             boolean activate)
                                      throws PartInitException
        Opens an editor on the given file resource. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened. If activate == true the editor will be activated.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        activate - if true the editor will be activated
        Returns:
        an open editor or null if an external editor was opened or if opening was canceled
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(org.eclipse.ui.IEditorInput, String, boolean)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IFile input,
                                             boolean activate,
                                             boolean determineContentType)
                                      throws PartInitException
        Opens an editor on the given file resource. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings if determineContentType is true.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened. If activate == true the editor will be activated.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        activate - if true the editor will be activated
        determineContentType - attempt to resolve the content type for this file
        Returns:
        an open editor or null if an external editor was opened or if opening was canceled
        Throws:
        PartInitException - if the editor could not be initialized
        Since:
        3.1
        See Also:
        IWorkbenchPage.openEditor(org.eclipse.ui.IEditorInput, String, boolean)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IFile input)
                                      throws PartInitException
        Opens an editor on the given file resource. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        Returns:
        an open editor or null if an external editor was opened or if opening was canceled
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IFile input,
                                             String editorId)
                                      throws PartInitException
        Opens an editor on the given file resource.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        editorId - the id of the editor extension to use
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IFile input,
                                             String editorId,
                                             boolean activate)
                                      throws PartInitException
        Opens an editor on the given file resource.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened. If activate == true the editor will be activated.

        Parameters:
        page - the page in which the editor will be opened
        input - the editor input
        editorId - the id of the editor extension to use
        activate - if true the editor will be activated
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String, boolean)
      • getEditorDescriptor

        @Deprecated
        public static IEditorDescriptor getEditorDescriptor​(IFile file)
                                                     throws PartInitException
        Returns an editor descriptor appropriate for opening the given file resource.

        The editor descriptor is determined using a multi-step process. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings.

        1. The IResource is consulted for a persistent property named IDE.EDITOR_KEY containing the preferred editor id to be used.
        2. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        3. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
        4. The operating system is consulted to determine if an external editor is available.
        5. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        file - the file
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
      • getEditorDescriptor

        @Deprecated
        public static IEditorDescriptor getEditorDescriptor​(IFile file,
                                                            boolean determineContentType)
                                                     throws PartInitException
        Deprecated.
        Returns an editor descriptor appropriate for opening the given file resource.

        The editor descriptor is determined using a multi-step process. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings if determineContentTypeis true.

        1. The IResource is consulted for a persistent property named IDE.EDITOR_KEY containing the preferred editor id to be used.
        2. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        3. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
        4. The operating system is consulted to determine if an external editor is available.
        5. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        file - the file
        determineContentType - query the content type system for the content type of the file
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        Since:
        3.1
      • getEditorDescriptor

        public static IEditorDescriptor getEditorDescriptor​(IFile file,
                                                            boolean determineContentType,
                                                            boolean allowInteractive)
                                                     throws PartInitException,
                                                            OperationCanceledException
        Returns an editor descriptor appropriate for opening the given file resource.

        The editor descriptor is determined using a multi-step process. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings if determineContentTypeis true.

        1. The IResource is consulted for a persistent property named IDE.EDITOR_KEY containing the preferred editor id to be used.
        2. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        3. The preferred IUnassociatedEditorStrategy is consulted.
        4. The SystemEditorOrTextEditorStrategy is consulted, whose behavior is
          1. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
          2. The operating system is consulted to determine if an external editor is available.
          3. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        file - the file
        determineContentType - query the content type system for the content type of the file
        allowInteractive - whether we allow user interactions
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        OperationCanceledException - in case descriptor lookup was canceled by the user
        Since:
        3.12
      • getEditorDescriptorForFileStore

        public static IEditorDescriptor getEditorDescriptorForFileStore​(IFileStore fileStore,
                                                                        boolean allowInteractive)
                                                                 throws PartInitException
        Returns an editor descriptor appropriate for opening the given file store.

        The editor descriptor is determined using a multi-step process. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings.

        1. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        2. The preferred IUnassociatedEditorStrategy is consulted.
        3. The SystemEditorOrTextEditorStrategy is consulted, whose behavior is
          1. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
          2. The operating system is consulted to determine if an external editor is available.
          3. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        fileStore - the file store
        allowInteractive - Whether user interactions are allowed
        Returns:
        editor descriptor of an editor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        Since:
        3.16
      • getEditorDescriptor

        @Deprecated
        public static IEditorDescriptor getEditorDescriptor​(String name)
                                                     throws PartInitException
        Deprecated.
        Returns an editor descriptor appropriate for opening a file resource with the given name.

        The editor descriptor is determined using a multi-step process. This method will attempt to infer content type from the file name.

        1. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        2. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
        3. The operating system is consulted to determine if an external editor is available.
        4. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        name - the file name
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        Since:
        3.1
      • getEditorDescriptor

        @Deprecated
        public static IEditorDescriptor getEditorDescriptor​(String name,
                                                            boolean inferContentType)
                                                     throws PartInitException
        Deprecated.
        Returns an editor descriptor appropriate for opening a file resource with the given name.

        The editor descriptor is determined using a multi-step process. This method will attempt to infer the content type of the file if inferContentType is true.

        1. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        2. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
        3. The operating system is consulted to determine if an external editor is available.
        4. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        name - the file name
        inferContentType - attempt to infer the content type from the file name if this is true
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        Since:
        3.1
      • getEditorDescriptor

        public static IEditorDescriptor getEditorDescriptor​(String name,
                                                            boolean inferContentType,
                                                            boolean allowInteractive)
                                                     throws PartInitException,
                                                            OperationCanceledException
        Returns an editor descriptor appropriate for opening a file resource with the given name.

        The editor descriptor is determined using a multi-step process. This method will attempt to infer the content type of the file if inferContentType is true.

        1. The workbench editor registry is consulted to determine if an editor extension has been registered for the file type. If so, an instance of the editor extension is opened on the file. See IEditorRegistry.getDefaultEditor(String).
        2. The preferred IUnassociatedEditorStrategy is consulted.
        3. The SystemEditorOrTextEditorStrategy is consulted, whose behavior is
          1. The operating system is consulted to determine if an in-place component editor is available (e.g. OLE editor on Win32 platforms).
          2. The operating system is consulted to determine if an external editor is available.
          3. The workbench editor registry is consulted to determine if the default text editor is available.
        Parameters:
        name - the file name
        inferContentType - attempt to infer the content type from the file name if this is true
        allowInteractive - whether we allow user interactions.
        Returns:
        an editor descriptor, appropriate for opening the file
        Throws:
        PartInitException - if no editor can be found
        OperationCanceledException - in case descriptor lookup was canceled by the user
        Since:
        3.12
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IMarker marker)
                                      throws PartInitException
        Opens an editor on the file resource of the given marker.

        If this page already has an editor open on the marker resource file that editor is brought to front; otherwise, a new editor is opened.The cursor and selection state of the editor are then updated from information recorded in the marker.

        If the marker contains an EDITOR_ID_ATTR attribute the attribute value will be used to determine the editor type to be opened. If not, the registered editor for the marker resource file will be used.

        Parameters:
        page - the workbench page to open the editor in
        marker - the marker to open
        Returns:
        an open editor or null not possible
        Throws:
        PartInitException - if the editor could not be initialized
        See Also:
        openEditor(org.eclipse.ui.IWorkbenchPage, org.eclipse.core.resources.IMarker, boolean)
      • openEditor

        public static IEditorPart openEditor​(IWorkbenchPage page,
                                             IMarker marker,
                                             boolean activate)
                                      throws PartInitException
        Opens an editor on the file resource of the given marker.

        If this page already has an editor open on the marker resource file that editor is brought to front; otherwise, a new editor is opened. If activate == true the editor will be activated. The cursor and selection state of the editor are then updated from information recorded in the marker.

        If the marker contains an EDITOR_ID_ATTR attribute the attribute value will be used to determine the editor type to be opened. If not, the registered editor for the marker resource file will be used.

        Parameters:
        page - the workbench page to open the editor in
        marker - the marker to open
        activate - if true the editor will be activated
        Returns:
        an open editor or null if not possible or if opening was canceled
        Throws:
        PartInitException - if the editor could not be initialized
      • openEditorOnFileStore

        public static IEditorPart openEditorOnFileStore​(IWorkbenchPage page,
                                                        IFileStore fileStore)
                                                 throws PartInitException
        Opens an editor on the given IFileStore object.

        Unlike the other openEditor methods, this one can be used to open files that reside outside the workspace resource set.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        fileStore - the IFileStore representing the file to open
        Returns:
        an open editor or null if an external editor was opened or if opening was canceled
        Throws:
        PartInitException - if the editor could not be initialized
        Since:
        3.3
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String)
      • openInternalEditorOnFileStore

        public static IEditorPart openInternalEditorOnFileStore​(IWorkbenchPage page,
                                                                IFileStore fileStore)
                                                         throws PartInitException
        Opens an internal editor on the given IFileStore object.

        Unlike the other openEditor methods, this one can be used to open files that reside outside the workspace resource set.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened.

        Parameters:
        page - the page in which the editor will be opened
        fileStore - the IFileStore representing the file to open
        Returns:
        an open editor or null if an external editor was opened
        Throws:
        PartInitException - if no internal editor can be found or if the editor could not be initialized
        Since:
        3.6
        See Also:
        IWorkbenchPage.openEditor(IEditorInput, String)
      • saveAllEditors

        public static boolean saveAllEditors​(IResource[] resourceRoots,
                                             boolean confirm)
        Save all dirty editors in the workbench whose editor input is a child resource of one of the IResource's provided. Opens a dialog to prompt the user if confirm is true. Return true if successful. Return false if the user has canceled the command.
        Parameters:
        resourceRoots - the resource roots under which editor input should be saved, other will be left dirty
        confirm - true to ask the user before saving unsaved changes (recommended), and false to save unsaved changes without asking
        Returns:
        true if the command succeeded, and false if the operation was canceled by the user or an error occurred while saving
        Since:
        3.0
      • setDefaultEditor

        public static void setDefaultEditor​(IFile file,
                                            String editorID)
        Sets the default editor id for a given file. This value will be used to determine the default editor descriptor for the file in future calls to getDefaultEditor(IFile).
        Parameters:
        file - the file
        editorID - the editor id
      • getDefaultEditor

        public static IEditorDescriptor getDefaultEditor​(IFile file)
        Returns the default editor for a given file. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings.

        A default editor id may be registered for a specific file using setDefaultEditor. If the given file has a registered default editor id the default editor will derived from it. If not, the default editor is determined by taking the file name for the file and obtaining the default editor for that name.

        Parameters:
        file - the file
        Returns:
        the descriptor of the default editor, or null if not found
      • getDefaultEditor

        public static IEditorDescriptor getDefaultEditor​(IFile file,
                                                         boolean determineContentType)
        Returns the default editor for a given file. This method will attempt to resolve the editor based on content-type bindings as well as traditional name/extension bindings if determineContentType is true.

        A default editor id may be registered for a specific file using setDefaultEditor. If the given file has a registered default editor id the default editor will derived from it. If not, the default editor is determined by taking the file name for the file and obtaining the default editor for that name.

        Parameters:
        file - the file
        determineContentType - determine the content type for the given file
        Returns:
        the descriptor of the default editor, or null if not found
        Since:
        3.1
      • computeSelectedResources

        public static List<IResource> computeSelectedResources​(IStructuredSelection originalSelection)
        Extracts and returns the IResources in the given selection or the resource objects they adapts to.
        Parameters:
        originalSelection - the original selection, possibly empty
        Returns:
        list of resources (element type: IResource), possibly empty
      • getContentType

        public static IContentType getContentType​(IFile file)
        Return the content type for the given file.
        Parameters:
        file - the file to test
        Returns:
        the content type, or null if it cannot be determined.
        Since:
        3.1
      • guessContentType

        public static IContentType guessContentType​(IFile file)
        Guess at the content type of the given file based on the filename.
        Parameters:
        file - the file to test
        Returns:
        the content type, or null if it cannot be determined.
        Since:
        3.2
      • promptToConfirm

        public static boolean promptToConfirm​(Shell shell,
                                              String title,
                                              String message,
                                              IResourceDelta delta,
                                              String[] ignoreModelProviderIds,
                                              boolean syncExec)
        Prompt the user to inform them of the possible side effects of an operation on resources. Do not prompt for side effects from ignored model providers. A model provider can be ignored if it is the client calling this API. Any message from the provided model provider id or any model providers it extends will be ignored.
        Parameters:
        shell - the shell to parent the prompt dialog
        title - the title of the dialog
        message - the message for the dialog
        delta - a delta built using an IResourceChangeDescriptionFactory
        ignoreModelProviderIds - model providers to be ignored
        syncExec - prompt in a sync exec (required when called from a non-UI thread)
        Returns:
        whether the user chose to continue
        Since:
        3.2
      • registerAdapters

        public static void registerAdapters()
        Register workbench adapters programmatically. This is necessary to enable certain types of content in the explorers.

        Note: this method should only be called once, in your application's WorkbenchAdvisor#initialize(IWorkbenchConfigurer) method.

        Since:
        3.5
      • openEditors

        public static IEditorReference[] openEditors​(IWorkbenchPage page,
                                                     IFile[] inputs)
                                              throws MultiPartInitException
        Opens editors on given file resources.

        If the page already has an editor open on the target object then that editor is brought to front; otherwise, a new editor is opened. The editor created for the first input will be activated.

        Parameters:
        page - the page in which the editor will be opened
        inputs - the inputs for the editors
        Returns:
        references to the editors opened; the corresponding editors might not be materialized
        Throws:
        MultiPartInitException - if at least one of the editors could not be initialized
        Since:
        3.5