VorbisAudioRTPSource.hh 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /**********
  2. This library is free software; you can redistribute it and/or modify it under
  3. the terms of the GNU Lesser General Public License as published by the
  4. Free Software Foundation; either version 3 of the License, or (at your
  5. option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)
  6. This library is distributed in the hope that it will be useful, but WITHOUT
  7. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  8. FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
  9. more details.
  10. You should have received a copy of the GNU Lesser General Public License
  11. along with this library; if not, write to the Free Software Foundation, Inc.,
  12. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  13. **********/
  14. // "liveMedia"
  15. // Copyright (c) 1996-2019 Live Networks, Inc. All rights reserved.
  16. // Vorbis Audio RTP Sources
  17. // C++ header
  18. #ifndef _VORBIS_AUDIO_RTP_SOURCE_HH
  19. #define _VORBIS_AUDIO_RTP_SOURCE_HH
  20. #ifndef _MULTI_FRAMED_RTP_SOURCE_HH
  21. #include "MultiFramedRTPSource.hh"
  22. #endif
  23. class VorbisAudioRTPSource: public MultiFramedRTPSource {
  24. public:
  25. static VorbisAudioRTPSource*
  26. createNew(UsageEnvironment& env, Groupsock* RTPgs,
  27. unsigned char rtpPayloadFormat,
  28. unsigned rtpTimestampFrequency);
  29. u_int32_t curPacketIdent() const { return fCurPacketIdent; } // The current "Ident" field; only the low-order 24 bits are used
  30. protected:
  31. VorbisAudioRTPSource(UsageEnvironment& env, Groupsock* RTPgs,
  32. unsigned char rtpPayloadFormat,
  33. unsigned rtpTimestampFrequency);
  34. // called only by createNew()
  35. virtual ~VorbisAudioRTPSource();
  36. protected:
  37. // redefined virtual functions:
  38. virtual Boolean processSpecialHeader(BufferedPacket* packet,
  39. unsigned& resultSpecialHeaderSize);
  40. virtual char const* MIMEtype() const;
  41. private:
  42. u_int32_t fCurPacketIdent; // only the low-order 24 bits are used
  43. };
  44. void parseVorbisOrTheoraConfigStr(char const* configStr,
  45. u_int8_t*& identificationHdr, unsigned& identificationHdrSize,
  46. u_int8_t*& commentHdr, unsigned& commentHdrSize,
  47. u_int8_t*& setupHdr, unsigned& setupHdrSize,
  48. u_int32_t& identField);
  49. // Returns (in each of the result parameters) unpacked Vorbis or Theora
  50. // "identification", "comment", and "setup" headers that were specified in a
  51. // "config" string (in the SDP description for a Vorbis/RTP or Theora/RTP stream).
  52. // Each of the "*Hdr" result arrays are dynamically allocated by this routine,
  53. // and must be delete[]d by the caller.
  54. #endif