4 * @version V4.22 15 Apr 2004 (c) 2000-2004 John Lim (jlim@natsoft.com.my). All rights reserved.
5 * Released under both BSD license and Lesser GPL library license.
6 * Whenever there is any discrepancy between the two licenses,
7 * the BSD license will take precedence.
9 * Set tabs to 4 for best viewing.
11 * Latest version is available at http://php.weblogs.com
13 * Exception-handling code using PHP5 exceptions (try-catch-throw).
16 if (!defined('ADODB_ERROR_HANDLER_TYPE')) define('ADODB_ERROR_HANDLER_TYPE', E_USER_ERROR);
17 define('ADODB_ERROR_HANDLER', 'adodb_throw');
19 class ADODB_Exception extends Exception
28 function __construct($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
34 $s = "$dbms error: [$errno: $errmsg] in $fn(\"$p1\")\n";
39 $user = $thisConnection->user;
40 $s = "$dbms error: [$errno: $errmsg] in $fn($p1, '$user', '****', $p2)\n";
43 $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)\n";
48 $this->host = $thisConnection->host;
49 $this->database = $thisConnection->database;
53 if (!is_numeric($errno)) $errno = -1;
54 parent::__construct($s, $errno);
59 * Default Error Handler. This will be called with the following params
61 * @param $dbms the RDBMS you are connecting to
62 * @param $fn the name of the calling function (in uppercase)
63 * @param $errno the native error number from the database
64 * @param $errmsg the native error msg from the database
65 * @param $p1 $fn specific parameter - see below
66 * @param $P2 $fn specific parameter - see below
69 function adodb_throw($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
71 global $ADODB_EXCEPTION;
73 if (is_string($ADODB_EXCEPTION)) $errfn = $ADODB_EXCEPTION;
74 else $errfn = 'ADODB_EXCEPTION';
75 throw new $errfn($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection);