Copyright updated
[core.git] / inc / classes / exceptions / socket / class_SocketOptionException.php
1 <?php
2 /**
3  * This exception is thrown when an option could not be set on given socket
4  * resource. This means that the socket could be (somehow) created but cannot
5  * be altered (as usual with non-blocking connections).
6  *
7  * @author              Roland Haeder <webmaster@ship-simu.org>
8  * @version             0.0.0
9  * @copyright   Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2012 Core Developer Team
10  * @license             GNU GPL 3.0 or any newer version
11  * @link                http://www.ship-simu.org
12  *
13  * This program is free software: you can redistribute it and/or modify
14  * it under the terms of the GNU General Public License as published by
15  * the Free Software Foundation, either version 3 of the License, or
16  * (at your option) any later version.
17  *
18  * This program is distributed in the hope that it will be useful,
19  * but WITHOUT ANY WARRANTY; without even the implied warranty of
20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  * GNU General Public License for more details.
22  *
23  * You should have received a copy of the GNU General Public License
24  * along with this program. If not, see <http://www.gnu.org/licenses/>.
25  */
26 class SocketOptionException extends AbstractSocketException {
27         /**
28          * A Constructor for this exception
29          *
30          * @param       $messageArray   Error message array
31          * @param       $code                   Error code
32          * @return      void
33          */
34         public function __construct (array $messageData, $code) {
35                 // Construct the message
36                 $message = sprintf("[%s:] Changing option on socket failed, type=%s, errno=%s, errstr=%s",
37                         $messageData[0]->__toString(),
38                         gettype($messageData[1]),
39                         $messageData[2],
40                         $messageData[3]
41                 );
42
43                 // Call parent exception constructor
44                 parent::__construct($message, $code);
45         }
46 }
47
48 // [EOF]
49 ?>