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 {
27 function __construct($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
33 $s = "$dbms error: [$errno: $errmsg] in $fn(\"$p1\")\n";
38 $user = $thisConnection->user;
39 $s = "$dbms error: [$errno: $errmsg] in $fn($p1, '$user', '****', $p2)\n";
42 $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)\n";
47 $this->host = $thisConnection->host;
48 $this->database = $thisConnection->database;
52 if (!is_numeric($errno)) $errno = -1;
53 parent::__construct($s,$errno);
58 * Default Error Handler. This will be called with the following params
60 * @param $dbms the RDBMS you are connecting to
61 * @param $fn the name of the calling function (in uppercase)
62 * @param $errno the native error number from the database
63 * @param $errmsg the native error msg from the database
64 * @param $p1 $fn specific parameter - see below
65 * @param $P2 $fn specific parameter - see below
68 function adodb_throw($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
70 global $ADODB_EXCEPTION;
72 if (is_string($ADODB_EXCEPTION)) $errfn = $ADODB_EXCEPTION;
73 else $errfn = 'ADODB_EXCEPTION';
74 throw new $errfn($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection);