Index: media/remoting/remoting_cdm_context.h |
diff --git a/media/remoting/remoting_cdm_context.h b/media/remoting/remoting_cdm_context.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f7c3284d1baccaac47d7c380915b41db34e3f4bf |
--- /dev/null |
+++ b/media/remoting/remoting_cdm_context.h |
@@ -0,0 +1,40 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef MEDIA_REMOTING_REMOTING_CDM_CONTEXT_H_ |
+#define MEDIA_REMOTING_REMOTING_CDM_CONTEXT_H_ |
+ |
+#include "media/base/cdm_context.h" |
+ |
+namespace media { |
+ |
+class RemotingCdm; |
+class RemotingSourceImpl; |
+ |
+// TODO(xjz): Merge this with erickung's implementation. |
+class RemotingCdmContext : public CdmContext { |
+ public: |
+ explicit RemotingCdmContext(RemotingCdm* remoting_cdm); |
+ ~RemotingCdmContext() override; |
+ |
+ // If |cdm_context| is an instance of RemotingCdmContext, return a type-casted |
+ // pointer to it. Otherwise, return nullptr. |
+ static RemotingCdmContext* From(CdmContext* cdm_context); |
+ |
+ RemotingSourceImpl* GetRemotingSource(); |
xhwang
2016/11/05 02:39:58
based on the discussion, please update this to ret
xjz
2016/11/07 19:03:54
Based on previous discussion (comments), I decide
xhwang
2016/11/08 17:39:20
When the returned value is stored in another scope
|
+ |
+ // CdmContext implementations. |
+ Decryptor* GetDecryptor() override; |
+ int GetCdmId() const override; |
+ void* GetClassIdentifier() const override; |
+ |
+ private: |
+ RemotingCdm* const remoting_cdm_; // Outlives this class. |
+ |
+ DISALLOW_COPY_AND_ASSIGN(RemotingCdmContext); |
+}; |
+ |
+} // namespace media |
+ |
+#endif // MEDIA_REMOTING_REMOTING_CDM_CONTEXT_H_ |