improved php parser
[phpeclipse.git] / net.sourceforge.phpeclipse / src / junit / sourceforge / phpeclipse / PHPParserTestCase.java
index 26589fc..400365a 100644 (file)
@@ -7,6 +7,8 @@ which accompanies this distribution, and is available at
 http://www.eclipse.org/legal/cpl-v10.html
 **********************************************************************/
 
+import org.eclipse.core.runtime.CoreException;
+
 import junit.framework.TestCase;
 
 import net.sourceforge.phpeclipse.phpeditor.PHPParser;
@@ -26,51 +28,63 @@ public class PHPParserTestCase extends TestCase {
    *  Test the PHP Parser with different PHP snippets
    */
   public void testPHPParser() {
-    check("if (isset($test)) { } elseif (isset($lang)) { }");
-    check("require_once(\"mainfile.php\");  ");
-    check("if (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
-    check("while (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
-    check("while (eregi(\"footer.php\",$PHP_SELF)) :\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "endwhile;\n");
-    check("$tipath = \"images/topics/\";");
-    check("$reasons = array(\"1\", \"2\",\"test\");");
-    check("if ($home == 1) { message_box(); blocks(Center);}");
-    check("$bresult = sql_query(\"select * from \".$prefix.\"_banner WHERE type='0' AND active='1'\", $dbi);");
-    check("switch($func) {\n case \"f1\":\n f1();\n break; \n default: \n f0(); \n break;\n }");
-    check("list ($catid) = sql_fetch_row($result, $dbi);");
-    check("if (!$name) { \n }");
-    check("mt_srand((double)microtime()*1000000);");
-    check("\"\\\"\";");
-    check("$v->read();");
-    check("$alttext = ereg_replace(\"\\\"\", \"\", $alttext);");
-    check("$message .= \"\"._THISISAUTOMATED.\"\\n\\n\";");
-    check("if (!empty($pass) AND $pass==$passwd) { }");
-    check("$AllowableHTML = array(\"b\"=>1,\n \"i\"=>1);");
-    check("if ($term{0}!=$firstChar) {}");
-    check("echo \"<center><b>\"._NOADMINYET.\"</b></center><br><br>\"\n"
-    + ".\"<form action=\\\"admin.php\\\" method=\\\"post\\\">\"\n"
-    + ".\"<tr><td><b>\"._NICKNAME.\":</b></td><td><input type=\\\"text\\\" name=\\\"name\\\" size=\\\"30\\\" maxlength=\\\"25\\\"></td></tr>\"\n"
-    +";");
-    check("/* \n overLib is from Eric Bosrup (http://www.bosrup.com/web/overlib/) \n */");
-    check("if ($arrAtchCookie[1]==0 && $IdAtchPostId!=null){  } ");
-    check("$arrAtchCookie[1] -= filesize(realpath($AtchTempDir).\"/\".$xattachlist)/ 1024; ");
-    check("if (!isset($message)){ \n"
-    + "$message = $myrow[post_text];\n"
-    + "$message = eregi_replace(\"\\[addsig]\", \"\\n-----------------\\n\" .    $myrow[user_sig], $message); \n"
-    +"$message = str_replace(\"<BR>\", \"\\n\", $message); \n"
-    +"$message = str_replace(\"<br>\", \"\\n\", $message); \n } ");
-    check("do {$array[] = array(\"$myrow[uid]\" => \"$myrow[uname]\"); } while($myrow = mysql_fetch_array($result));");
-    check("$ol = new Overlib();");
+    checkHTML("<?php phpinfo(); ?>");
+    
+    checkPHP("if (isset($test)) { } elseif (isset($lang)) { }");
+    checkPHP("require_once(\"mainfile.php\");  ");
+    checkPHP("if (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
+    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
+    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) :\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "endwhile;\n");
+    checkPHP("$tipath = \"images/topics/\";");
+    checkPHP("$reasons = array(\"1\", \"2\",\"test\");");
+    checkPHP("if ($home == 1) { message_box(); blocks(Center);}");
+    checkPHP("$bresult = sql_query(\"select * from \".$prefix.\"_banner WHERE type='0' AND active='1'\", $dbi);");
+    checkPHP("switch($func) {\n case \"f1\":\n f1();\n break; \n default: \n f0(); \n break;\n }");
+    checkPHP("list ($catid) = sql_fetch_row($result, $dbi);");
+    checkPHP("if (!$name) { \n }");
+    checkPHP("mt_srand((double)microtime()*1000000);");
+    checkPHP("\"\\\"\";");
+    checkPHP("$v->read();");
+    checkPHP("$alttext = ereg_replace(\"\\\"\", \"\", $alttext);");
+    checkPHP("$message .= \"\"._THISISAUTOMATED.\"\\n\\n\";");
+    checkPHP("if (!empty($pass) AND $pass==$passwd) { }");
+    checkPHP("$AllowableHTML = array(\"b\"=>1,\n \"i\"=>1);");
+    checkPHP("if ($term{0}!=$firstChar) {}");
+    checkPHP(
+      "echo \"<center><b>\"._NOADMINYET.\"</b></center><br><br>\"\n"
+        + ".\"<form action=\\\"admin.php\\\" method=\\\"post\\\">\"\n"
+        + ".\"<tr><td><b>\"._NICKNAME.\":</b></td><td><input type=\\\"text\\\" name=\\\"name\\\" size=\\\"30\\\" maxlength=\\\"25\\\"></td></tr>\"\n"
+        + ";");
+    checkPHP("/* \n overLib is from Eric Bosrup (http://www.bosrup.com/web/overlib/) \n */");
+    checkPHP("if ($arrAtchCookie[1]==0 && $IdAtchPostId!=null){  } ");
+    checkPHP("$arrAtchCookie[1] -= filesize(realpath($AtchTempDir).\"/\".$xattachlist)/ 1024; ");
+    checkPHP(
+      "if (!isset($message)){ \n"
+        + "$message = $myrow[post_text];\n"
+        + "$message = eregi_replace(\"\\[addsig]\", \"\\n-----------------\\n\" .    $myrow[user_sig], $message); \n"
+        + "$message = str_replace(\"<BR>\", \"\\n\", $message); \n"
+        + "$message = str_replace(\"<br>\", \"\\n\", $message); \n } ");
+    checkPHP("do {$array[] = array(\"$myrow[uid]\" => \"$myrow[uname]\"); } while($myrow = mysql_fetch_array($result));");
+    checkPHP("$ol = new Overlib();");
+    checkPHP("$risultato = mysql_query($sql) or\n    die(mysql_error());");
+  }
+
+  private void checkPHP(String strEval) {
+    try {
+      parser.phpParse(strEval, 1);
+    } catch (CoreException e) {
+    }
   }
 
-  public void check(String strEval) {
-    parser.start(strEval, 1);
+  private void checkHTML(String strEval) {
+    parser.htmlParse(strEval);
   }
 
   /**
    *  The JUnit setup method
    */
   protected void setUp() {
-    parser = new PHPParser();
+    parser = new PHPParser(null);
   }
 
 }