package rhogenwizard.editors;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IMarker;
import org.eclipse.core.resources.IResourceChangeEvent;
import org.eclipse.core.resources.IResourceChangeListener;
import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.jface.dialogs.ErrorDialog;
import org.eclipse.swt.widgets.Display;
import org.eclipse.ui.*;
import org.eclipse.ui.part.FileEditorInput;
import org.eclipse.ui.part.MultiPageEditorPart;
import org.eclipse.ui.texteditor.ITextEditor;
import org.eclipse.ui.editors.text.TextEditor;
import org.eclipse.ui.ide.IDE;
public class RubyEditor extends MultiPageEditorPart implements IResourceChangeListener
{
/** The text editor used in page 0. */
private TextEditor editor;
/**
* Creates a multi-page editor example.
*/
public RubyEditor()
{
super();
ResourcesPlugin.getWorkspace().addResourceChangeListener(this);
}
/**
* Creates page 0 of the multi-page editor,
* which contains a text editor.
*/
void createPage0()
{
try
{
editor = new TextEditor();
int index = addPage(editor, getEditorInput());
setPageText(index, editor.getTitle());
}
catch (PartInitException e)
{
ErrorDialog.openError(getSite().getShell(), "Error creating nested text editor",
null, e.getStatus());
}
}
public ITextEditor getTextEditor()
{
return editor;
}
/**
* Creates the pages of the multi-page editor.
*/
protected void createPages()
{
createPage0();
}
/**
* The <code>MultiPageEditorPart</code> implementation of this
* <code>IWorkbenchPart</code> method disposes all nested editors.
* Subclasses may extend.
*/
public void dispose()
{
ResourcesPlugin.getWorkspace().removeResourceChangeListener(this);
super.dispose();
}
/**
* Saves the multi-page editor's document.
*/
public void doSave(IProgressMonitor monitor)
{
getEditor(0).doSave(monitor);
}
/**
* Saves the multi-page editor's document as another file.
* Also updates the text for page 0's tab, and updates this multi-page editor's input
* to correspond to the nested editor's.
*/
public void doSaveAs()
{
IEditorPart editor = getEditor(0);
editor.doSaveAs();
setPageText(0, editor.getTitle());
setInput(editor.getEditorInput());
}
/* (non-Javadoc)
* Method declared on IEditorPart
*/
public void gotoMarker(IMarker marker)
{
setActivePage(0);
IDE.gotoMarker(getEditor(0), marker);
}
/**
* The <code>MultiPageEditorExample</code> implementation of this method
* checks that the input is an instance of <code>IFileEditorInput</code>.
*/
@SuppressWarnings("deprecation")
public void init(IEditorSite site, IEditorInput editorInput) throws PartInitException
{
if (!(editorInput instanceof IFileEditorInput))
throw new PartInitException("Invalid Input: Must be IFileEditorInput");
super.init(site, editorInput);
setTitle(getFileName());
}
/* (non-Javadoc)
* Method declared on IEditorPart.
*/
public boolean isSaveAsAllowed()
{
return true;
}
/**
* Calculates the contents of page 2 when the it is activated.
*/
protected void pageChange(int newPageIndex)
{
super.pageChange(newPageIndex);
}
/**
* Closes all project files on project close.
*/
public void resourceChanged(final IResourceChangeEvent event)
{
if(event.getType() == IResourceChangeEvent.PRE_CLOSE)
{
Display.getDefault().asyncExec(new Runnable()
{
public void run(){
IWorkbenchPage[] pages = getSite().getWorkbenchWindow().getPages();
for (int i = 0; i<pages.length; i++)
{
if(((FileEditorInput)editor.getEditorInput()).getFile().getProject().equals(event.getResource())){
IEditorPart editorPart = pages[i].findEditor(editor.getEditorInput());
pages[i].closeEditor(editorPart,true);
}
}
}
});
}
}
private String getFileName()
{
IEditorInput editorInput = getEditorInput();
if (!(editorInput instanceof IFileEditorInput))
return null;
IFileEditorInput fileEditorInput = (IFileEditorInput)editorInput;
IFile currFile = fileEditorInput.getFile();
return currFile.getName();
}
}