now throw PHP Exception objects instead of giving a PHP error of type E_ERROR. This change shouldn't cause incompatibility issues, since you can't set an error handler for E_ERROR, so previously PHP would just exit which also happens for unhandled exceptions. The benefit is you can now catch them if you want to. Fixes SF#2545578 and SF#2955522. git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@12055 626c5289-ae23-0410-ae9c-e8d60b6d4f22
39 lines
853 B
PHP
39 lines
853 B
PHP
<?
|
|
require "tests.php";
|
|
require "exception_order.php";
|
|
|
|
check::functions(array(a_foo,a_bar,a_foobar,a_barfoo));
|
|
check::classes(array(A,E1,E2,E3,exception_order,ET_i,ET_d));
|
|
check::globals(array(efoovar,foovar,cfoovar,a_sfoovar,a_foovar,a_efoovar));
|
|
|
|
$a = new A();
|
|
try {
|
|
$a->foo();
|
|
} catch (Exception $e) {
|
|
check::equal($e->getMessage(), 'C++ E1 exception thrown', '');
|
|
}
|
|
|
|
try {
|
|
$a->bar();
|
|
} catch (Exception $e) {
|
|
check::equal($e->getMessage(), 'C++ E2 exception thrown', '');
|
|
}
|
|
|
|
try {
|
|
$a->foobar();
|
|
} catch (Exception $e) {
|
|
check::equal($e->getMessage(), 'postcatch unknown', '');
|
|
}
|
|
|
|
try {
|
|
$a->barfoo(1);
|
|
} catch (Exception $e) {
|
|
check::equal($e->getMessage(), 'C++ E1 exception thrown', '');
|
|
}
|
|
|
|
try {
|
|
$a->barfoo(2);
|
|
} catch (Exception $e) {
|
|
check::equal($e->getMessage(), 'C++ E2 * exception thrown', '');
|
|
}
|
|
?>
|