tags:

views:

161

answers:

2

In the documentation for Ruby class Socket::recv, there is a mention of a second option parameter "flag" which is said to be zero or more of MSG_ options.

I checked a few different sites and wasn't able to find what the MSG_ choices are. Can anyone point me to the documentation for these flags?

A: 

well ... i got stuck with this thing couple a months ago .... 1st u r using the 'Socket' class right .... cause that's what i was using ...

any way .... i don't know for sure .... but it depends on the type of the protocol u r creating withe the class 'Socket' ...

like if u create the socket as a TCP socket:

sock = Socket.open(Socket::PF_INET, Socket::SOCK_RAW, Socket::IPPROTO_RAW)

the flags will be the 6 flags of the TCP protocol (URG, ACK, PSH, ...).

though ... i'm not sure of that .... but the 0 is working for me perfectly ....

Raafat
+1  A: 

They have the same names as the corresponding #defines in the C BSD socket stack, except for the Socket:: in front. (And for the record, to answer the exact question you asked, I should say "in ext/socket/socket.c" in the Ruby source tree.) So:

>> require 'socket'
=> true
>> Socket::MSG_PEEK
=> 2

You can probably see this by typing man 2 recv, though you may need to install a man pages package first. There are also online man pages, see perhaps: man 2 recv here.

For now, here is what you need, these are the Posix options taken from the NetBSD man page. There are a lot more available on Linux. When running on Linux, Ruby will define the additional symbols, otherwise they may be undefined depending on the host. (Thanks, mark4o.)

 The flags argument to a recv call is formed by or'ing one or more of the
 values:

       MSG_OOB        process out-of-band data
       MSG_PEEK       peek at incoming message
       MSG_WAITALL    wait for full request or error

 The MSG_OOB flag requests receipt of out-of-band data that would not be
 received in the normal data stream.  Some protocols place expedited data
 at the head of the normal data queue, and thus this flag cannot be used
 with such protocols.  The MSG_PEEK flag causes the receive operation to
 return data from the beginning of the receive queue without removing that
 data from the queue.  Thus, a subsequent receive call will return the
 same data.  The MSG_WAITALL flag requests that the operation block until
 the full request is satisfied.  However, the call may still return less
 data than requested if a signal is caught, an error or disconnect occurs,
 or the next data to be received is of a different type than that
 returned.
DigitalRoss
A lot of those are Linux-specific. POSIX only includes MSG_PEEK, MSG_OOB, and MSG_WAITALL. http://www.opengroup.org/onlinepubs/9699919799/functions/recv.html
mark4o
That's a very good point. Do note, however, that Ruby does support them when running on a Linux system.
DigitalRoss