1 // Copyright (C) 1999-2003 Open Source Telecom Corporation.
2 //
3 // This program is free software; you can redistribute it and/or modify
4 // it under the terms of the GNU General Public License as published by
5 // the Free Software Foundation; either version 2 of the License, or
6 // (at your option) any later version.
7 //
8 // This program is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 // GNU General Public License for more details.
12 //
13 // You should have received a copy of the GNU General Public License
14 // along with this program; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
16 //
17 // As a special exception, you may use this file as part of a free software
18 // library without restriction. Specifically, if other files instantiate
19 // templates or use macros or inline functions from this file, or you compile
20 // this file and link it with other files to produce an executable, this
21 // file does not by itself cause the resulting executable to be covered by
22 // the GNU General Public License. This exception does not however
23 // invalidate any other reasons why the executable file might be covered by
24 // the GNU General Public License.
25 //
26 // This exception applies only to the code released under the name GNU
27 // ccRTP. If you copy code from other releases into a copy of GNU
28 // ccRTP, as the General Public License permits, the exception does
29 // not apply to the code that you add in this way. To avoid misleading
30 // anyone as to the status of such modified files, you must delete
31 // this exception notice from them.
32 //
33 // If you write modifications of your own for GNU ccRTP, it is your choice
34 // whether to permit this exception to apply to your modifications.
35 // If you do not wish that, delete this exception notice.
36 //
37
43 #ifndef CCXX_RTP_EXT_H
44 #define CCXX_RTP_EXT_H
45
46 #ifndef CCXX_SOCKET_H_
48 #endif
49
52
53 #ifdef CCXX_NAMESPACES
54 namespace ost {
55 #endif
56
74 {
75 public:
82
86 virtual
88
97
98 protected:
99
104 bool
106 { return isPendingReceive(timeout); }
107
113 size_t
114 sendData(
const unsigned char *
const buffer,
size_t len)
116
124 size_t
127 { /* na = UDPReceive::getPeer(&tp); FIX name ambiguity */
129
134 inline void
136 { }
137
142 inline void
144 { }
145
146 inline size_t
148 {
149 // the const cast is a trick only needed for cc++2 <= 1.0.10
151 }
152
157
158 private:
160 };
161 // rtpext
163
164 #ifdef CCXX_NAMESPACES
165 }
166 #endif
167
168 #endif //CCXX_RTP_EXT_H
169
size_t sendData(const unsigned char *const buffer, size_t len)
Generic RTP input/output queues.
ssize_t transmit(const char *buffer, size_t len)
Transmit "send" to use "connected" send rather than sendto.
void setDataPeer(const InetAddress &, tpport_t)
Synchronization source in an RTP session.
Representing half of a two-way UDP connection, the UDP transmitter can broadcast data to another sele...
size_t recvData(unsigned char *buffer, size_t len, InetHostAddress &na, tpport_t &tp)
uint32 microtimeout_t
Time interval expressed in microseconds.
unsigned short tpport_t
Transport Protocol Ports.
size_t ccioctl(SOCKET so, int request, size_t &len)
Definition of socket classes for different underlying transport and/or network protocols that can be ...
SOCKET getReceiver(void) const
ssize_t receive(void *buf, size_t len)
Receive a data packet from the connected peer host.
size_t getNextDataPacketSize() const
void setControlPeer(const InetAddress &, tpport_t)
A peer associated RTP socket pair for physically connected peer hosts.
bool isPendingData(microtimeout_t timeout)
Network addresses and sockets related classes.
A packet queue handler for building different kinds of RTP protocol systems.
Representing half of a two-way UDP connection, the UDP receiver can receive data from another peer ho...