. */ Doctrine::autoload('Doctrine_Connection_Exception'); /** * Doctrine_Connection_Firebird_Exception * * @package Doctrine * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ * @author Konsta Vesterinen * @author Lorenzo Alberton (PEAR MDB2 Interbase driver) * @author Lukas Smith (PEAR MDB2 library) */ class Doctrine_Connection_Firebird_Exception extends Doctrine_Connection_Exception { /** * @var array $errorCodeMap an array that is used for determining portable * error code from a native database error code */ protected static $errorCodeMap = array( -104 => Doctrine::ERR_SYNTAX, -150 => Doctrine::ERR_ACCESS_VIOLATION, -151 => Doctrine::ERR_ACCESS_VIOLATION, -155 => Doctrine::ERR_NOSUCHTABLE, -157 => Doctrine::ERR_NOSUCHFIELD, -158 => Doctrine::ERR_VALUE_COUNT_ON_ROW, -170 => Doctrine::ERR_MISMATCH, -171 => Doctrine::ERR_MISMATCH, -172 => Doctrine::ERR_INVALID, // -204 => // Covers too many errors, need to use regex on msg -205 => Doctrine::ERR_NOSUCHFIELD, -206 => Doctrine::ERR_NOSUCHFIELD, -208 => Doctrine::ERR_INVALID, -219 => Doctrine::ERR_NOSUCHTABLE, -297 => Doctrine::ERR_CONSTRAINT, -303 => Doctrine::ERR_INVALID, -413 => Doctrine::ERR_INVALID_NUMBER, -530 => Doctrine::ERR_CONSTRAINT, -551 => Doctrine::ERR_ACCESS_VIOLATION, -552 => Doctrine::ERR_ACCESS_VIOLATION, // -607 => // Covers too many errors, need to use regex on msg -625 => Doctrine::ERR_CONSTRAINT_NOT_NULL, -803 => Doctrine::ERR_CONSTRAINT, -804 => Doctrine::ERR_VALUE_COUNT_ON_ROW, -904 => Doctrine::ERR_CONNECT_FAILED, -922 => Doctrine::ERR_NOSUCHDB, -923 => Doctrine::ERR_CONNECT_FAILED, -924 => Doctrine::ERR_CONNECT_FAILED ); /** * @var array $errorRegexps an array that is used for determining portable * error code from a native database error message */ protected static $errorRegexps = array( '/generator .* is not defined/' => Doctrine::ERR_SYNTAX, // for compat. w ibase_errcode() '/table.*(not exist|not found|unknown)/i' => Doctrine::ERR_NOSUCHTABLE, '/table .* already exists/i' => Doctrine::ERR_ALREADY_EXISTS, '/unsuccessful metadata update .* failed attempt to store duplicate value/i' => Doctrine::ERR_ALREADY_EXISTS, '/unsuccessful metadata update .* not found/i' => Doctrine::ERR_NOT_FOUND, '/validation error for column .* value "\*\*\* null/i' => Doctrine::ERR_CONSTRAINT_NOT_NULL, '/violation of [\w ]+ constraint/i' => Doctrine::ERR_CONSTRAINT, '/conversion error from string/i' => Doctrine::ERR_INVALID_NUMBER, '/no permission for/i' => Doctrine::ERR_ACCESS_VIOLATION, '/arithmetic exception, numeric overflow, or string truncation/i' => Doctrine::ERR_INVALID, '/table unknown/i' => Doctrine::ERR_NOSUCHTABLE, ); /** * This method checks if native error code/message can be * converted into a portable code and then adds this * portable error code to errorInfo array and returns the modified array * * the portable error code is added at the end of array * * @param array $errorInfo error info array * @since 1.0 * @return array */ public function processErrorInfo(array $errorInfo) { /** // todo: are the following lines needed? // memo for the interbase php module hackers: we need something similar // to mysql_errno() to retrieve error codes instead of this ugly hack if (preg_match('/^([^0-9\-]+)([0-9\-]+)\s+(.*)$/', $native_msg, $m)) { $native_code = (int)$m[2]; } else { $native_code = null; } */ foreach(self::$errorRegexps as $regexp => $code) { if (preg_match($regexp, $errorInfo[2])) { $errorInfo[3] = $code; break; } } if(isset(self::$errorCodeMap[$errorInfo[1]])) $errorInfo[3] = self::$errorCodeMap[$errorInfo[1]]; return $errorInfo; } }