1: <?php
2: /**
3: * Zend Framework
4: *
5: * LICENSE
6: *
7: * This source file is subject to the new BSD license that is bundled
8: * with this package in the file LICENSE.txt.
9: * It is also available through the world-wide-web at this URL:
10: * http://framework.zend.com/license/new-bsd
11: * If you did not receive a copy of the license and are unable to
12: * obtain it through the world-wide-web, please send an email
13: * to license@zend.com so we can send you a copy immediately.
14: *
15: * @category Zend
16: * @package Zend_Db
17: * @subpackage Adapter
18: * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
19: * @license http://framework.zend.com/license/new-bsd New BSD License
20: * @version $Id: Exception.php 20625 2010-01-25 21:03:53Z ralph $
21: */
22:
23: /**
24: * @see Zend_Db_Adapter_Exception
25: */
26: require_once 'Zend/Db/Adapter/Exception.php';
27:
28: /**
29: * Zend_Db_Adapter_Sqlsrv_Exception
30: *
31: * @category Zend
32: * @package Zend_Db
33: * @subpackage Adapter
34: * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
35: * @license http://framework.zend.com/license/new-bsd New BSD License
36: */
37: class Zend_Db_Adapter_Sqlsrv_Exception extends Zend_Db_Adapter_Exception
38: {
39: /**
40: * Constructor
41: *
42: * If $message is an array, the assumption is that the return value of
43: * sqlsrv_errors() was provided. If so, it then retrieves the most recent
44: * error from that stack, and sets the message and code based on it.
45: *
46: * @param null|array|string $message
47: * @param null|int $code
48: */
49: public function __construct($message = null, $code = 0)
50: {
51: if (is_array($message)) {
52: // Error should be array of errors
53: // We only need first one (?)
54: if (isset($message[0])) {
55: $message = $message[0];
56: }
57:
58: $code = (int) $message['code'];
59: $message = (string) $message['message'];
60: }
61: parent::__construct($message, $code, new Exception($message, $code));
62: }
63: }
64: