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 Statement
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 20096 2010-01-06 02:05:09Z bkarwin $
21: */
22:
23: /**
24: * @see Zend_Db_Statement_Exception
25: */
26: require_once 'Zend/Db/Statement/Exception.php';
27:
28: /**
29: * @package Zend_Db
30: * @subpackage Statement
31: * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
32: * @license http://framework.zend.com/license/new-bsd New BSD License
33: */
34: class Zend_Db_Statement_Sqlsrv_Exception extends Zend_Db_Statement_Exception
35: {
36: /**
37: * Constructor
38: *
39: * If $message is an array, the assumption is that the return value of
40: * sqlsrv_errors() was provided. If so, it then retrieves the most recent
41: * error from that stack, and sets the message and code based on it.
42: *
43: * @param null|array|string $message
44: * @param null|int $code
45: */
46: public function __construct($message = null, $code = 0)
47: {
48: if (is_array($message)) {
49: // Error should be array of errors
50: // We only need first one (?)
51: if (isset($message[0])) {
52: $message = $message[0];
53: }
54:
55: $code = (int) $message['code'];
56: $message = (string) $message['message'];
57: }
58: parent::__construct($message, $code);
59: }
60: }
61:
62: