Chromium Code Reviews| Index: components/cdm/renderer/android_key_systems.cc |
| diff --git a/components/cdm/renderer/android_key_systems.cc b/components/cdm/renderer/android_key_systems.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8fcf54514ab1106cdce7c3ba132d56306d125af2 |
| --- /dev/null |
| +++ b/components/cdm/renderer/android_key_systems.cc |
| @@ -0,0 +1,76 @@ |
| +// Copyright 2014 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. |
| + |
| +#include "components/cdm/renderer/android_key_systems.h" |
| + |
| +#include <string> |
| +#include <vector> |
| + |
| +#include "base/logging.h" |
| +#include "components/cdm/common/cdm_messages_android.h" |
| +#include "components/cdm/renderer/widevine_key_systems.h" |
| +#include "content/public/renderer/render_thread.h" |
| + |
| +#include "widevine_cdm_version.h" // In SHARED_INTERMEDIATE_DIR. |
| + |
| +using content::KeySystemInfo; |
| +using content::SupportedCodecs; |
| + |
| +namespace cdm { |
| + |
| +static SupportedKeySystemResponse GetSupportedKeySystem( |
|
ddorwin
2014/06/10 18:48:04
ditto on naming
ycheo (away)
2014/06/11 00:08:22
Done.
|
| + const std::string& key_system) { |
| + SupportedKeySystemRequest request; |
| + SupportedKeySystemResponse response; |
| + |
| + request.key_system = key_system; |
| + request.codecs = content::EME_CODEC_WEBM_ALL | content::EME_CODEC_MP4_ALL; |
| + content::RenderThread::Get()->Send( |
| + new CdmHostMsg_GetSupportedKeySystem(request, &response)); |
| + DCHECK(response.compositing_codecs & content::EME_CODEC_ALL) |
|
ddorwin
2014/06/10 18:48:04
This only checks that there is at least one suppor
ycheo (away)
2014/06/11 00:08:22
Good catch!.
|
| + << "unrecognized codec"; |
| + DCHECK(response.non_compositing_codecs & content::EME_CODEC_ALL) |
| + << "unrecognized codec"; |
| + return response; |
| +} |
| + |
| +void AddAndroidWidevine(std::vector<KeySystemInfo>* concrete_key_systems) { |
| + SupportedKeySystemResponse response; |
| + response = GetSupportedKeySystem(kWidevineKeySystem); |
|
ddorwin
2014/06/10 18:48:04
merge with the line above.
ycheo (away)
2014/06/11 00:08:22
Done.
|
| + if (response.compositing_codecs != content::EME_CODEC_NONE) { |
| + AddWidevineWithCodecs( |
| + WIDEVINE, |
| + static_cast<SupportedCodecs>(response.compositing_codecs), |
| + concrete_key_systems); |
| + } |
| + |
| + if (response.non_compositing_codecs != content::EME_CODEC_NONE) { |
| + AddWidevineWithCodecs( |
| + WIDEVINE_HR_NON_COMPOSITING, |
| + static_cast<SupportedCodecs>(response.non_compositing_codecs), |
| + concrete_key_systems); |
| + } |
| +} |
| + |
| +void AddOtherAndroidSupportedKeySystems( |
| + std::vector<KeySystemInfo>* concrete_key_systems) { |
| + std::vector<std::string> key_system_names; |
| + content::RenderThread::Get()->Send( |
| + new CdmHostMsg_GetAllSupportedKeySystemNames(&key_system_names)); |
| + |
| + for (std::vector<std::string>::const_iterator it = key_system_names.begin(); |
| + it != key_system_names.end(); ++it) { |
| + if (it->compare(kWidevineKeySystem) == 0) // Skip Widevine. |
| + continue; |
| + |
| + SupportedKeySystemResponse response = GetSupportedKeySystem(*it); |
| + if (response.compositing_codecs != content::EME_CODEC_NONE) { |
|
ddorwin
2014/06/10 18:48:04
Don't you want to support non-compositing?
ycheo (away)
2014/06/11 00:08:22
no, but the keysyste name suffix '.noncompositing'
ddorwin
2014/06/11 01:54:01
Right.
I don't know what the use case is or even
|
| + KeySystemInfo info(*it); |
| + info.supported_codecs = response.compositing_codecs; |
| + concrete_key_systems->push_back(info); |
| + } |
| + } |
| +} |
| + |
| +} // namespace cdm |