mirror of
https://github.com/phpv8/v8js.git
synced 2025-01-07 03:41:52 +00:00
Merge pull request #5 from tenorviol/master
Replaced deprecated v8 methods with newer equivalents
This commit is contained in:
commit
c2512e42dd
@ -1,4 +0,0 @@
|
|||||||
037+ Mon Sep 08 1975 09:00:00 GMT-0700 (PDT)
|
|
||||||
037- Mon Sep 08 1975 09:00:00 GMT+0200 (EET)
|
|
||||||
046+ string(6) "-07:00"
|
|
||||||
046- string(6) "+02:00"
|
|
@ -1,85 +0,0 @@
|
|||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
bool(true)
|
|
||||||
[1]=>
|
|
||||||
bool(false)
|
|
||||||
[2]=>
|
|
||||||
int(1234567890)
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
float(3.14)
|
|
||||||
[1]=>
|
|
||||||
int(42)
|
|
||||||
[2]=>
|
|
||||||
NULL
|
|
||||||
}
|
|
||||||
test4.js:1: TypeError: Testing::mytest() expects at least 2 parameters, 0 given
|
|
||||||
array(4) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
[2]=>
|
|
||||||
string(4) "arg3"
|
|
||||||
[3]=>
|
|
||||||
string(9) "extra_arg"
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST: Javascript Date -> PHP DateTime
|
|
||||||
======================================
|
|
||||||
Mon Sep 08 1975 09:00:00 GMT+0200 (EET)
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
object(DateTime)#4 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
string(3) "foo"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
object(V8Object)#4 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
[2]=>
|
|
||||||
object(V8Object)#5 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
===EOF===
|
|
@ -1,174 +0,0 @@
|
|||||||
|
|
||||||
---- EXPECTED OUTPUT
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
bool(true)
|
|
||||||
[1]=>
|
|
||||||
bool(false)
|
|
||||||
[2]=>
|
|
||||||
int(1234567890)
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
float(3.14)
|
|
||||||
[1]=>
|
|
||||||
int(42)
|
|
||||||
[2]=>
|
|
||||||
NULL
|
|
||||||
}
|
|
||||||
test4.js:1: TypeError: Testing::mytest() expects at least 2 parameters, 0 given
|
|
||||||
array(4) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
[2]=>
|
|
||||||
string(4) "arg3"
|
|
||||||
[3]=>
|
|
||||||
string(9) "extra_arg"
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST: Javascript Date -> PHP DateTime
|
|
||||||
======================================
|
|
||||||
Mon Sep 08 1975 09:00:00 GMT+0200 (EET)
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
object(DateTime)#4 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
string(3) "foo"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
object(V8Object)#4 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
[2]=>
|
|
||||||
object(V8Object)#5 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
===EOF===
|
|
||||||
---- ACTUAL OUTPUT
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
bool(true)
|
|
||||||
[1]=>
|
|
||||||
bool(false)
|
|
||||||
[2]=>
|
|
||||||
int(1234567890)
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
float(3.14)
|
|
||||||
[1]=>
|
|
||||||
int(42)
|
|
||||||
[2]=>
|
|
||||||
NULL
|
|
||||||
}
|
|
||||||
test4.js:1: TypeError: Testing::mytest() expects at least 2 parameters, 0 given
|
|
||||||
array(4) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
[2]=>
|
|
||||||
string(4) "arg3"
|
|
||||||
[3]=>
|
|
||||||
string(9) "extra_arg"
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST: Javascript Date -> PHP DateTime
|
|
||||||
======================================
|
|
||||||
Mon Sep 08 1975 09:00:00 GMT-0700 (PDT)
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
object(DateTime)#4 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "-07:00"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
string(3) "foo"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
object(V8Object)#4 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
[2]=>
|
|
||||||
object(V8Object)#5 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
===EOF===
|
|
||||||
---- FAILED
|
|
@ -1,85 +0,0 @@
|
|||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
bool(true)
|
|
||||||
[1]=>
|
|
||||||
bool(false)
|
|
||||||
[2]=>
|
|
||||||
int(1234567890)
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
float(3.14)
|
|
||||||
[1]=>
|
|
||||||
int(42)
|
|
||||||
[2]=>
|
|
||||||
NULL
|
|
||||||
}
|
|
||||||
test4.js:1: TypeError: Testing::mytest() expects at least 2 parameters, 0 given
|
|
||||||
array(4) {
|
|
||||||
[0]=>
|
|
||||||
string(4) "arg1"
|
|
||||||
[1]=>
|
|
||||||
string(4) "arg2"
|
|
||||||
[2]=>
|
|
||||||
string(4) "arg3"
|
|
||||||
[3]=>
|
|
||||||
string(9) "extra_arg"
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST: Javascript Date -> PHP DateTime
|
|
||||||
======================================
|
|
||||||
Mon Sep 08 1975 09:00:00 GMT-0700 (PDT)
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
object(DateTime)#4 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "-07:00"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
string(3) "foo"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
object(V8Object)#4 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
[2]=>
|
|
||||||
object(V8Object)#5 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#6 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
===EOF===
|
|
@ -1,53 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
// Test class
|
|
||||||
class Testing
|
|
||||||
{
|
|
||||||
public $foo = 'ORIGINAL';
|
|
||||||
private $my_private = 'arf'; // Should not show in JS side
|
|
||||||
protected $my_protected = 'argh'; // Should not show in JS side
|
|
||||||
|
|
||||||
function mytest($a, $b, $c = NULL)
|
|
||||||
{
|
|
||||||
var_dump(func_get_args());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$a = new V8Js();
|
|
||||||
$a->myobj = new Testing();
|
|
||||||
|
|
||||||
$a->executeString("PHP.myobj.mytest('arg1', 'arg2');", "test1.js");
|
|
||||||
$a->executeString("PHP.myobj.mytest(true, false, 1234567890);", "test2.js");
|
|
||||||
$a->executeString("PHP.myobj.mytest(3.14, 42, null);", "test3.js");
|
|
||||||
|
|
||||||
// Invalid parameters
|
|
||||||
try {
|
|
||||||
$a->executeString("PHP.myobj.mytest();", "test4.js");
|
|
||||||
} catch (V8JsException $e) {
|
|
||||||
echo $e->getMessage(), "\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
$a->executeString("PHP.myobj.mytest('arg1', 'arg2', 'arg3', 'extra_arg');", "test5.js");
|
|
||||||
} catch (V8JsException $e) {
|
|
||||||
echo $e->getMessage(), "\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
date_default_timezone_set("UTC");
|
|
||||||
echo "\nTEST: Javascript Date -> PHP DateTime\n";
|
|
||||||
echo "======================================\n";
|
|
||||||
$a->executeString("date = new Date('September 8, 1975 09:00:00'); print(date + '\\n'); PHP.myobj.mytest(date, 'foo');", "test6.js");
|
|
||||||
} catch (V8JsException $e) {
|
|
||||||
echo $e->getMessage(), "\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Array / Object
|
|
||||||
try {
|
|
||||||
$a->executeString("PHP.myobj.mytest(PHP.myobj, new Array(1,2,3), new Array('foo', 'bar', PHP.myobj));", "test7.js");
|
|
||||||
} catch (V8JsException $e) {
|
|
||||||
var_dump($e);
|
|
||||||
}
|
|
||||||
|
|
||||||
?>
|
|
||||||
===EOF===
|
|
@ -2,6 +2,8 @@
|
|||||||
Test V8::executeString() : Calling methods of object passed from PHP
|
Test V8::executeString() : Calling methods of object passed from PHP
|
||||||
--SKIPIF--
|
--SKIPIF--
|
||||||
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--INI--
|
||||||
|
date.timezone=UTC
|
||||||
--FILE--
|
--FILE--
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
@ -16,6 +18,12 @@ class Testing
|
|||||||
{
|
{
|
||||||
var_dump(func_get_args());
|
var_dump(func_get_args());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function mydatetest(DateTime $date, $b) {
|
||||||
|
$date->setTimeZone(new DateTimeZone(ini_get('date.timezone')));
|
||||||
|
echo $date->format(DateTime::RFC1123), "\n";
|
||||||
|
var_dump($b);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$a = new V8Js();
|
$a = new V8Js();
|
||||||
@ -39,10 +47,9 @@ try {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
date_default_timezone_set("UTC");
|
|
||||||
echo "\nTEST: Javascript Date -> PHP DateTime\n";
|
echo "\nTEST: Javascript Date -> PHP DateTime\n";
|
||||||
echo "======================================\n";
|
echo "======================================\n";
|
||||||
$a->executeString("date = new Date('September 8, 1975 09:00:00'); print(date + '\\n'); PHP.myobj.mytest(date, 'foo');", "test6.js");
|
$a->executeString("date = new Date('September 8, 1975 09:00:00 GMT'); print(date.toUTCString() + '\\n'); PHP.myobj.mydatetest(date, 'foo');", "test6.js");
|
||||||
} catch (V8JsException $e) {
|
} catch (V8JsException $e) {
|
||||||
echo $e->getMessage(), "\n";
|
echo $e->getMessage(), "\n";
|
||||||
}
|
}
|
||||||
@ -93,26 +100,18 @@ array(4) {
|
|||||||
|
|
||||||
TEST: Javascript Date -> PHP DateTime
|
TEST: Javascript Date -> PHP DateTime
|
||||||
======================================
|
======================================
|
||||||
Mon Sep 08 1975 09:00:00 GMT+0200 (EET)
|
Mon, 08 Sep 1975 09:00:00 GMT
|
||||||
array(2) {
|
Mon, 08 Sep 1975 09:00:00 +0000
|
||||||
[0]=>
|
|
||||||
object(DateTime)#4 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
[1]=>
|
|
||||||
string(3) "foo"
|
string(3) "foo"
|
||||||
}
|
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
object(V8Object)#4 (2) {
|
object(V8Object)#4 (3) {
|
||||||
["mytest"]=>
|
["mytest"]=>
|
||||||
object(V8Function)#6 (0) {
|
object(V8Function)#6 (0) {
|
||||||
}
|
}
|
||||||
|
["mydatetest"]=>
|
||||||
|
object(V8Function)#7 (0) {
|
||||||
|
}
|
||||||
["foo"]=>
|
["foo"]=>
|
||||||
string(8) "ORIGINAL"
|
string(8) "ORIGINAL"
|
||||||
}
|
}
|
||||||
@ -132,8 +131,11 @@ array(3) {
|
|||||||
[1]=>
|
[1]=>
|
||||||
string(3) "bar"
|
string(3) "bar"
|
||||||
[2]=>
|
[2]=>
|
||||||
object(V8Object)#5 (2) {
|
object(V8Object)#5 (3) {
|
||||||
["mytest"]=>
|
["mytest"]=>
|
||||||
|
object(V8Function)#7 (0) {
|
||||||
|
}
|
||||||
|
["mydatetest"]=>
|
||||||
object(V8Function)#6 (0) {
|
object(V8Function)#6 (0) {
|
||||||
}
|
}
|
||||||
["foo"]=>
|
["foo"]=>
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
035+ string(6) "-07:00"
|
|
||||||
035- string(6) "+02:00"
|
|
@ -1,42 +0,0 @@
|
|||||||
NULL
|
|
||||||
object(V8Object)#3 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#4 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
object(DateTime)#3 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
int(1234567890)
|
|
||||||
float(123.456789)
|
|
||||||
string(11) "some string"
|
|
||||||
bool(true)
|
|
||||||
bool(false)
|
|
||||||
===EOF===
|
|
@ -1,88 +0,0 @@
|
|||||||
|
|
||||||
---- EXPECTED OUTPUT
|
|
||||||
NULL
|
|
||||||
object(V8Object)#3 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#4 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
object(DateTime)#3 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
int(1234567890)
|
|
||||||
float(123.456789)
|
|
||||||
string(11) "some string"
|
|
||||||
bool(true)
|
|
||||||
bool(false)
|
|
||||||
===EOF===
|
|
||||||
---- ACTUAL OUTPUT
|
|
||||||
NULL
|
|
||||||
object(V8Object)#3 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#4 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
object(DateTime)#3 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "-07:00"
|
|
||||||
}
|
|
||||||
int(1234567890)
|
|
||||||
float(123.456789)
|
|
||||||
string(11) "some string"
|
|
||||||
bool(true)
|
|
||||||
bool(false)
|
|
||||||
===EOF===
|
|
||||||
---- FAILED
|
|
@ -1,42 +0,0 @@
|
|||||||
NULL
|
|
||||||
object(V8Object)#3 (2) {
|
|
||||||
["mytest"]=>
|
|
||||||
object(V8Function)#4 (0) {
|
|
||||||
}
|
|
||||||
["foo"]=>
|
|
||||||
string(8) "ORIGINAL"
|
|
||||||
}
|
|
||||||
array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(2)
|
|
||||||
[2]=>
|
|
||||||
int(3)
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
array(2) {
|
|
||||||
[0]=>
|
|
||||||
string(3) "foo"
|
|
||||||
[1]=>
|
|
||||||
string(3) "bar"
|
|
||||||
}
|
|
||||||
object(DateTime)#3 (3) {
|
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "-07:00"
|
|
||||||
}
|
|
||||||
int(1234567890)
|
|
||||||
float(123.456789)
|
|
||||||
string(11) "some string"
|
|
||||||
bool(true)
|
|
||||||
bool(false)
|
|
||||||
===EOF===
|
|
@ -1,34 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
$JS = <<< EOT
|
|
||||||
function test(passed)
|
|
||||||
{
|
|
||||||
return passed;
|
|
||||||
}
|
|
||||||
EOT;
|
|
||||||
|
|
||||||
// Test class
|
|
||||||
class Testing
|
|
||||||
{
|
|
||||||
public $foo = 'ORIGINAL';
|
|
||||||
private $my_private = 'arf'; // Should not show in JS side
|
|
||||||
protected $my_protected = 'argh'; // Should not show in JS side
|
|
||||||
|
|
||||||
function mytest() { echo 'Here be monsters..', "\n"; }
|
|
||||||
}
|
|
||||||
|
|
||||||
$a = new V8Js();
|
|
||||||
$a->myobj = new Testing();
|
|
||||||
var_dump($a->executeString($JS, "test.js"));
|
|
||||||
var_dump($a->executeString("test(PHP.myobj);", "test1.js"));
|
|
||||||
var_dump($a->executeString("test(new Array(1,2,3));", "test2.js"));
|
|
||||||
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
|
||||||
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
|
||||||
var_dump($a->executeString("test(new Date('September 8, 1975 09:00:00'));", "test4.js"));
|
|
||||||
var_dump($a->executeString("test(1234567890);", "test5.js"));
|
|
||||||
var_dump($a->executeString("test(123.456789);", "test6.js"));
|
|
||||||
var_dump($a->executeString("test('some string');", "test7.js"));
|
|
||||||
var_dump($a->executeString("test(true);", "test8.js"));
|
|
||||||
var_dump($a->executeString("test(false);", "test9.js"));
|
|
||||||
?>
|
|
||||||
===EOF===
|
|
@ -2,6 +2,8 @@
|
|||||||
Test V8::executeString() : Return values
|
Test V8::executeString() : Return values
|
||||||
--SKIPIF--
|
--SKIPIF--
|
||||||
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--INI--
|
||||||
|
date.timezone=UTC
|
||||||
--FILE--
|
--FILE--
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
@ -29,7 +31,9 @@ var_dump($a->executeString("test(PHP.myobj);", "test1.js"));
|
|||||||
var_dump($a->executeString("test(new Array(1,2,3));", "test2.js"));
|
var_dump($a->executeString("test(new Array(1,2,3));", "test2.js"));
|
||||||
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
||||||
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
var_dump($a->executeString("test(new Array('foo', 'bar'));", "test3.js"));
|
||||||
var_dump($a->executeString("test(new Date('September 8, 1975 09:00:00'));", "test4.js"));
|
$date = $a->executeString("test(new Date('September 8, 1975 09:00:00 GMT'));", "test4.js");
|
||||||
|
$date->setTimeZone(new DateTimeZone('GMT'));
|
||||||
|
echo $date->format(DateTime::RFC1123), "\n";
|
||||||
var_dump($a->executeString("test(1234567890);", "test5.js"));
|
var_dump($a->executeString("test(1234567890);", "test5.js"));
|
||||||
var_dump($a->executeString("test(123.456789);", "test6.js"));
|
var_dump($a->executeString("test(123.456789);", "test6.js"));
|
||||||
var_dump($a->executeString("test('some string');", "test7.js"));
|
var_dump($a->executeString("test('some string');", "test7.js"));
|
||||||
@ -66,14 +70,7 @@ array(2) {
|
|||||||
[1]=>
|
[1]=>
|
||||||
string(3) "bar"
|
string(3) "bar"
|
||||||
}
|
}
|
||||||
object(DateTime)#3 (3) {
|
Mon, 08 Sep 1975 09:00:00 +0000
|
||||||
["date"]=>
|
|
||||||
string(19) "1975-09-08 09:00:00"
|
|
||||||
["timezone_type"]=>
|
|
||||||
int(1)
|
|
||||||
["timezone"]=>
|
|
||||||
string(6) "+02:00"
|
|
||||||
}
|
|
||||||
int(1234567890)
|
int(1234567890)
|
||||||
float(123.456789)
|
float(123.456789)
|
||||||
string(11) "some string"
|
string(11) "some string"
|
||||||
|
@ -37,7 +37,7 @@ extern "C" {
|
|||||||
static v8::Handle<v8::Value> php_v8js_php_callback(const v8::Arguments &args) /* {{{ */
|
static v8::Handle<v8::Value> php_v8js_php_callback(const v8::Arguments &args) /* {{{ */
|
||||||
{
|
{
|
||||||
v8::Handle<v8::Value> return_value;
|
v8::Handle<v8::Value> return_value;
|
||||||
zval *value = reinterpret_cast<zval *>(args.This()->GetPointerFromInternalField(0));
|
zval *value = reinterpret_cast<zval *>(args.This()->GetAlignedPointerFromInternalField(0));
|
||||||
zend_function *method_ptr;
|
zend_function *method_ptr;
|
||||||
zend_fcall_info fci;
|
zend_fcall_info fci;
|
||||||
zend_fcall_info_cache fcc;
|
zend_fcall_info_cache fcc;
|
||||||
@ -50,7 +50,7 @@ static v8::Handle<v8::Value> php_v8js_php_callback(const v8::Arguments &args) /*
|
|||||||
|
|
||||||
/* Set method_ptr from v8::External or fetch the closure invoker */
|
/* Set method_ptr from v8::External or fetch the closure invoker */
|
||||||
if (!args.Data().IsEmpty() && args.Data()->IsExternal()) {
|
if (!args.Data().IsEmpty() && args.Data()->IsExternal()) {
|
||||||
method_ptr = static_cast<zend_function *>(v8::External::Unwrap(args.Data()));
|
method_ptr = static_cast<zend_function *>(v8::External::Cast(*args.Data())->Value());
|
||||||
} else {
|
} else {
|
||||||
method_ptr = zend_get_closure_invoke_method(value TSRMLS_CC);
|
method_ptr = zend_get_closure_invoke_method(value TSRMLS_CC);
|
||||||
}
|
}
|
||||||
@ -384,7 +384,7 @@ static v8::Handle<v8::Value> php_v8js_hash_to_jsobj(zval *value TSRMLS_DC) /* {{
|
|||||||
newobj->SetHiddenValue(V8JS_SYM(ZEND_ISSET_FUNC_NAME), PHP_V8JS_CALLBACK(isset_ptr));
|
newobj->SetHiddenValue(V8JS_SYM(ZEND_ISSET_FUNC_NAME), PHP_V8JS_CALLBACK(isset_ptr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
newobj->SetPointerInInternalField(0, (void *) value);
|
newobj->SetAlignedPointerInInternalField(0, (void *) value);
|
||||||
} else {
|
} else {
|
||||||
new_tpl->SetClassName(V8JS_SYM("Array"));
|
new_tpl->SetClassName(V8JS_SYM("Array"));
|
||||||
newobj = new_tpl->InstanceTemplate()->NewInstance();
|
newobj = new_tpl->InstanceTemplate()->NewInstance();
|
||||||
|
Loading…
Reference in New Issue
Block a user