OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <algorithm> | 5 #include <algorithm> |
6 #include <iterator> | 6 #include <iterator> |
7 #include <map> | 7 #include <map> |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/containers/hash_tables.h" | 10 #include "base/containers/hash_tables.h" |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
70 | 70 |
71 void ParseCodecString(const std::string& codecs, | 71 void ParseCodecString(const std::string& codecs, |
72 std::vector<std::string>* codecs_out, | 72 std::vector<std::string>* codecs_out, |
73 bool strip); | 73 bool strip); |
74 | 74 |
75 bool IsStrictMediaMimeType(const std::string& mime_type) const; | 75 bool IsStrictMediaMimeType(const std::string& mime_type) const; |
76 bool IsSupportedStrictMediaMimeType( | 76 bool IsSupportedStrictMediaMimeType( |
77 const std::string& mime_type, | 77 const std::string& mime_type, |
78 const std::vector<std::string>& codecs) const; | 78 const std::vector<std::string>& codecs) const; |
79 | 79 |
| 80 void RemoveProprietaryMediaTypesAndCodecsForTests(); |
| 81 |
80 private: | 82 private: |
81 friend struct base::DefaultLazyInstanceTraits<MimeUtil>; | 83 friend struct base::DefaultLazyInstanceTraits<MimeUtil>; |
82 | 84 |
83 typedef base::hash_set<std::string> MimeMappings; | 85 typedef base::hash_set<std::string> MimeMappings; |
84 typedef std::map<std::string, MimeMappings> StrictMappings; | 86 typedef std::map<std::string, MimeMappings> StrictMappings; |
85 | 87 |
86 MimeUtil(); | 88 MimeUtil(); |
87 | 89 |
88 // Returns true if |codecs| is nonempty and all the items in it are present in | 90 // Returns true if |codecs| is nonempty and all the items in it are present in |
89 // |supported_codecs|. | 91 // |supported_codecs|. |
(...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
257 "image/x-xbitmap" // xbm | 259 "image/x-xbitmap" // xbm |
258 }; | 260 }; |
259 | 261 |
260 // A list of media types: http://en.wikipedia.org/wiki/Internet_media_type | 262 // A list of media types: http://en.wikipedia.org/wiki/Internet_media_type |
261 // A comprehensive mime type list: http://plugindoc.mozdev.org/winmime.php | 263 // A comprehensive mime type list: http://plugindoc.mozdev.org/winmime.php |
262 // This set of codecs is supported by all variations of Chromium. | 264 // This set of codecs is supported by all variations of Chromium. |
263 static const char* const common_media_types[] = { | 265 static const char* const common_media_types[] = { |
264 // Ogg. | 266 // Ogg. |
265 "audio/ogg", | 267 "audio/ogg", |
266 "application/ogg", | 268 "application/ogg", |
267 #if defined(ENABLE_MEDIA_CODEC_THEORA) | 269 #if !defined(OS_ANDROID) // Android doesn't support Ogg Theora. |
268 "video/ogg", | 270 "video/ogg", |
269 #endif | 271 #endif |
270 | 272 |
271 // WebM. | 273 // WebM. |
272 "video/webm", | 274 "video/webm", |
273 "audio/webm", | 275 "audio/webm", |
274 | 276 |
275 // Wav. | 277 // Wav. |
276 "audio/wav", | 278 "audio/wav", |
277 "audio/x-wav", | 279 "audio/x-wav", |
(...skipping 15 matching lines...) Expand all Loading... |
293 | 295 |
294 // List of supported codecs when passed in with <source type="...">. | 296 // List of supported codecs when passed in with <source type="...">. |
295 // This set of codecs is supported by all variations of Chromium. | 297 // This set of codecs is supported by all variations of Chromium. |
296 // | 298 // |
297 // Refer to http://wiki.whatwg.org/wiki/Video_type_parameters#Browser_Support | 299 // Refer to http://wiki.whatwg.org/wiki/Video_type_parameters#Browser_Support |
298 // for more information. | 300 // for more information. |
299 // | 301 // |
300 // The codecs for WAV are integers as defined in Appendix A of RFC2361: | 302 // The codecs for WAV are integers as defined in Appendix A of RFC2361: |
301 // http://tools.ietf.org/html/rfc2361 | 303 // http://tools.ietf.org/html/rfc2361 |
302 static const char* const common_media_codecs[] = { | 304 static const char* const common_media_codecs[] = { |
303 #if defined(ENABLE_MEDIA_CODEC_THEORA) | 305 #if !defined(OS_ANDROID) // Android doesn't support Ogg Theora. |
304 "theora", | 306 "theora", |
305 #endif | 307 #endif |
306 "vorbis", | 308 "vorbis", |
307 "vp8", | 309 "vp8", |
308 "vp9", | 310 "vp9", |
309 "1" // WAVE_FORMAT_PCM. | 311 "1" // WAVE_FORMAT_PCM. |
310 }; | 312 }; |
311 | 313 |
312 // List of proprietary codecs only supported by Google Chrome. | 314 // List of proprietary codecs only supported by Google Chrome. |
313 static const char* const proprietary_media_codecs[] = { | 315 static const char* const proprietary_media_codecs[] = { |
(...skipping 354 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
668 } | 670 } |
669 | 671 |
670 bool MimeUtil::IsSupportedStrictMediaMimeType( | 672 bool MimeUtil::IsSupportedStrictMediaMimeType( |
671 const std::string& mime_type, | 673 const std::string& mime_type, |
672 const std::vector<std::string>& codecs) const { | 674 const std::vector<std::string>& codecs) const { |
673 StrictMappings::const_iterator it = strict_format_map_.find(mime_type); | 675 StrictMappings::const_iterator it = strict_format_map_.find(mime_type); |
674 return (it != strict_format_map_.end()) && | 676 return (it != strict_format_map_.end()) && |
675 AreSupportedCodecs(it->second, codecs); | 677 AreSupportedCodecs(it->second, codecs); |
676 } | 678 } |
677 | 679 |
| 680 void MimeUtil::RemoveProprietaryMediaTypesAndCodecsForTests() { |
| 681 for (size_t i = 0; i < arraysize(proprietary_media_types); ++i) { |
| 682 non_image_map_.erase(proprietary_media_types[i]); |
| 683 media_map_.erase(proprietary_media_types[i]); |
| 684 } |
| 685 for (size_t i = 0; i < arraysize(proprietary_media_codecs); ++i) |
| 686 codecs_map_.erase(proprietary_media_codecs[i]); |
| 687 } |
| 688 |
678 //---------------------------------------------------------------------------- | 689 //---------------------------------------------------------------------------- |
679 // Wrappers for the singleton | 690 // Wrappers for the singleton |
680 //---------------------------------------------------------------------------- | 691 //---------------------------------------------------------------------------- |
681 | 692 |
682 bool GetMimeTypeFromExtension(const base::FilePath::StringType& ext, | 693 bool GetMimeTypeFromExtension(const base::FilePath::StringType& ext, |
683 std::string* mime_type) { | 694 std::string* mime_type) { |
684 return g_mime_util.Get().GetMimeTypeFromExtension(ext, mime_type); | 695 return g_mime_util.Get().GetMimeTypeFromExtension(ext, mime_type); |
685 } | 696 } |
686 | 697 |
687 bool GetMimeTypeFromFile(const base::FilePath& file_path, | 698 bool GetMimeTypeFromFile(const base::FilePath& file_path, |
(...skipping 239 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
927 | 938 |
928 GetExtensionsFromHardCodedMappings(secondary_mappings, | 939 GetExtensionsFromHardCodedMappings(secondary_mappings, |
929 arraysize(secondary_mappings), | 940 arraysize(secondary_mappings), |
930 mime_type, | 941 mime_type, |
931 &unique_extensions); | 942 &unique_extensions); |
932 } | 943 } |
933 | 944 |
934 HashSetToVector(&unique_extensions, extensions); | 945 HashSetToVector(&unique_extensions, extensions); |
935 } | 946 } |
936 | 947 |
937 void GetMediaTypesBlacklistedForTests(std::vector<std::string>* types) { | 948 void RemoveProprietaryMediaTypesAndCodecsForTests() { |
938 types->clear(); | 949 g_mime_util.Get().RemoveProprietaryMediaTypesAndCodecsForTests(); |
939 | |
940 // Unless/until WebM files are added to the media layout tests, we need to avoid | |
941 // blacklisting mp4 and H.264 when Theora is not supported (and proprietary | |
942 // codecs are) so that the media tests can still run. | |
943 #if defined(ENABLE_MEDIA_CODEC_THEORA) || !defined(USE_PROPRIETARY_CODECS) | |
944 for (size_t i = 0; i < arraysize(proprietary_media_types); ++i) | |
945 types->push_back(proprietary_media_types[i]); | |
946 #endif | |
947 } | |
948 | |
949 void GetMediaCodecsBlacklistedForTests(std::vector<std::string>* codecs) { | |
950 codecs->clear(); | |
951 | |
952 // Unless/until WebM files are added to the media layout tests, we need to avoid | |
953 // blacklisting mp4 and H.264 when Theora is not supported (and proprietary | |
954 // codecs are) so that the media tests can still run. | |
955 #if defined(ENABLE_MEDIA_CODEC_THEORA) || !defined(USE_PROPRIETARY_CODECS) | |
956 for (size_t i = 0; i < arraysize(proprietary_media_codecs); ++i) | |
957 codecs->push_back(proprietary_media_codecs[i]); | |
958 #endif | |
959 } | 950 } |
960 | 951 |
961 const std::string GetIANAMediaType(const std::string& mime_type) { | 952 const std::string GetIANAMediaType(const std::string& mime_type) { |
962 for (size_t i = 0; i < arraysize(kIanaMediaTypes); ++i) { | 953 for (size_t i = 0; i < arraysize(kIanaMediaTypes); ++i) { |
963 if (StartsWithASCII(mime_type, kIanaMediaTypes[i].matcher, true)) { | 954 if (StartsWithASCII(mime_type, kIanaMediaTypes[i].matcher, true)) { |
964 return kIanaMediaTypes[i].name; | 955 return kIanaMediaTypes[i].name; |
965 } | 956 } |
966 } | 957 } |
967 return std::string(); | 958 return std::string(); |
968 } | 959 } |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1003 post_data->append("\r\n" + value + "\r\n"); | 994 post_data->append("\r\n" + value + "\r\n"); |
1004 } | 995 } |
1005 | 996 |
1006 void AddMultipartFinalDelimiterForUpload(const std::string& mime_boundary, | 997 void AddMultipartFinalDelimiterForUpload(const std::string& mime_boundary, |
1007 std::string* post_data) { | 998 std::string* post_data) { |
1008 DCHECK(post_data); | 999 DCHECK(post_data); |
1009 post_data->append("--" + mime_boundary + "--\r\n"); | 1000 post_data->append("--" + mime_boundary + "--\r\n"); |
1010 } | 1001 } |
1011 | 1002 |
1012 } // namespace net | 1003 } // namespace net |
OLD | NEW |