3 * @version V4.22 15 Apr 2004 (c) 2000-2004 John Lim (jlim@natsoft.com.my). All rights reserved.
4 * Released under both BSD license and Lesser GPL library license.
5 Whenever there is any discrepancy between the two licenses,
6 the BSD license will take precedence.
8 * Set tabs to 4 for best viewing.
10 * Latest version is available at http://php.weblogs.com
13 include_once 'PEAR.php';
15 define('ADODB_ERROR_HANDLER', 'ADODB_Error_PEAR');
18 * Enabled the following if you want to terminate scripts when an error occurs
20 //PEAR::setErrorHandling (PEAR_ERROR_DIE);
23 * Name of the PEAR_Error derived class to call.
25 if (!defined('ADODB_PEAR_ERROR_CLASS')) define('ADODB_PEAR_ERROR_CLASS', 'PEAR_Error');
28 * Store the last PEAR_Error object here
30 global $ADODB_Last_PEAR_Error;
31 $ADODB_Last_PEAR_Error = false;
34 * Error Handler with PEAR support. This will be called with the following params
36 * @param $dbms the RDBMS you are connecting to
37 * @param $fn the name of the calling function (in uppercase)
38 * @param $errno the native error number from the database
39 * @param $errmsg the native error msg from the database
40 * @param $p1 $fn specific parameter - see below
41 * @param $P2 $fn specific parameter - see below
43 function ADODB_Error_PEAR($dbms, $fn, $errno, $errmsg, $p1 = false, $p2 = false)
45 global $ADODB_Last_PEAR_Error;
47 if (error_reporting() == 0) return; // obey @ protocol
53 $s = "$dbms error: [$errno: $errmsg] in $fn(\"$sql\")";
61 $s = "$dbms error: [$errno: $errmsg] in $fn('$host', ?, ?, '$database')";
65 $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)";
69 $class = ADODB_PEAR_ERROR_CLASS;
70 $ADODB_Last_PEAR_Error = new $class($s, $errno,
71 $GLOBALS['_PEAR_default_error_mode'],
72 $GLOBALS['_PEAR_default_error_options'],
79 * Returns last PEAR_Error object. This error might be for an error that
80 * occured several sql statements ago.
82 function &ADODB_PEAR_Error()
84 global $ADODB_Last_PEAR_Error;
86 return $ADODB_Last_PEAR_Error;