0
0
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:
Patrick Reilly 2013-03-18 20:11:16 -07:00
commit c2512e42dd
13 changed files with 32 additions and 642 deletions

View File

@ -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"

View File

@ -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===

View File

@ -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

View File

@ -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===

View File

@ -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===

View File

@ -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"]=>

View File

@ -1,2 +0,0 @@
035+ string(6) "-07:00"
035- string(6) "+02:00"

View File

@ -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===

View File

@ -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

View File

@ -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===

View File

@ -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===

View File

@ -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"

View File

@ -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();