SourceBufferPrivateGStreamer.h [plain text]
#pragma once
#if ENABLE(MEDIA_SOURCE) && USE(GSTREAMER)
#include "ContentType.h"
#include "MediaPlayerPrivateGStreamerMSE.h"
#include "SourceBufferPrivate.h"
#include "SourceBufferPrivateClient.h"
#include "WebKitMediaSourceGStreamer.h"
namespace WebCore {
class MediaSourceGStreamer;
class SourceBufferPrivateGStreamer final : public SourceBufferPrivate {
public:
static Ref<SourceBufferPrivateGStreamer> create(MediaSourceGStreamer*, Ref<MediaSourceClientGStreamerMSE>, const ContentType&);
virtual ~SourceBufferPrivateGStreamer() = default;
void clearMediaSource() { m_mediaSource = nullptr; }
void setClient(SourceBufferPrivateClient*) final;
void append(Vector<unsigned char>&&) final;
void abort() final;
void resetParserState() final;
void removedFromMediaSource() final;
MediaPlayer::ReadyState readyState() const final;
void setReadyState(MediaPlayer::ReadyState) final;
void flush(const AtomicString&) final;
void enqueueSample(Ref<MediaSample>&&, const AtomicString&) final;
void allSamplesInTrackEnqueued(const AtomicString&) final;
bool isReadyForMoreSamples(const AtomicString&) final;
void setActive(bool) final;
void notifyClientWhenReadyForMoreSamples(const AtomicString&) final;
void setReadyForMoreSamples(bool);
void notifyReadyForMoreSamples();
void didReceiveInitializationSegment(const SourceBufferPrivateClient::InitializationSegment&);
void didReceiveSample(MediaSample&);
void didReceiveAllPendingSamples();
void appendParsingFailed();
ContentType type() const { return m_type; }
private:
SourceBufferPrivateGStreamer(MediaSourceGStreamer*, Ref<MediaSourceClientGStreamerMSE>, const ContentType&);
friend class MediaSourceClientGStreamerMSE;
MediaSourceGStreamer* m_mediaSource;
ContentType m_type;
Ref<MediaSourceClientGStreamerMSE> m_client;
SourceBufferPrivateClient* m_sourceBufferPrivateClient { nullptr };
bool m_isReadyForMoreSamples = true;
bool m_notifyWhenReadyForMoreSamples = false;
AtomicString m_trackId;
};
}
#endif