MockSourceBufferPrivate.h [plain text]
#pragma once
#if ENABLE(MEDIA_SOURCE)
#include "SourceBufferPrivate.h"
namespace WebCore {
class AudioTrackPrivate;
class InbandTextTrackPrivate;
class MockInitializationBox;
class MockMediaSourcePrivate;
class MockSampleBox;
class TimeRanges;
class VideoTrackPrivate;
class MockSourceBufferPrivate final : public SourceBufferPrivate {
public:
static Ref<MockSourceBufferPrivate> create(MockMediaSourcePrivate*);
virtual ~MockSourceBufferPrivate();
void clearMediaSource() { m_mediaSource = nullptr; }
private:
explicit MockSourceBufferPrivate(MockMediaSourcePrivate*);
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;
bool canSetMinimumUpcomingPresentationTime(const AtomString&) const final;
void setMinimumUpcomingPresentationTime(const AtomString&, const MediaTime&) final;
void clearMinimumUpcomingPresentationTime(const AtomString&) final;
bool canSwitchToType(const ContentType&) final;
bool isSeeking() const final;
MediaTime currentMediaTime() const final;
MediaTime duration() const final;
void flush(const AtomString&) final { m_enqueuedSamples.clear(); m_minimumUpcomingPresentationTime = MediaTime::invalidTime(); }
void enqueueSample(Ref<MediaSample>&&, const AtomString&) final;
bool isReadyForMoreSamples(const AtomString&) final { return !m_maxQueueDepth || m_enqueuedSamples.size() < m_maxQueueDepth.value(); }
void setActive(bool) final;
bool isActive() const final;
Vector<String> enqueuedSamplesForTrackID(const AtomString&) final;
MediaTime minimumUpcomingPresentationTimeForTrackID(const AtomString&) final;
void setMaximumQueueDepthForTrackID(const AtomString&, uint64_t) final;
void didReceiveInitializationSegment(const MockInitializationBox&);
void didReceiveSample(const MockSampleBox&);
#if !RELEASE_LOG_DISABLED
const Logger& logger() const final { return m_logger.get(); }
const char* logClassName() const override { return "MockSourceBufferPrivate"; }
const void* logIdentifier() const final { return m_logIdentifier; }
WTFLogChannel& logChannel() const final;
const Logger& sourceBufferLogger() const final { return m_logger.get(); }
const void* sourceBufferLogIdentifier() final { return logIdentifier(); }
#endif
MockMediaSourcePrivate* m_mediaSource;
bool m_isActive { false };
MediaTime m_minimumUpcomingPresentationTime;
Vector<String> m_enqueuedSamples;
Optional<uint64_t> m_maxQueueDepth;
Vector<char> m_inputBuffer;
#if !RELEASE_LOG_DISABLED
Ref<const Logger> m_logger;
const void* m_logIdentifier;
#endif
};
}
#endif // ENABLE(MEDIA_SOURCE) && USE(AVFOUNDATION)