From 7342bb8b7a5e7f532f5e0cc2a423f02533a63ad4 Mon Sep 17 00:00:00 2001 From: thomascube Date: Tue, 19 Apr 2011 21:00:34 +0000 Subject: Check for DB connection state instead of handle (handle could be an error object) --- program/include/rcube_mdb2.php | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) (limited to 'program') diff --git a/program/include/rcube_mdb2.php b/program/include/rcube_mdb2.php index 7675e847f..707bce027 100644 --- a/program/include/rcube_mdb2.php +++ b/program/include/rcube_mdb2.php @@ -30,7 +30,7 @@ * @author David Saez Padros * @author Thomas Bruederli * @author Lukas Kahwe Smith - * @version 1.17 + * @version 1.18 * @link http://pear.php.net/package/MDB2 */ class rcube_mdb2 @@ -142,7 +142,9 @@ class rcube_mdb2 $this->db_handle = $this->dsn_connect($dsn); $this->db_connected = !PEAR::isError($this->db_handle); - $this->db_mode = $mode; + + if ($this->db_connected) + $this->db_mode = $mode; } @@ -291,7 +293,7 @@ class rcube_mdb2 */ function num_rows($res_id=null) { - if (!$this->db_handle) + if (!$this->db_connected) return false; if ($result = $this->_get_result($res_id)) @@ -310,7 +312,7 @@ class rcube_mdb2 */ function affected_rows($res_id = null) { - if (!$this->db_handle) + if (!$this->db_connected) return false; return (int) $this->_get_result($res_id); @@ -327,7 +329,7 @@ class rcube_mdb2 */ function insert_id($table = '') { - if (!$this->db_handle || $this->db_mode == 'r') + if (!$this->db_connected || $this->db_mode == 'r') return false; if ($table) { @@ -449,7 +451,7 @@ class rcube_mdb2 if (!$this->db_handle) $this->db_connect('r'); - return $this->db_handle->quote($input, $type); + return $this->db_connected ? $this->db_handle->quote($input, $type) : addslashes($input); } @@ -480,7 +482,7 @@ class rcube_mdb2 if (!$this->db_handle) $this->db_connect('r'); - return $this->db_handle->quoteIdentifier($str); + return $this->db_connected ? $this->db_handle->quoteIdentifier($str) : $str; } -- cgit v1.2.3