summaryrefslogtreecommitdiff
path: root/ext/sqlite3/sqlite3.c
diff options
context:
space:
mode:
authorChristoph M. Becker <cmb@php.net>2016-07-25 17:03:10 +0200
committerChristoph M. Becker <cmb@php.net>2016-07-25 17:03:10 +0200
commit64e3e932fc38dc7e59805dfb28acae173503018b (patch)
tree77e90475886a971b395db47107e18ee071953571 /ext/sqlite3/sqlite3.c
parent0c34d515f16963922bed749c9320a99043c06722 (diff)
downloadphp-git-64e3e932fc38dc7e59805dfb28acae173503018b.tar.gz
Further fixes wrt. bug #72668
Not only SQLite3::querySingle(), but also SQLite3::query() and SQLite3Stmt::execute() were affected.
Diffstat (limited to 'ext/sqlite3/sqlite3.c')
-rw-r--r--ext/sqlite3/sqlite3.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/ext/sqlite3/sqlite3.c b/ext/sqlite3/sqlite3.c
index 4513b77d0f..c901e536a0 100644
--- a/ext/sqlite3/sqlite3.c
+++ b/ext/sqlite3/sqlite3.c
@@ -578,7 +578,9 @@ PHP_METHOD(sqlite3, query)
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);
@@ -690,7 +692,9 @@ PHP_METHOD(sqlite3, querySingle)
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);
@@ -1637,7 +1641,9 @@ PHP_METHOD(sqlite3stmt, execute)
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;
}