Klaus Hartlage - www.eclipseproject.de
**********************************************************************/
+import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
+import net.sourceforge.phpdt.internal.compiler.util.Util;
+import net.sourceforge.phpdt.internal.core.builder.PHPBuilder;
import net.sourceforge.phpeclipse.PHPeclipsePlugin;
+import net.sourceforge.phpeclipse.actions.ExternalPHPParser;
+
import org.eclipse.core.resources.IFile;
-import org.eclipse.core.resources.IMarker;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.jface.preference.IPreferenceStore;
import org.eclipse.ui.IEditorInput;
import org.eclipse.ui.texteditor.ITextEditor;
import org.eclipse.ui.texteditor.TextEditorAction;
+//import test.PHPParserManager;
+
/**
- * Class that defines the action for parsing the current PHP file
+ * ClassDeclaration that defines the action for parsing the current PHP file
*/
public class PHPParserAction extends TextEditorAction {
private static PHPParserAction instance = new PHPParserAction();
+ private static String[] EXTENSIONS = { ".php", ".php3", ".php4", ".inc", ".phtml" };
protected IFile fileToParse;
protected List fVariables = new ArrayList(100);
* Code called when the action is fired.
*/
public void run() {
- try {
- fileToParse = getPHPFile();
+ boolean phpFlag = false;
+
+ // try {
+ fileToParse = getPHPFile();
+ parseFile(fileToParse);
+ }
+
+ public static void parseFile(IFile fileToParse) {
+ boolean phpFlag = false;
+// try {
+
if (fileToParse == null) {
- // should never happen
+ // TODO should never happen => should throw an exception
System.err.println("Error : no file in the editor");
- // should throw an exception
+
return;
}
- IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
- if (store.getBoolean(PHPeclipsePlugin.PHP_PARSER_DEFAULT)) {
- // first delete all the previous markers
- fileToParse.deleteMarkers(IMarker.PROBLEM, false, 0);
-
- try {
- InputStream iStream = fileToParse.getContents();
- // int c = iStream.read();
- parse(iStream);
- iStream.close();
- } catch (IOException e) {
+ // TODO use isPHPFile()
+ String name = fileToParse.getName().toLowerCase();
+ for (int i = 0; i < EXTENSIONS.length; i++) {
+ if (name.endsWith(EXTENSIONS[i])) {
+ phpFlag = true; // php file extension
+ break;
}
- } else {
- PHPParser.phpExternalParse(fileToParse);
}
-
- } catch (CoreException e) {
- }
-
+ if (phpFlag) {
+ IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
+// if (store.getString(PHPeclipsePlugin.PHP_PARSER_DEFAULT).equals(PHPeclipsePlugin.PHP_INTERNAL_PARSER)) {
+// PHPBuilder.removeProblemsAndTasksFor(fileToParse);
+// parse(fileToParse); //, iStream);
+// } else {
+ ExternalPHPParser parser = new ExternalPHPParser(fileToParse);
+ parser.phpExternalParse();
+// }
+ }
}
-
/**
* Finds the file that's currently opened in the PHP Text Editor
*/
return null;
}
- /**
- * Create marker for the parse error
- */
- // protected void setMarker(String message, int lineNumber) throws CoreException {
- //
- // Hashtable attributes = new Hashtable();
- // MarkerUtilities.setMessage(attributes, message);
- // if (message.startsWith(ERROR))
- // attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_ERROR));
- // else if (message.startsWith(WARNING))
- // attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_WARNING));
- // else
- // attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_INFO));
- // MarkerUtilities.setLineNumber(attributes, lineNumber);
- // MarkerUtilities.createMarker(fileToParse, attributes, IMarker.PROBLEM);
- // }
-
- // private String getIdentifier(InputStream iStream, int c) {
- // // int i = 0;
- // // char c;
- // // int textLength = text.length();
- // StringBuffer identifier = new StringBuffer();
- // identifier.append((char) c);
- // try {
- // while ((c = iStream.read()) != (-1)) {
- // if (Character.isJavaIdentifierPart((char) c)) {
- // identifier.append((char) c);
- // // } else if ((i == 0) && (c == '$')) {
- // // identifier.append((char)c);
- // } else {
- // return identifier.toString();
- // }
- // // i++;
- // }
- // } catch (IOException e) {
- // }
- // return identifier.toString();
- // }
-
- protected void parse(InputStream iStream) {
-
- StringBuffer buf = new StringBuffer();
- int c0;
+
+
+
+ protected static void parse(IFile fileToParse) {
+ InputStream stream = null;
+ char[] charArray;
try {
- while ((c0 = iStream.read()) != (-1)) {
- buf.append((char) c0);
- }
+ stream = new BufferedInputStream(fileToParse.getContents());
+ charArray = Util.getInputStreamAsCharArray(stream, -1, null);
+ ExternalPHPParser parser = new ExternalPHPParser(fileToParse);
+ parser.phpExternalParse();
+ } catch (CoreException e) {
} catch (IOException e) {
- return;
+ } finally {
+ try {
+ if (stream!=null) {
+ stream.close();
+ }
+ } catch (IOException e) {
+ }
}
- String input = buf.toString();
-
- PHPParser parser = new PHPParser(fileToParse);
- parser.htmlParse(input);
}
}
\ No newline at end of file