groupsock/include/GroupsockHelper.hh

Go to the documentation of this file.
00001 /**********
00002 This library is free software; you can redistribute it and/or modify it under
00003 the terms of the GNU Lesser General Public License as published by the
00004 Free Software Foundation; either version 2.1 of the License, or (at your
00005 option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)
00006 
00007 This library is distributed in the hope that it will be useful, but WITHOUT
00008 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
00009 FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for
00010 more details.
00011 
00012 You should have received a copy of the GNU Lesser General Public License
00013 along with this library; if not, write to the Free Software Foundation, Inc.,
00014 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301  USA
00015 **********/
00016 // "mTunnel" multicast access service
00017 // Copyright (c) 1996-2008 Live Networks, Inc.  All rights reserved.
00018 // Helper routines to implement 'group sockets'
00019 // C++ header
00020 
00021 #ifndef _GROUPSOCK_HELPER_HH
00022 #define _GROUPSOCK_HELPER_HH
00023 
00024 #ifndef _NET_ADDRESS_HH
00025 #include "NetAddress.hh"
00026 #endif
00027 
00028 int setupDatagramSocket(UsageEnvironment& env,
00029                         Port port, Boolean setLoopback = True);
00030 int setupStreamSocket(UsageEnvironment& env,
00031                       Port port, Boolean makeNonBlocking = True);
00032 
00033 int readSocket(UsageEnvironment& env,
00034                int socket, unsigned char* buffer, unsigned bufferSize,
00035                struct sockaddr_in& fromAddress,
00036                struct timeval* timeout = NULL);
00037 
00038 int readSocketExact(UsageEnvironment& env,
00039                     int socket, unsigned char* buffer, unsigned bufferSize,
00040                     struct sockaddr_in& fromAddress,
00041                     struct timeval* timeout = NULL);
00042     // like "readSocket()", except that it rereads as many times as needed until
00043     // *exactly* "bufferSize" bytes are read.
00044 
00045 Boolean writeSocket(UsageEnvironment& env,
00046                     int socket, struct in_addr address, Port port,
00047                     u_int8_t ttlArg,
00048                     unsigned char* buffer, unsigned bufferSize);
00049 
00050 unsigned getSendBufferSize(UsageEnvironment& env, int socket);
00051 unsigned getReceiveBufferSize(UsageEnvironment& env, int socket);
00052 unsigned setSendBufferTo(UsageEnvironment& env,
00053                          int socket, unsigned requestedSize);
00054 unsigned setReceiveBufferTo(UsageEnvironment& env,
00055                             int socket, unsigned requestedSize);
00056 unsigned increaseSendBufferTo(UsageEnvironment& env,
00057                               int socket, unsigned requestedSize);
00058 unsigned increaseReceiveBufferTo(UsageEnvironment& env,
00059                                  int socket, unsigned requestedSize);
00060 
00061 Boolean makeSocketNonBlocking(int sock);
00062 
00063 Boolean socketJoinGroup(UsageEnvironment& env, int socket,
00064                         netAddressBits groupAddress);
00065 Boolean socketLeaveGroup(UsageEnvironment&, int socket,
00066                          netAddressBits groupAddress);
00067 
00068 // source-specific multicast join/leave
00069 Boolean socketJoinGroupSSM(UsageEnvironment& env, int socket,
00070                            netAddressBits groupAddress,
00071                            netAddressBits sourceFilterAddr);
00072 Boolean socketLeaveGroupSSM(UsageEnvironment&, int socket,
00073                             netAddressBits groupAddress,
00074                             netAddressBits sourceFilterAddr);
00075 
00076 Boolean getSourcePort(UsageEnvironment& env, int socket, Port& port);
00077 
00078 netAddressBits ourIPAddress(UsageEnvironment& env); // in network order
00079 
00080 // IP addresses of our sending and receiving interfaces.  (By default, these
00081 // are INADDR_ANY (i.e., 0), specifying the default interface.)
00082 extern netAddressBits SendingInterfaceAddr;
00083 extern netAddressBits ReceivingInterfaceAddr;
00084 
00085 // Allocates a randomly-chosen IPv4 SSM (multicast) address:
00086 netAddressBits chooseRandomIPv4SSMAddress(UsageEnvironment& env);
00087 
00088 // Returns a simple "hh:mm:ss" string, for use in debugging output (e.g.)
00089 char const* timestampString();
00090 
00091 
00092 #ifdef HAVE_SOCKADDR_LEN
00093 #define SET_SOCKADDR_SIN_LEN(var) var.sin_len = sizeof var
00094 #else
00095 #define SET_SOCKADDR_SIN_LEN(var)
00096 #endif
00097 
00098 #define MAKE_SOCKADDR_IN(var,adr,prt) /*adr,prt must be in network order*/\
00099     struct sockaddr_in var;\
00100     var.sin_family = AF_INET;\
00101     var.sin_addr.s_addr = (adr);\
00102     var.sin_port = (prt);\
00103     SET_SOCKADDR_SIN_LEN(var);
00104 
00105 
00106 // By default, we create sockets with the SO_REUSE_* flag set.
00107 // If, instead, you want to create sockets without the SO_REUSE_* flags,
00108 // Then enclose the creation code with:
00109 //          {
00110 //            NoReuse dummy;
00111 //            ...
00112 //          }
00113 class NoReuse {
00114 public:
00115   NoReuse();
00116   ~NoReuse();
00117 };
00118 
00119 
00120 #if (defined(__WIN32__) || defined(_WIN32)) && !defined(IMN_PIM)
00121 // For Windoze, we need to implement our own gettimeofday()
00122 extern int gettimeofday(struct timeval*, int*);
00123 #endif
00124 
00125 // The following are implemented in inet.c:
00126 extern "C" netAddressBits our_inet_addr(char const*);
00127 extern "C" char* our_inet_ntoa(struct in_addr);
00128 extern "C" struct hostent* our_gethostbyname(char* name);
00129 extern "C" void our_srandom(int x);
00130 extern "C" long our_random();
00131 extern "C" u_int32_t our_random32(); // because "our_random()" returns a 31-bit number
00132 
00133 #endif

Generated on Tue Oct 7 15:38:08 2008 for live by  doxygen 1.5.2