import java.util.ArrayList;
import java.util.List;
-import net.sourceforge.phpdt.internal.compiler.parser.Parser;
import net.sourceforge.phpeclipse.PHPeclipsePlugin;
import org.eclipse.core.resources.IFile;
import org.eclipse.ui.IFileEditorInput;
import org.eclipse.ui.texteditor.ITextEditor;
import org.eclipse.ui.texteditor.TextEditorAction;
+import test.PHPParserSuperclass;
+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 {
*/
public void run() {
boolean phpFlag = false;
+
+ // try {
+ fileToParse = getPHPFile();
+ parseFile(fileToParse);
+ }
+
+ public static void parseFile(IFile fileToParse) {
+ boolean phpFlag = false;
try {
- fileToParse = getPHPFile();
+
if (fileToParse == null) {
// should never happen
System.err.println("Error : no file in the editor");
// should throw an exception
return;
}
- String name = fileToParse.getName();
- for (int i = 0; i<EXTENSIONS.length; i++) {
+ String name = fileToParse.getName().toLowerCase();
+ for (int i = 0; i < EXTENSIONS.length; i++) {
if (name.endsWith(EXTENSIONS[i])) {
- phpFlag = true; // php file extension
+ phpFlag = true; // php file extension
break;
}
}
// first delete all the previous markers
fileToParse.deleteMarkers(IMarker.PROBLEM, false, 0);
+ //the tasks are removed here
+ fileToParse.deleteMarkers(IMarker.TASK, false, 0);
+
try {
InputStream iStream = fileToParse.getContents();
// int c = iStream.read();
- parse(iStream);
+ parse(fileToParse, iStream);
iStream.close();
} catch (IOException e) {
}
} else {
- Parser.phpExternalParse(fileToParse);
+ PHPParserSuperclass.phpExternalParse(fileToParse);
}
}
} catch (CoreException e) {
}
}
-
/**
* Finds the file that's currently opened in the PHP Text Editor
*/
// identifier.append((char) c);
// try {
// while ((c = iStream.read()) != (-1)) {
- // if (Character.isJavaIdentifierPart((char) c)) {
+ // if (Scanner.isPHPIdentifierPart((char) c)) {
// identifier.append((char) c);
// // } else if ((i == 0) && (c == '$')) {
// // identifier.append((char)c);
// return identifier.toString();
// }
- protected void parse(InputStream iStream) {
+ protected static void parse(IFile fileToParse, InputStream iStream) {
StringBuffer buf = new StringBuffer();
int c0;
}
String input = buf.toString();
- Parser parser = new Parser(fileToParse);
+ PHPParserSuperclass parser = PHPParserManager.getParser(fileToParse);
try {
parser.parse(input);
} catch (CoreException e) {