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_ |