ByteStreamMemoryBufferSource.hh 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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. // A class for streaming data from a (static) memory buffer, as if it were a file.
  17. // C++ header
  18. #ifndef _BYTE_STREAM_MEMORY_BUFFER_SOURCE_HH
  19. #define _BYTE_STREAM_MEMORY_BUFFER_SOURCE_HH
  20. #ifndef _FRAMED_SOURCE_HH
  21. #include "FramedSource.hh"
  22. #endif
  23. class ByteStreamMemoryBufferSource: public FramedSource {
  24. public:
  25. static ByteStreamMemoryBufferSource* createNew(UsageEnvironment& env,
  26. u_int8_t* buffer, u_int64_t bufferSize,
  27. Boolean deleteBufferOnClose = True,
  28. unsigned preferredFrameSize = 0,
  29. unsigned playTimePerFrame = 0);
  30. // "preferredFrameSize" == 0 means 'no preference'
  31. // "playTimePerFrame" is in microseconds
  32. u_int64_t bufferSize() const { return fBufferSize; }
  33. void seekToByteAbsolute(u_int64_t byteNumber, u_int64_t numBytesToStream = 0);
  34. // if "numBytesToStream" is >0, then we limit the stream to that number of bytes, before treating it as EOF
  35. void seekToByteRelative(int64_t offset, u_int64_t numBytesToStream = 0);
  36. protected:
  37. ByteStreamMemoryBufferSource(UsageEnvironment& env,
  38. u_int8_t* buffer, u_int64_t bufferSize,
  39. Boolean deleteBufferOnClose,
  40. unsigned preferredFrameSize,
  41. unsigned playTimePerFrame);
  42. // called only by createNew()
  43. virtual ~ByteStreamMemoryBufferSource();
  44. private:
  45. // redefined virtual functions:
  46. virtual void doGetNextFrame();
  47. private:
  48. u_int8_t* fBuffer;
  49. u_int64_t fBufferSize;
  50. u_int64_t fCurIndex;
  51. Boolean fDeleteBufferOnClose;
  52. unsigned fPreferredFrameSize;
  53. unsigned fPlayTimePerFrame;
  54. unsigned fLastPlayTime;
  55. Boolean fLimitNumBytesToStream;
  56. u_int64_t fNumBytesToStream; // used iff "fLimitNumBytesToStream" is True
  57. };
  58. #endif