import java.util.ArrayList;
import java.util.List;
+import net.sourceforge.phpdt.internal.compiler.parser.Parser;
import net.sourceforge.phpeclipse.PHPeclipsePlugin;
-import net.sourceforge.phpeclipse.phpeditor.phpparser.PHPParser;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IMarker;
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() {
+ boolean phpFlag = false;
try {
fileToParse = getPHPFile();
if (fileToParse == null) {
// should throw an exception
return;
}
- IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
- if (store.getString(PHPeclipsePlugin.PHP_PARSER_DEFAULT).equals(PHPeclipsePlugin.PHP_INTERNAL_PARSER)) {
- // 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) {
+ String name = fileToParse.getName();
+ for (int i = 0; i<EXTENSIONS.length; i++) {
+ if (name.endsWith(EXTENSIONS[i])) {
+ phpFlag = true; // php file extension
+ break;
+ }
+ }
+ if (phpFlag) {
+ IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
+ if (store.getString(PHPeclipsePlugin.PHP_PARSER_DEFAULT).equals(PHPeclipsePlugin.PHP_INTERNAL_PARSER)) {
+ // 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) {
+ }
+ } else {
+ Parser.phpExternalParse(fileToParse);
}
- } else {
- PHPParser.phpExternalParse(fileToParse);
}
-
} catch (CoreException e) {
}
protected void parse(InputStream iStream) {
- StringBuffer buf = new StringBuffer();
+ StringBuffer buf = new StringBuffer();
int c0;
- try {
+ try {
while ((c0 = iStream.read()) != (-1)) {
buf.append((char) c0);
}
}
String input = buf.toString();
- PHPParser parser = new PHPParser(fileToParse);
+ Parser parser = new Parser(fileToParse);
try {
parser.parse(input);
} catch (CoreException e) {