jrtplib  3.7.0
rtptransmitter.h
Go to the documentation of this file.
1 /*
2 
3  This file is a part of JRTPLIB
4  Copyright (c) 1999-2007 Jori Liesenborgs
5 
6  Contact: jori.liesenborgs@gmail.com
7 
8  This library was developed at the "Expertisecentrum Digitale Media"
9  (http://www.edm.uhasselt.be), a research center of the Hasselt University
10  (http://www.uhasselt.be). The library is based upon work done for
11  my thesis at the School for Knowledge Technology (Belgium/The Netherlands).
12 
13  Permission is hereby granted, free of charge, to any person obtaining a
14  copy of this software and associated documentation files (the "Software"),
15  to deal in the Software without restriction, including without limitation
16  the rights to use, copy, modify, merge, publish, distribute, sublicense,
17  and/or sell copies of the Software, and to permit persons to whom the
18  Software is furnished to do so, subject to the following conditions:
19 
20  The above copyright notice and this permission notice shall be included
21  in all copies or substantial portions of the Software.
22 
23  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26  THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
29  IN THE SOFTWARE.
30 
31 */
32 
37 #ifndef RTPTRANSMITTER_H
38 
39 #define RTPTRANSMITTER_H
40 
41 #include "rtpconfig.h"
42 #include "rtptypes.h"
43 #include "rtpmemoryobject.h"
44 
45 class RTPRawPacket;
46 class RTPAddress;
48 class RTPTime;
50 
57 class RTPTransmitter : public RTPMemoryObject
58 {
59 public:
66  {
70  };
71 
74  {
78  };
79 protected:
81  RTPTransmitter(RTPMemoryManager *mgr) : RTPMemoryObject(mgr) { }
82 public:
83  virtual ~RTPTransmitter() { }
84 
89  virtual int Init(bool threadsafe) = 0;
90 
99  virtual int Create(size_t maxpacksize,const RTPTransmissionParams *transparams) = 0;
100 
104  virtual void Destroy() = 0;
105 
114 
124  virtual int GetLocalHostName(uint8_t *buffer,size_t *bufferlength) = 0;
125 
127  virtual bool ComesFromThisTransmitter(const RTPAddress *addr) = 0;
128 
131  virtual size_t GetHeaderOverhead() = 0;
132 
134  virtual int Poll() = 0;
135 
140  virtual int WaitForIncomingData(const RTPTime &delay,bool *dataavailable = 0) = 0;
141 
143  virtual int AbortWait() = 0;
144 
146  virtual int SendRTPData(const void *data,size_t len) = 0;
147 
149  virtual int SendRTCPData(const void *data,size_t len) = 0;
150 
152  virtual int AddDestination(const RTPAddress &addr) = 0;
153 
155  virtual int DeleteDestination(const RTPAddress &addr) = 0;
156 
158  virtual void ClearDestinations() = 0;
159 
161  virtual bool SupportsMulticasting() = 0;
162 
164  virtual int JoinMulticastGroup(const RTPAddress &addr) = 0;
165 
167  virtual int LeaveMulticastGroup(const RTPAddress &addr) = 0;
168 
170  virtual void LeaveAllMulticastGroups() = 0;
171 
177  virtual int SetReceiveMode(RTPTransmitter::ReceiveMode m) = 0;
178 
180  virtual int AddToIgnoreList(const RTPAddress &addr) = 0;
181 
183  virtual int DeleteFromIgnoreList(const RTPAddress &addr)= 0;
184 
186  virtual void ClearIgnoreList() = 0;
187 
189  virtual int AddToAcceptList(const RTPAddress &addr) = 0;
190 
192  virtual int DeleteFromAcceptList(const RTPAddress &addr) = 0;
193 
195  virtual void ClearAcceptList() = 0;
196 
198  virtual int SetMaximumPacketSize(size_t s) = 0;
199 
201  virtual bool NewDataAvailable() = 0;
202 
205  virtual RTPRawPacket *GetNextPacket() = 0;
206 #ifdef RTPDEBUG
207  virtual void Dump() = 0;
208 #endif // RTPDEBUG
209 };
210 
218 {
219 protected:
221 public:
222  virtual ~RTPTransmissionParams() { }
223 
226 private:
228 };
229 
237 {
238 protected:
240 public:
241  virtual ~RTPTransmissionInfo() { }
244 private:
246 };
247 
248 #endif // RTPTRANSMITTER_H
249 
virtual int WaitForIncomingData(const RTPTime &delay, bool *dataavailable=0)=0
Waits until incoming data is detected.
virtual int DeleteDestination(const RTPAddress &addr)=0
Deletes the address specified by addr from the list of destinations.
virtual int AddToAcceptList(const RTPAddress &addr)=0
Adds addr to the list of addresses to accept.
TransmissionProtocol
Used to identify a specific transmitter.
Definition: rtptransmitter.h:65
virtual int LeaveMulticastGroup(const RTPAddress &addr)=0
Leaves the multicast group specified by addr.
All incoming data is accepted, no matter where it originated from.
Definition: rtptransmitter.h:75
virtual RTPTransmissionInfo * GetTransmissionInfo()=0
Returns additional information about the transmitter.
A memory manager.
Definition: rtpmemorymanager.h:144
virtual int SendRTPData(const void *data, size_t len)=0
Send a packet with length len containing data to all RTP addresses of the current destination list...
RTPTransmitter::TransmissionProtocol GetTransmissionProtocol() const
Returns the transmitter type for which these parameters are valid.
Definition: rtptransmitter.h:225
virtual bool SupportsMulticasting()=0
Returns true if the transmission component supports multicasting.
This class is used to specify wallclock time, delay intervals etc.
Definition: rtptimeutilities.h:77
virtual int Init(bool threadsafe)=0
This function must be called before the transmission component can be used.
virtual int GetLocalHostName(uint8_t *buffer, size_t *bufferlength)=0
Looks up the local host name.
Base class for additional information about the transmitter.
Definition: rtptransmitter.h:236
Specifies a user defined, external transmitter.
Definition: rtptransmitter.h:69
virtual void ClearAcceptList()=0
Clears the list of addresses to accept.
virtual void Destroy()=0
By calling this function, buffers are cleared and the component cannot be used anymore.
virtual int Poll()=0
Checks for incoming data and stores it.
Specifies the internal UDP over IPv6 transmitter.
Definition: rtptransmitter.h:68
Specifies the internal UDP over IPv4 transmitter.
Definition: rtptransmitter.h:67
This class is used by the transmission component to store the incoming RTP and RTCP data in...
Definition: rtprawpacket.h:48
virtual int AbortWait()=0
If the previous function has been called, this one aborts the waiting.
virtual int AddDestination(const RTPAddress &addr)=0
Adds the address specified by addr to the list of destinations.
virtual void ClearDestinations()=0
Clears the list of destinations.
ReceiveMode
Three kind of receive modes can be specified.
Definition: rtptransmitter.h:73
virtual size_t GetHeaderOverhead()=0
Returns the amount of bytes that will be added to the RTP packet by the underlying layers (excluding ...
Abstract class from which actual transmission components should be derived.
Definition: rtptransmitter.h:57
virtual RTPRawPacket * GetNextPacket()=0
Returns the raw data of a received RTP packet (received during the Poll function) in an RTPRawPacket ...
This class is an abstract class which is used to specify destinations, multicast groups etc...
Definition: rtpaddress.h:47
virtual int DeleteFromAcceptList(const RTPAddress &addr)=0
Deletes addr from the list of addresses to accept.
RTPTransmitter(RTPMemoryManager *mgr)
Constructor in which you can specify a memory manager to use.
Definition: rtptransmitter.h:81
virtual void ClearIgnoreList()=0
Clears the list of addresses to ignore.
virtual int JoinMulticastGroup(const RTPAddress &addr)=0
Joins the multicast group specified by addr.
virtual int DeleteFromIgnoreList(const RTPAddress &addr)=0
Deletes addr from the list of addresses to accept.
virtual int Create(size_t maxpacksize, const RTPTransmissionParams *transparams)=0
Prepares the component to be used.
virtual bool NewDataAvailable()=0
Returns true if packets can be obtained using the GetNextPacket member function.
virtual int SetMaximumPacketSize(size_t s)=0
Sets the maximum packet size which the transmitter should allow to s.
virtual void LeaveAllMulticastGroups()=0
Leaves all the multicast groups that have been joined.
RTPTransmitter::TransmissionProtocol GetTransmissionProtocol() const
Returns the transmitter type for which these parameters are valid.
Definition: rtptransmitter.h:243
virtual int SendRTCPData(const void *data, size_t len)=0
Send a packet with length len containing data to all RTCP addresses of the current destination list...
Only data coming from specific sources will be accepted.
Definition: rtptransmitter.h:76
virtual bool ComesFromThisTransmitter(const RTPAddress *addr)=0
Returns true if the address specified by addr is one of the addresses of the transmitter.
Base class for transmission parameters.
Definition: rtptransmitter.h:217
virtual int AddToIgnoreList(const RTPAddress &addr)=0
Adds addr to the list of addresses to ignore.
All incoming data is accepted, except for data coming from a specific set of sources.
Definition: rtptransmitter.h:77
virtual int SetReceiveMode(RTPTransmitter::ReceiveMode m)=0
Sets the receive mode.