summaryrefslogtreecommitdiffstats
path: root/webkit/glue/simple_webmimeregistry_impl.cc
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-07-30 00:22:05 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-07-30 00:22:05 +0000
commitd3a931dc4b33fb111f39dda795d97ac155554648 (patch)
treea3fb933c3fcd5f295ae68b62d040f3958b9f96cc /webkit/glue/simple_webmimeregistry_impl.cc
parent0cfb453028779455e9137e07613ff14c94e2516d (diff)
downloadchromium_src-d3a931dc4b33fb111f39dda795d97ac155554648.zip
chromium_src-d3a931dc4b33fb111f39dda795d97ac155554648.tar.gz
chromium_src-d3a931dc4b33fb111f39dda795d97ac155554648.tar.bz2
Fix a DCHECK we hit when a mime type isn't ASCII.
I have a layout test for this, but Tony says I should send it upstream so that will be a separate commit. BUG=17958 Review URL: http://codereview.chromium.org/160363 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@22027 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/simple_webmimeregistry_impl.cc')
-rw-r--r--webkit/glue/simple_webmimeregistry_impl.cc24
1 files changed, 18 insertions, 6 deletions
diff --git a/webkit/glue/simple_webmimeregistry_impl.cc b/webkit/glue/simple_webmimeregistry_impl.cc
index 29296ff..63c1165 100644
--- a/webkit/glue/simple_webmimeregistry_impl.cc
+++ b/webkit/glue/simple_webmimeregistry_impl.cc
@@ -14,18 +14,30 @@
using WebKit::WebString;
using WebKit::WebMimeRegistry;
+namespace {
+
+// Convert a WebString to ASCII, falling back on an empty string in the case
+// of a non-ASCII string.
+const std::string& AsASCII(const WebString& string) {
+ if (!IsStringASCII(string))
+ return EmptyString();
+ return UTF16ToASCII(string);
+}
+
+} // namespace
+
namespace webkit_glue {
WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsImageMIMEType(
const WebString& mime_type) {
- if (!net::IsSupportedImageMimeType(UTF16ToASCII(mime_type).c_str()))
+ if (!net::IsSupportedImageMimeType(AsASCII(mime_type).c_str()))
return WebMimeRegistry::IsNotSupported;
return WebMimeRegistry::IsSupported;
}
WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsJavaScriptMIMEType(
const WebString& mime_type) {
- if (!net::IsSupportedJavascriptMimeType(UTF16ToASCII(mime_type).c_str()))
+ if (!net::IsSupportedJavascriptMimeType(AsASCII(mime_type).c_str()))
return WebMimeRegistry::IsNotSupported;
return WebMimeRegistry::IsSupported;
}
@@ -33,12 +45,12 @@ WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsJavaScriptMIMET
WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsMediaMIMEType(
const WebString& mime_type, const WebString& codecs) {
// Not supporting the container is a flat-out no.
- if (!net::IsSupportedMediaMimeType(UTF16ToASCII(mime_type).c_str()))
+ if (!net::IsSupportedMediaMimeType(AsASCII(mime_type).c_str()))
return IsNotSupported;
// If we don't recognize the codec, it's possible we support it.
std::vector<std::string> parsed_codecs;
- net::ParseCodecString(UTF16ToASCII(codecs).c_str(), &parsed_codecs);
+ net::ParseCodecString(AsASCII(codecs).c_str(), &parsed_codecs);
if (!net::AreSupportedMediaCodecs(parsed_codecs))
return MayBeSupported;
@@ -48,7 +60,7 @@ WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsMediaMIMEType(
WebMimeRegistry::SupportsType SimpleWebMimeRegistryImpl::supportsNonImageMIMEType(
const WebString& mime_type) {
- if (!net::IsSupportedNonImageMimeType(UTF16ToASCII(mime_type).c_str()))
+ if (!net::IsSupportedNonImageMimeType(AsASCII(mime_type).c_str()))
return WebMimeRegistry::IsNotSupported;
return WebMimeRegistry::IsSupported;
}
@@ -72,7 +84,7 @@ WebString SimpleWebMimeRegistryImpl::mimeTypeFromFile(
WebString SimpleWebMimeRegistryImpl::preferredExtensionForMIMEType(
const WebString& mime_type) {
FilePath::StringType file_extension;
- net::GetPreferredExtensionForMimeType(UTF16ToASCII(mime_type),
+ net::GetPreferredExtensionForMimeType(AsASCII(mime_type),
&file_extension);
return FilePathStringToWebString(file_extension);
}