Merge "bug 478849 IndentAction: Adding ScriptFormatterExtension2 initialization"
diff --git a/core/plugins/org.eclipse.dltk.ui/src/org/eclipse/dltk/ui/actions/IndentAction.java b/core/plugins/org.eclipse.dltk.ui/src/org/eclipse/dltk/ui/actions/IndentAction.java
index d7c9d79..22de784 100644
--- a/core/plugins/org.eclipse.dltk.ui/src/org/eclipse/dltk/ui/actions/IndentAction.java
+++ b/core/plugins/org.eclipse.dltk.ui/src/org/eclipse/dltk/ui/actions/IndentAction.java
@@ -16,8 +16,7 @@
import org.eclipse.core.resources.IProject;
import org.eclipse.core.runtime.Assert;
-import org.eclipse.dltk.core.IModelElement;
-import org.eclipse.dltk.core.IScriptProject;
+import org.eclipse.dltk.core.ISourceModule;
import org.eclipse.dltk.core.PreferencesLookupDelegate;
import org.eclipse.dltk.core.ScriptUtils;
import org.eclipse.dltk.internal.ui.editor.EditorUtility;
@@ -26,6 +25,7 @@
import org.eclipse.dltk.ui.formatter.FormatterException;
import org.eclipse.dltk.ui.formatter.IScriptFormatter;
import org.eclipse.dltk.ui.formatter.IScriptFormatterExtension;
+import org.eclipse.dltk.ui.formatter.IScriptFormatterExtension2;
import org.eclipse.dltk.ui.formatter.IScriptFormatterFactory;
import org.eclipse.dltk.ui.formatter.ScriptFormatterManager;
import org.eclipse.dltk.ui.text.util.AutoEditUtils;
@@ -81,18 +81,6 @@
fIsTabAction = isTabAction;
}
- private IProject getProject() {
- final IModelElement input = EditorUtility.getEditorInputModelElement(
- getTextEditor(), false);
- if (input != null) {
- final IScriptProject scriptProject = input.getScriptProject();
- if (scriptProject != null) {
- return scriptProject.getProject();
- }
- }
- return null;
- }
-
/*
* @see org.eclipse.jface.action.Action#run()
*/
@@ -147,7 +135,15 @@
}
return;
}
- final IProject project = getProject();
+
+ IProject project = null;
+ final ISourceModule sourceModule = EditorUtility
+ .getEditorInputModelElement(getTextEditor(), false);
+ if (sourceModule != null
+ && sourceModule.getScriptProject() != null) {
+ project = sourceModule.getScriptProject().getProject();
+ }
+
final IScriptFormatterFactory factory = ScriptFormatterManager
.getSelected(ScriptUtils.getNatureId(getTextEditor()),
project);
@@ -165,6 +161,12 @@
((IScriptFormatterExtension) formatter)
.initialize(project);
}
+ if (sourceModule != null
+ && formatter instanceof IScriptFormatterExtension2) {
+ ((IScriptFormatterExtension2) formatter)
+ .initialize(sourceModule);
+ }
+
final Position end = new Position(offset + length);
document.addPosition(end);
if (indentLines(document, startLine, lastLine, formatter)) {
@@ -435,4 +437,4 @@
return TextSelection.emptySelection();
}
-}
+}
\ No newline at end of file