Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(455)

Unified Diff: media/base/key_systems.cc

Issue 1027363002: Change EmeInitDataType to be an enum class (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/base/key_systems.h ('k') | media/base/key_systems_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/base/key_systems.cc
diff --git a/media/base/key_systems.cc b/media/base/key_systems.cc
index bf33dccc87bfe8424f95e2a8f329e69fe148310b..e1df3b13f88808e58eec3fac4ae868f16bcac323 100644
--- a/media/base/key_systems.cc
+++ b/media/base/key_systems.cc
@@ -34,14 +34,11 @@ struct NamedInitDataType {
EmeInitDataType type;
};
-// Mapping between initialization data types names and enum values. When adding
-// entries, make sure to update IsSaneInitDataTypeWithContainer().
+// Mapping between initialization data types names and enum values.
static NamedInitDataType kInitDataTypeNames[] = {
- {"webm", EME_INIT_DATA_TYPE_WEBM},
-#if defined(USE_PROPRIETARY_CODECS)
- {"cenc", EME_INIT_DATA_TYPE_CENC},
-#endif // defined(USE_PROPRIETARY_CODECS)
- {"keyids", EME_INIT_DATA_TYPE_KEYIDS},
+ {"webm", EmeInitDataType::WEBM},
+ {"cenc", EmeInitDataType::CENC},
+ {"keyids", EmeInitDataType::KEYIDS},
};
struct NamedCodec {
@@ -118,7 +115,7 @@ static void AddClearKey(std::vector<KeySystemInfo>* concrete_key_systems) {
// VP9 support is device dependent.
info.supported_init_data_types =
- EME_INIT_DATA_TYPE_WEBM | EME_INIT_DATA_TYPE_KEYIDS;
+ kInitDataTypeMaskWebM | kInitDataTypeMaskKeyIds;
info.supported_codecs = EME_CODEC_WEBM_ALL;
#if defined(OS_ANDROID)
@@ -132,7 +129,7 @@ static void AddClearKey(std::vector<KeySystemInfo>* concrete_key_systems) {
#endif // defined(OS_ANDROID)
#if defined(USE_PROPRIETARY_CODECS)
- info.supported_init_data_types |= EME_INIT_DATA_TYPE_CENC;
+ info.supported_init_data_types |= kInitDataTypeMaskCenc;
info.supported_codecs |= EME_CODEC_MP4_ALL;
#endif // defined(USE_PROPRIETARY_CODECS)
@@ -351,7 +348,7 @@ EmeInitDataType KeySystems::GetInitDataTypeForName(
init_data_type_name_map_.find(init_data_type);
if (iter != init_data_type_name_map_.end())
return iter->second;
- return EME_INIT_DATA_TYPE_NONE;
+ return EmeInitDataType::UNKNOWN;
}
SupportedCodecs KeySystems::GetCodecMaskForContainer(
@@ -581,10 +578,21 @@ bool KeySystems::IsSupportedKeySystemWithInitDataType(
if (key_system_iter == concrete_key_system_map_.end())
return false;
- // Check |init_data_type| and |key_system| x |init_data_type|.
- const KeySystemInfo& info = key_system_iter->second;
- EmeInitDataType eme_init_data_type = GetInitDataTypeForName(init_data_type);
- return (info.supported_init_data_types & eme_init_data_type) != 0;
+ // Check |init_data_type|.
+ InitDataTypeMask available_init_data_types =
+ key_system_iter->second.supported_init_data_types;
+ switch (GetInitDataTypeForName(init_data_type)) {
+ case EmeInitDataType::UNKNOWN:
+ return false;
+ case EmeInitDataType::WEBM:
+ return (available_init_data_types & kInitDataTypeMaskWebM) != 0;
+ case EmeInitDataType::CENC:
+ return (available_init_data_types & kInitDataTypeMaskCenc) != 0;
+ case EmeInitDataType::KEYIDS:
+ return (available_init_data_types & kInitDataTypeMaskKeyIds) != 0;
+ }
+ NOTREACHED();
+ return false;
}
// TODO(sandersd): Reorganize to be more similar to
@@ -883,18 +891,6 @@ std::string GetPrefixedKeySystemName(const std::string& key_system) {
return key_system;
}
-bool IsSaneInitDataTypeWithContainer(
- const std::string& init_data_type,
- const std::string& container) {
- if (init_data_type == "cenc") {
- return container == "audio/mp4" || container == "video/mp4";
- } else if (init_data_type == "webm") {
- return container == "audio/webm" || container == "video/webm";
- } else {
- return true;
- }
-}
-
bool PrefixedIsSupportedConcreteKeySystem(const std::string& key_system) {
return KeySystems::GetInstance().IsConcreteSupportedKeySystem(key_system);
}
« no previous file with comments | « media/base/key_systems.h ('k') | media/base/key_systems_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698