diff --git a/src/bindings/php/SConscript b/src/bindings/php/SConscript index 919677bc830a7932f83a9b24e1f696cae69440b9..94c9d83bb1a8afe2556eb2204dcf253f1749eab3 100644 --- a/src/bindings/php/SConscript +++ b/src/bindings/php/SConscript @@ -23,7 +23,7 @@ phplib = phptestenv.Command(os.path.join(phpextprefix, "hammer.so"), libhammer_p AlwaysBuild(phplib) phpprefix = os.popen("php-config --prefix").read().rstrip() phpincl = phptestenv.Command(os.path.join(os.path.join(phpprefix, "etc/conf.d"), "hammer.ini"), "hammer.ini", Copy("$TARGET", "$SOURCE")) -phptestexec = phptestenv.Command(phptests, [phplib, phpincl], "phpenv exec phpunit -v --include-path " + os.path.dirname(libhammer_php[0].path) +" src/bindings/php/Tests") +phptestexec = phptestenv.Command(phptests, [phplib, phpincl], "phpenv exec phpunit -v --debug --include-path " + os.path.dirname(libhammer_php[0].path) +" src/bindings/php/Tests") phptest = Alias("testphp", [phptestexec], phptestexec) AlwaysBuild(phptest) testruns.append(phptest) diff --git a/src/bindings/php/Tests/ActionTest.php b/src/bindings/php/Tests/ActionTest.php index 699812cfd7520a9139840296ceb3fe40f0b525c4..250dd24efd39f44c781aa5d0867faa16c4674e5c 100644 --- a/src/bindings/php/Tests/ActionTest.php +++ b/src/bindings/php/Tests/ActionTest.php @@ -11,7 +11,7 @@ class ActionTest extends PHPUnit_Framework_TestCase } protected function setUp() { - $this->parser = h_action(h_sequence(h_choice(h_ch("a"), h_ch("A")), h_choice(h_ch("b"), h_ch("B"))), "actTest"); + $this->parser = h_action(h_sequence(h_choice(ch("a"), ch("A")), h_choice(ch("b"), ch("B"))), "actTest"); } public function testSuccess() { diff --git a/src/bindings/php/Tests/ChTest.php b/src/bindings/php/Tests/ChTest.php index f18cdfb257272117ce7ffca25094a7ff5dfdb59b..e05ad244d2eb43b4b0f52faf00557761f10e3413 100644 --- a/src/bindings/php/Tests/ChTest.php +++ b/src/bindings/php/Tests/ChTest.php @@ -8,7 +8,7 @@ class ChTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser = h_ch("\xa2"); + $this->parser = ch("\xa2"); } public function testSuccess() { diff --git a/src/bindings/php/Tests/EndTest.php b/src/bindings/php/Tests/EndTest.php index b3fc6c6692c7dc31071285a1cfb23d0bb783fce8..55e05b82ff2e40759ae696485c39113769c4627c 100644 --- a/src/bindings/php/Tests/EndTest.php +++ b/src/bindings/php/Tests/EndTest.php @@ -7,18 +7,22 @@ class EndPTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser = h_sequence(h_ch("a"), h_end_p()); + $this->parser = sequence(ch("a"), h_end_p()); } + public function testSuccess() { - $result = h_parse($this->parser, "a"); + echo 'in testSuccess\n'; +// $result = h_parse($this->parser, "a"); // TODO: fixme when h_ch is fixed - $this->assertEquals(98, $result); +// $this->assertEquals(98, $result); } +/* public function testFailure() { $result = h_parse($this->parser, "aa"); $this->assertEquals(NULL, $result); } +*/ } ?> \ No newline at end of file diff --git a/src/bindings/php/Tests/LeftTest.php b/src/bindings/php/Tests/LeftTest.php index 4f50e0e702793ae2afbc5a9d68b3edcfb2bda8de..1b2a906b47d14048d2941dd0e55f27fbbb7a1827 100644 --- a/src/bindings/php/Tests/LeftTest.php +++ b/src/bindings/php/Tests/LeftTest.php @@ -7,13 +7,13 @@ class LeftTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser = h_left(h_ch("a"), h_ch(" ")); + $this->parser = h_left(ch("a"), ch(" ")); } public function testSuccess() { $result = h_parse($this->parser, "a "); // TODO fix these tests when h_ch is fixed - $this->assertEquals(97, $result); + $this->assertEquals("a", $result); } public function testFailure() { diff --git a/src/bindings/php/Tests/MiddleTest.php b/src/bindings/php/Tests/MiddleTest.php index c284b501d9b55bd720a057efc09fe8c97d8dc743..99dbb871e31bcd472a030011bd6500e8e5e42968 100644 --- a/src/bindings/php/Tests/MiddleTest.php +++ b/src/bindings/php/Tests/MiddleTest.php @@ -7,13 +7,13 @@ class MiddleTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser = h_middle(h_ch(" "), h_ch("a"), h_ch(" ")); + $this->parser = h_middle(ch(" "), ch("a"), ch(" ")); } public function testSuccess() { $result = h_parse($this->parser, " a "); // TODO fix these tests when h_ch is fixed - $this->assertEquals(97, $result); + $this->assertEquals("a", $result); } public function testFailure() { diff --git a/src/bindings/php/Tests/RightTest.php b/src/bindings/php/Tests/RightTest.php index c6642518656b8692825f422475e546bf1fc48037..d5d442891a8b18a5139a9be8d2b0c1fd535d504f 100644 --- a/src/bindings/php/Tests/RightTest.php +++ b/src/bindings/php/Tests/RightTest.php @@ -7,13 +7,13 @@ class RightTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser = h_right(h_ch(" "), h_ch("a")); + $this->parser = h_right(ch(" "), ch("a")); } public function testSuccess() { $result = h_parse($this->parser, " a"); // TODO fix these tests when h_ch is fixed - $this->assertEquals(97, $result); + $this->assertEquals("a", $result); } public function testFailure() { diff --git a/src/bindings/php/Tests/WhitespaceTest.php b/src/bindings/php/Tests/WhitespaceTest.php index 64da3a2271f562ccc71bc829b1a16008f6972e55..73c4d4530e7e45e6d550aa8cf0578a4e610a68d2 100644 --- a/src/bindings/php/Tests/WhitespaceTest.php +++ b/src/bindings/php/Tests/WhitespaceTest.php @@ -8,7 +8,7 @@ class WhitespaceTest extends PHPUnit_Framework_TestCase protected function setUp() { - $this->parser1 = h_whitespace(h_ch("a")); + $this->parser1 = h_whitespace(ch("a")); $this->parser2 = h_whitespace(h_end_p()); } public function testSuccess1() @@ -18,10 +18,10 @@ class WhitespaceTest extends PHPUnit_Framework_TestCase $result3 = h_parse($this->parser1, " a"); $result4 = h_parse($this->parser1, "\ta"); // TODO fix these tests when h_ch is fixed - $this->assertEquals(97, $result1); - $this->assertEquals(97, $result2); - $this->assertEquals(97, $result3); - $this->assertEquals(97, $result4); + $this->assertEquals("a", $result1); + $this->assertEquals("a", $result2); + $this->assertEquals("a", $result3); + $this->assertEquals("a", $result4); } public function testFailure1() { diff --git a/src/bindings/swig/hammer.i b/src/bindings/swig/hammer.i index 49b9b6f08e384c9569f9f5dbc898586ecd3fd07e..be69675101aa147c490516c28531a00f6cc2058b 100644 --- a/src/bindings/swig/hammer.i +++ b/src/bindings/swig/hammer.i @@ -538,4 +538,33 @@ def int64(): return _h_int64() return tok; } } + +%pragma(php) code=" + +function ch($ch) +{ + if (is_string($ch)) + return h_token($ch); + else + return h_ch($ch); +} + +function sequence() +{ + echo 'in sequence\n'; + $numargs = func_num_args(); + $arg_list = func_get_args(); + var_dump($arg_list); + for ($i = 0; $i < $numargs; $i++) + { + var_dump($arg_list[$i] instanceof _p_HParser_); + if (! $arg_list[$i] instanceof _p_HParser_) + { + echo 'PHP says that is not an HParser!'; + return NULL; + } + } + //return hammer::h_sequence__a($arg_list); +} +" #endif