socket_set_block
(PHP 4 >= 4.2.0, PHP 5)
socket_set_block — Sets blocking mode on a socket resource
Description
$socket
)
The socket_set_block() function removes the
O_NONBLOCK
flag on the socket specified by the
socket
parameter.
When an operation (e.g. receive, send, connect, accept, ...) is performed on a blocking socket, the script will pause its execution until it receives a signal or it can perform the operation.
Return Values
Returns TRUE
on success or FALSE
on failure.
Examples
Example #1 socket_set_block() example
<?php
$socket = socket_create_listen(1223);
socket_set_block($socket);
socket_accept($socket);
?>
This example creates a listening socket on all interfaces on port 1223 and
sets the socket to O_BLOCK
mode.
socket_accept() will hang until there is a connection
to accept.
See Also
- socket_set_nonblock() - Sets nonblocking mode for file descriptor fd
- socket_set_option() - Sets socket options for the socket
- socket_accept
- socket_bind
- socket_clear_error
- socket_close
- socket_cmsg_space
- socket_connect
- socket_create_listen
- socket_create_pair
- socket_create
- socket_get_option
- socket_getopt
- socket_getpeername
- socket_getsockname
- socket_import_stream
- socket_last_error
- socket_listen
- socket_read
- socket_recv
- socket_recvfrom
- socket_recvmsg
- socket_select
- socket_send
- socket_sendmsg
- socket_sendto
- socket_set_block
- socket_set_nonblock
- socket_set_option
- socket_setopt
- socket_shutdown
- socket_strerror
- socket_write
Коментарии
Besides true and false socket_set_block might return NULL if you're not too careful. That would happen when passing non socket resource as first parameter.
E.g. socket_set_block(false)) would return NULL and emit warning that you're trying to do things with non-socket.