3 * This exception is thrown when the socket resource is invalid or an error
4 * occurs while socket initialization phase.
6 * @author Roland Haeder <webmaster@shipsimu.org>
8 * @copyright Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2017 Core Developer Team
9 * @license GNU GPL 3.0 or any newer version
10 * @link http://www.shipsimu.org
12 * This program is free software: you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation, either version 3 of the License, or
15 * (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
22 * You should have received a copy of the GNU General Public License
23 * along with this program. If not, see <http://www.gnu.org/licenses/>.
25 class InvalidSocketException extends AbstractSocketException {
27 * A Constructor for this exception
29 * @param $messageArray Error message array
30 * @param $code Error code
33 public function __construct (array $messageData, $code) {
35 if (is_resource($messageData[1])) {
37 $lastError = socket_last_error($messageData[1]);
39 // Construct the message
40 $message = sprintf('[%s:] Invalid socket, type=%s, errno=%s, errstr=%s',
41 $messageData[0]->__toString(),
42 gettype($messageData[1]),
44 socket_strerror($lastError)
47 // Construct the message
48 $message = sprintf('[%s:] Invalid socket, type=%s(%s), errno=%s, errstr=%s',
49 $messageData[0]->__toString(),
51 gettype($messageData[1]),
57 // Call parent exception constructor
58 parent::__construct($message, $code);