break;
}
default:
- php_sqlite3_error(db_obj, "Unable to execute statement: %s", sqlite3_errmsg(db_obj->db));
+ if (!EG(exception)) {
+ php_sqlite3_error(db_obj, "Unable to execute statement: %s", sqlite3_errmsg(db_obj->db));
+ }
sqlite3_finalize(stmt_obj->stmt);
stmt_obj->initialised = 0;
zval_dtor(return_value);
break;
}
default:
- php_sqlite3_error(db_obj, "Unable to execute statement: %s", sqlite3_errmsg(db_obj->db));
+ if (!EG(exception)) {
+ php_sqlite3_error(db_obj, "Unable to execute statement: %s", sqlite3_errmsg(db_obj->db));
+ }
RETVAL_FALSE;
}
sqlite3_finalize(stmt);
sqlite3_reset(stmt_obj->stmt);
default:
- php_sqlite3_error(stmt_obj->db_obj, "Unable to execute statement: %s", sqlite3_errmsg(sqlite3_db_handle(stmt_obj->stmt)));
+ if (!EG(exception)) {
+ php_sqlite3_error(stmt_obj->db_obj, "Unable to execute statement: %s", sqlite3_errmsg(sqlite3_db_handle(stmt_obj->stmt)));
+ }
zval_dtor(return_value);
RETURN_FALSE;
}
--- /dev/null
+--TEST--
+Bug #72668 (Spurious warning when exception is thrown in user defined function)
+--SKIPIF--
+<?php
+if (!extension_loaded('sqlite3')) die('skip'); ?>
+--FILE--
+<?php
+function my_udf_md5($string) {
+ throw new \Exception("test exception\n");
+}
+
+$db = new SQLite3(':memory:');
+$db->createFunction('my_udf_md5', 'my_udf_md5');
+
+try {
+ $result = $db->query('SELECT my_udf_md5("test")');
+ var_dump($result);
+}
+catch(\Exception $e) {
+ echo "Exception: ".$e->getMessage();
+}
+try {
+ $result = $db->querySingle('SELECT my_udf_md5("test")');
+ var_dump($result);
+}
+catch(\Exception $e) {
+ echo "Exception: ".$e->getMessage();
+}
+$statement = $db->prepare('SELECT my_udf_md5("test")');
+try {
+ $result = $statement->execute();
+ var_dump($result);
+}
+catch(\Exception $e) {
+ echo "Exception: ".$e->getMessage();
+}
+?>
+--EXPECT--
+Exception: test exception
+Exception: test exception
+Exception: test exception