JRTPLIB  3.9.0
rtptransmitter.h
Go to the documentation of this file.
1 /*
2 
3  This file is a part of JRTPLIB
4  Copyright (c) 1999-2011 Jori Liesenborgs
5 
6  Contact: jori.liesenborgs@gmail.com
7 
8  This library was developed at the Expertise Centre for Digital 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 namespace jrtplib
46 {
47 
48 class RTPRawPacket;
49 class RTPAddress;
50 class RTPTransmissionParams;
51 class RTPTime;
52 class RTPTransmissionInfo;
53 
61 class RTPTransmitter : public RTPMemoryObject
62 {
63 public:
70  {
75  };
76 
79  {
83  };
84 protected:
86  RTPTransmitter(RTPMemoryManager *mgr) : RTPMemoryObject(mgr) { }
87 public:
88  virtual ~RTPTransmitter() { }
89 
94  virtual int Init(bool threadsafe) = 0;
95 
104  virtual int Create(size_t maxpacksize,const RTPTransmissionParams *transparams) = 0;
105 
109  virtual void Destroy() = 0;
110 
118  virtual RTPTransmissionInfo *GetTransmissionInfo() = 0;
119 
123  virtual void DeleteTransmissionInfo(RTPTransmissionInfo *inf) = 0;
124 
134  virtual int GetLocalHostName(uint8_t *buffer,size_t *bufferlength) = 0;
135 
137  virtual bool ComesFromThisTransmitter(const RTPAddress *addr) = 0;
138 
141  virtual size_t GetHeaderOverhead() = 0;
142 
144  virtual int Poll() = 0;
145 
150  virtual int WaitForIncomingData(const RTPTime &delay,bool *dataavailable = 0) = 0;
151 
153  virtual int AbortWait() = 0;
154 
156  virtual int SendRTPData(const void *data,size_t len) = 0;
157 
159  virtual int SendRTCPData(const void *data,size_t len) = 0;
160 
162  virtual int AddDestination(const RTPAddress &addr) = 0;
163 
165  virtual int DeleteDestination(const RTPAddress &addr) = 0;
166 
168  virtual void ClearDestinations() = 0;
169 
171  virtual bool SupportsMulticasting() = 0;
172 
174  virtual int JoinMulticastGroup(const RTPAddress &addr) = 0;
175 
177  virtual int LeaveMulticastGroup(const RTPAddress &addr) = 0;
178 
180  virtual void LeaveAllMulticastGroups() = 0;
181 
187  virtual int SetReceiveMode(RTPTransmitter::ReceiveMode m) = 0;
188 
190  virtual int AddToIgnoreList(const RTPAddress &addr) = 0;
191 
193  virtual int DeleteFromIgnoreList(const RTPAddress &addr)= 0;
194 
196  virtual void ClearIgnoreList() = 0;
197 
199  virtual int AddToAcceptList(const RTPAddress &addr) = 0;
200 
202  virtual int DeleteFromAcceptList(const RTPAddress &addr) = 0;
203 
205  virtual void ClearAcceptList() = 0;
206 
208  virtual int SetMaximumPacketSize(size_t s) = 0;
209 
211  virtual bool NewDataAvailable() = 0;
212 
215  virtual RTPRawPacket *GetNextPacket() = 0;
216 #ifdef RTPDEBUG
217  virtual void Dump() = 0;
218 #endif // RTPDEBUG
219 };
220 
228 {
229 protected:
231 public:
232  virtual ~RTPTransmissionParams() { }
233 
236 private:
238 };
239 
247 {
248 protected:
250 public:
251  virtual ~RTPTransmissionInfo() { }
254 private:
256 };
257 
258 } // end namespace
259 
260 #endif // RTPTRANSMITTER_H
261 
virtual int Init(bool threadsafe)=0
This function must be called before the transmission component can be used.
virtual void ClearDestinations()=0
Clears the list of destinations.
Specifies the internal UDP over IPv4 transmitter.
Definition: rtptransmitter.h:71
Base class for transmission parameters.
Definition: rtptransmitter.h:227
virtual int DeleteFromIgnoreList(const RTPAddress &addr)=0
Deletes addr from the list of addresses to accept.
virtual bool SupportsMulticasting()=0
Returns true if the transmission component supports multicasting.
virtual int JoinMulticastGroup(const RTPAddress &addr)=0
Joins the multicast group specified by addr.
virtual int DeleteFromAcceptList(const RTPAddress &addr)=0
Deletes addr from the list of addresses to accept.
virtual int SetReceiveMode(RTPTransmitter::ReceiveMode m)=0
Sets the receive mode.
RTPTransmitter::TransmissionProtocol GetTransmissionProtocol() const
Returns the transmitter type for which these parameters are valid.
Definition: rtptransmitter.h:253
virtual void LeaveAllMulticastGroups()=0
Leaves all the multicast groups that have been joined.
virtual void DeleteTransmissionInfo(RTPTransmissionInfo *inf)=0
Deallocates the information returned by RTPTransmitter::GetTransmissionInfo .
RTPTransmitter(RTPMemoryManager *mgr)
Constructor in which you can specify a memory manager to use.
Definition: rtptransmitter.h:86
virtual int LeaveMulticastGroup(const RTPAddress &addr)=0
Leaves the multicast group specified by addr.
virtual int SetMaximumPacketSize(size_t s)=0
Sets the maximum packet size which the transmitter should allow to s.
virtual bool ComesFromThisTransmitter(const RTPAddress *addr)=0
Returns true if the address specified by addr is one of the addresses of the transmitter.
virtual RTPRawPacket * GetNextPacket()=0
Returns the raw data of a received RTP packet (received during the Poll function) in an RTPRawPacket ...
virtual void ClearIgnoreList()=0
Clears the list of addresses to ignore.
virtual int Create(size_t maxpacksize, const RTPTransmissionParams *transparams)=0
Prepares the component to be used.
virtual RTPTransmissionInfo * GetTransmissionInfo()=0
Returns additional information about the transmitter.
All incoming data is accepted, no matter where it originated from.
Definition: rtptransmitter.h:80
All incoming data is accepted, except for data coming from a specific set of sources.
Definition: rtptransmitter.h:82
virtual int AbortWait()=0
If the previous function has been called, this one aborts the waiting.
Abstract class from which actual transmission components should be derived.
Definition: rtptransmitter.h:61
ReceiveMode
Three kind of receive modes can be specified.
Definition: rtptransmitter.h:78
virtual int GetLocalHostName(uint8_t *buffer, size_t *bufferlength)=0
Looks up the local host name.
virtual bool NewDataAvailable()=0
Returns true if packets can be obtained using the GetNextPacket member function.
virtual int Poll()=0
Checks for incoming data and stores it.
virtual int AddToAcceptList(const RTPAddress &addr)=0
Adds addr to the list of addresses to accept.
A memory manager.
Definition: rtpmemorymanager.h:147
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...
Specifies the transmitter which can send packets using an external mechanism, and which can have rece...
Definition: rtptransmitter.h:73
Specifies the internal UDP over IPv6 transmitter.
Definition: rtptransmitter.h:72
virtual int WaitForIncomingData(const RTPTime &delay, bool *dataavailable=0)=0
Waits until incoming data is detected.
virtual size_t GetHeaderOverhead()=0
Returns the amount of bytes that will be added to the RTP packet by the underlying layers (excluding ...
virtual int AddToIgnoreList(const RTPAddress &addr)=0
Adds addr to the list of addresses to ignore.
virtual void Destroy()=0
By calling this function, buffers are cleared and the component cannot be used anymore.
virtual void ClearAcceptList()=0
Clears the list of addresses to accept.
Specifies a user defined, external transmitter.
Definition: rtptransmitter.h:74
Base class for additional information about the transmitter.
Definition: rtptransmitter.h:246
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...
virtual int AddDestination(const RTPAddress &addr)=0
Adds the address specified by addr to the list of destinations.
virtual int DeleteDestination(const RTPAddress &addr)=0
Deletes the address specified by addr from the list of destinations.
RTPTransmitter::TransmissionProtocol GetTransmissionProtocol() const
Returns the transmitter type for which these parameters are valid.
Definition: rtptransmitter.h:235
Only data coming from specific sources will be accepted.
Definition: rtptransmitter.h:81
TransmissionProtocol
Used to identify a specific transmitter.
Definition: rtptransmitter.h:69