| Index: webrtc/media/base/videosourcebase.h
|
| diff --git a/webrtc/media/base/videosourcebase.h b/webrtc/media/base/videosourcebase.h
|
| index 61dfff3cb4c60cb54af917deadf02348999648c3..40d2fb3482f2e55b1998c88150360372bee82ef1 100644
|
| --- a/webrtc/media/base/videosourcebase.h
|
| +++ b/webrtc/media/base/videosourcebase.h
|
| @@ -11,6 +11,39 @@
|
| #ifndef WEBRTC_MEDIA_BASE_VIDEOSOURCEBASE_H_
|
| #define WEBRTC_MEDIA_BASE_VIDEOSOURCEBASE_H_
|
|
|
| -// TODO(perkj): Add implementation.
|
| +#include <vector>
|
| +
|
| +#include "webrtc/base/thread_checker.h"
|
| +#include "webrtc/media/base/videoframe.h"
|
| +#include "webrtc/media/base/videosourceinterface.h"
|
| +
|
| +namespace rtc {
|
| +
|
| +// VideoSourceBase is not thread safe.
|
| +class VideoSourceBase : public VideoSourceInterface<cricket::VideoFrame> {
|
| + public:
|
| + VideoSourceBase();
|
| + void AddOrUpdateSink(VideoSinkInterface<cricket::VideoFrame>* sink,
|
| + const VideoSinkWants& wants) override;
|
| + void RemoveSink(VideoSinkInterface<cricket::VideoFrame>* sink) override;
|
| +
|
| + protected:
|
| + struct SinkPair {
|
| + SinkPair(VideoSinkInterface<cricket::VideoFrame>* sink,
|
| + VideoSinkWants wants)
|
| + : sink(sink), wants(wants) {}
|
| + VideoSinkInterface<cricket::VideoFrame>* sink;
|
| + VideoSinkWants wants;
|
| + };
|
| + SinkPair* FindSinkPair(const VideoSinkInterface<cricket::VideoFrame>* sink);
|
| +
|
| + const std::vector<SinkPair>& sink_pairs() const { return sinks_; }
|
| + ThreadChecker thread_checker_;
|
| +
|
| + private:
|
| + std::vector<SinkPair> sinks_;
|
| +};
|
| +
|
| +} // namespace rtc
|
|
|
| #endif // WEBRTC_MEDIA_BASE_VIDEOSOURCEBASE_H_
|
|
|