source: companies/celepar/phpgwapi/inc/adodb/adodb-exceptions.inc.php @ 763

Revision 763, 2.2 KB checked in by niltonneto, 15 years ago (diff)

Importação inicial do Expresso da Celepar

Line 
1<?php
2
3/**
4 * @version V4.94 23 Jan 2007  (c) 2000-2007 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.
8 *
9 * Set tabs to 4 for best viewing.
10 *
11 * Latest version is available at http://php.weblogs.com
12 *
13 * Exception-handling code using PHP5 exceptions (try-catch-throw).
14 */
15
16
17if (!defined('ADODB_ERROR_HANDLER_TYPE')) define('ADODB_ERROR_HANDLER_TYPE',E_USER_ERROR);
18define('ADODB_ERROR_HANDLER','adodb_throw');
19
20class ADODB_Exception extends Exception {
21var $dbms;
22var $fn;
23var $sql = '';
24var $params = '';
25var $host = '';
26var $database = '';
27       
28        function __construct($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
29        {
30                switch($fn) {
31                case 'EXECUTE':
32                        $this->sql = $p1;
33                        $this->params = $p2;
34                        $s = "$dbms error: [$errno: $errmsg] in $fn(\"$p1\")\n";
35                        break;
36       
37                case 'PCONNECT':
38                case 'CONNECT':
39                        $user = $thisConnection->user;
40                        $s = "$dbms error: [$errno: $errmsg] in $fn($p1, '$user', '****', $p2)\n";
41                        break;
42                default:
43                        $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)\n";
44                        break;
45                }
46       
47                $this->dbms = $dbms;
48                if ($thisConnection) {
49                        $this->host = $thisConnection->host;
50                        $this->database = $thisConnection->database;
51                }
52                $this->fn = $fn;
53                $this->msg = $errmsg;
54                               
55                if (!is_numeric($errno)) $errno = -1;
56                parent::__construct($s,$errno);
57        }
58}
59
60/**
61* Default Error Handler. This will be called with the following params
62*
63* @param $dbms          the RDBMS you are connecting to
64* @param $fn            the name of the calling function (in uppercase)
65* @param $errno         the native error number from the database
66* @param $errmsg        the native error msg from the database
67* @param $p1            $fn specific parameter - see below
68* @param $P2            $fn specific parameter - see below
69*/
70
71function adodb_throw($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection)
72{
73global $ADODB_EXCEPTION;
74       
75        if (error_reporting() == 0) return; // obey @ protocol
76        if (is_string($ADODB_EXCEPTION)) $errfn = $ADODB_EXCEPTION;
77        else $errfn = 'ADODB_EXCEPTION';
78        throw new $errfn($dbms, $fn, $errno, $errmsg, $p1, $p2, $thisConnection);
79}
80
81
82?>
Note: See TracBrowser for help on using the repository browser.