diff options
author | Matthias P. Braendli <matthias.braendli@mpb.li> | 2019-08-27 11:02:23 +0200 |
---|---|---|
committer | Matthias P. Braendli <matthias.braendli@mpb.li> | 2019-08-27 11:02:23 +0200 |
commit | 0298076eea4f92685f9a01974261da41c2a01e5b (patch) | |
tree | f72831cd212da64c1a3ea124bb9b590ced8558f2 /src/input/Edi.h | |
parent | cac39dedee89d62ebf5d0135b84ccaa2e387a7cb (diff) | |
download | dabmux-0298076eea4f92685f9a01974261da41c2a01e5b.tar.gz dabmux-0298076eea4f92685f9a01974261da41c2a01e5b.tar.bz2 dabmux-0298076eea4f92685f9a01974261da41c2a01e5b.zip |
EDI input: add new buffer management
Diffstat (limited to 'src/input/Edi.h')
-rw-r--r-- | src/input/Edi.h | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/input/Edi.h b/src/input/Edi.h index 9542e28..bf65ac9 100644 --- a/src/input/Edi.h +++ b/src/input/Edi.h @@ -53,7 +53,8 @@ class Edi : public InputBase { ~Edi(); virtual void open(const std::string& name); - virtual int readFrame(uint8_t* buffer, size_t size); + virtual size_t readFrame(uint8_t *buffer, size_t size); + virtual size_t readFrame(uint8_t *buffer, size_t size, uint32_t seconds, uint32_t tsta); virtual int setBitrate(int bitrate); virtual void close(); @@ -72,8 +73,11 @@ class Edi : public InputBase { std::thread m_thread; std::atomic<bool> m_running = ATOMIC_VAR_INIT(false); ThreadsafeQueue<EdiDecoder::sti_frame_t> m_frames; + + // Used in timestamp-based buffer management EdiDecoder::sti_frame_t m_pending_sti_frame; + // Used in prebuffering-based buffer management bool m_is_prebuffering = true; std::string m_name; |