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