Continued:
[core.git] / framework / main / exceptions / socket / class_SocketCreationException.php
1 <?php
2 // Own namespace
3 namespace Org\Mxchange\CoreFramework\Socket;
4
5 /**
6  * This exception is thrown when socket_create() returns a variable with
7  * non-resource type. This could mean you don't have propper permission to
8  * create a socket or else. (Sorry I don't know it exactly)
9  *
10  * @author              Roland Haeder <webmaster@shipsimu.org>
11  * @version             0.0.0
12  * @copyright   Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2019 Core Developer Team
13  * @license             GNU GPL 3.0 or any newer version
14  * @link                http://www.shipsimu.org
15  *
16  * This program is free software: you can redistribute it and/or modify
17  * it under the terms of the GNU General Public License as published by
18  * the Free Software Foundation, either version 3 of the License, or
19  * (at your option) any later version.
20  *
21  * This program is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24  * GNU General Public License for more details.
25  *
26  * You should have received a copy of the GNU General Public License
27  * along with this program. If not, see <http://www.gnu.org/licenses/>.
28  */
29 class SocketCreationException extends AbstractSocketException {
30         /**
31          * A Constructor for this exception
32          *
33          * @param       $messageArray   Error message array
34          * @param       $code                   Error code
35          * @return      void
36          */
37         public function __construct (array $messageData, $code) {
38                 // Construct the message
39                 $message = sprintf('[%s:] Cannot create socket, type=%s, errno=%s, errstr=%s',
40                         $messageData[0]->__toString(),
41                         $messageData[1],
42                         $messageData[2],
43                         $messageData[3]
44                 );
45
46                 // Call parent exception constructor
47                 parent::__construct($message, $code);
48         }
49
50 }