Merge m-c to inbound
authorCarsten "Tomcat" Book <cbook@mozilla.com>
Tue, 23 Jul 2013 11:06:20 +0200
changeset 151839 1ede6adb61d65f8210dbefb0e6247b702c9e70a9
parent 151838 bf53001aa2c795cd6bf525f2bbbb6eb82df6af36 (current diff)
parent 151768 fb4bf993a58a153a1d63302ccd2aa3103975f850 (diff)
child 151840 b717a7945dfbc1af6c51eccb67be0d640766e44c
child 151861 a80f35bdbaa0e86fb4e758176a683c57cc902993
push id2859
push userakeybl@mozilla.com
push dateMon, 16 Sep 2013 19:14:59 +0000
treeherdermozilla-beta@87d3c51cd2bf [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
milestone25.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Merge m-c to inbound
content/html/content/reftests/toblob-todataurl/blob.js
content/html/content/reftests/toblob-todataurl/dataurl.js
content/html/content/reftests/toblob-todataurl/images/original.png
content/html/content/reftests/toblob-todataurl/images/q0.jpg
content/html/content/reftests/toblob-todataurl/images/q100.jpg
content/html/content/reftests/toblob-todataurl/images/q25.jpg
content/html/content/reftests/toblob-todataurl/images/q50.jpg
content/html/content/reftests/toblob-todataurl/images/q75.jpg
content/html/content/reftests/toblob-todataurl/images/q92.jpg
content/html/content/reftests/toblob-todataurl/quality-0-ref.html
content/html/content/reftests/toblob-todataurl/quality-100-ref.html
content/html/content/reftests/toblob-todataurl/quality-25-ref.html
content/html/content/reftests/toblob-todataurl/quality-50-ref.html
content/html/content/reftests/toblob-todataurl/quality-75-ref.html
content/html/content/reftests/toblob-todataurl/quality-92-ref.html
content/html/content/reftests/toblob-todataurl/reftest.list
content/html/content/reftests/toblob-todataurl/sample.js
content/html/content/reftests/toblob-todataurl/toblob-quality-0.html
content/html/content/reftests/toblob-todataurl/toblob-quality-100.html
content/html/content/reftests/toblob-todataurl/toblob-quality-25.html
content/html/content/reftests/toblob-todataurl/toblob-quality-50.html
content/html/content/reftests/toblob-todataurl/toblob-quality-75.html
content/html/content/reftests/toblob-todataurl/toblob-quality-92.html
content/html/content/reftests/toblob-todataurl/toblob-quality-default.html
content/html/content/reftests/toblob-todataurl/toblob-quality-undefined.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-0.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-100.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-25.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-50.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-75.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-92.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-default.html
content/html/content/reftests/toblob-todataurl/todataurl-quality-undefined.html
--- a/content/html/content/public/HTMLCanvasElement.h
+++ b/content/html/content/public/HTMLCanvasElement.h
@@ -95,26 +95,20 @@ public:
                  const Optional<JS::Handle<JS::Value> >& aParams,
                  nsAString& aDataURL, ErrorResult& aRv)
   {
     JS::Value params = aParams.WasPassed()
                      ? aParams.Value()
                      : JS::UndefinedValue();
     aRv = ToDataURL(aType, params, aCx, aDataURL);
   }
-  void ToBlob(JSContext* aCx,
-              nsIFileCallback* aCallback,
-              const nsAString& aType,
-              const Optional<JS::Handle<JS::Value> >& aParams,
+  void ToBlob(nsIFileCallback* aCallback, const nsAString& aType,
               ErrorResult& aRv)
   {
-    JS::Value params = aParams.WasPassed()
-                     ? aParams.Value()
-                     : JS::UndefinedValue();
-    aRv = ToBlob(aCallback, aType, params, aCx);
+    aRv = ToBlob(aCallback, aType);
   }
 
   bool MozOpaque() const
   {
     return GetBoolAttr(nsGkAtoms::moz_opaque);
   }
   void SetMozOpaque(bool aValue, ErrorResult& aRv)
   {
@@ -228,21 +222,16 @@ public:
 
 protected:
   virtual JSObject* WrapNode(JSContext* aCx,
                              JS::Handle<JSObject*> aScope) MOZ_OVERRIDE;
 
   nsIntSize GetWidthHeight();
 
   nsresult UpdateContext(JSContext* aCx, JS::Handle<JS::Value> options);
-  nsresult ParseParams(JSContext* aCx,
-                       const nsAString& aType,
-                       const JS::Value& aEncoderOptions,
-                       nsAString& aParams,
-                       bool* usingCustomParseOptions);
   nsresult ExtractData(const nsAString& aType,
                        const nsAString& aOptions,
                        nsIInputStream** aStream,
                        bool& aFellBackToPNG);
   nsresult ToDataURLImpl(JSContext* aCx,
                          const nsAString& aMimeType,
                          const JS::Value& aEncoderOptions,
                          nsAString& aDataURL);
--- a/content/html/content/reftests/reftest.list
+++ b/content/html/content/reftests/reftest.list
@@ -1,11 +1,10 @@
 # autofocus attribute (we can't test with mochitests)
 include autofocus/reftest.list
-include toblob-todataurl/reftest.list
 
 skip-if(B2G) == 41464-1a.html 41464-1-ref.html
 skip-if(B2G) == 41464-1b.html 41464-1-ref.html
 == 52019-1.html 52019-1-ref.html
 != 468263-1a.html about:blank
 != 468263-1b.html about:blank
 != 468263-1c.html about:blank
 != 468263-1d.html about:blank
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/blob.js
+++ /dev/null
@@ -1,68 +0,0 @@
-function init() {
-  function end() {
-    document.documentElement.className = '';
-  }
-
-  function next() {
-    compressAndDisplay(original, end);
-  }
-
-  var original = getImageFromDataUrl(sample);
-  setImgLoadListener(original, next);
-}
-
-function compressAndDisplay(image, next) {
-  var canvas = document.createElement('canvas');
-  canvas.width = image.naturalWidth;
-  canvas.height = image.naturalHeight;
-  var ctx = canvas.getContext('2d');
-  ctx.drawImage(image, 0, 0);
-
-  function gotBlob(blob) {
-    var img = getImageFromBlob(blob);
-    setImgLoadListener(img, next);
-    document.body.appendChild(img);
-  }
-
-  // I want to test passing 'undefined' as quality as well
-  if ('quality' in window) {
-    canvas.toBlob(gotBlob, 'image/jpeg', quality);
-  } else {
-    canvas.toBlob(gotBlob, 'image/jpeg');
-  }
-}
-
-function setImgLoadListener(img, func) {
-  if (img.complete) {
-    func.call(img, { target: img});
-  } else {
-    img.addEventListener('load', func);
-  }
-}
-
-function naturalDimensionsHandler(e) {
-  var img = e.target;
-  img.width = img.naturalWidth;
-  img.height = img.naturalHeight;
-}
-
-function getImageFromBlob(blob) {
-  var img = document.createElement('img');
-  img.src = window.URL.createObjectURL(blob);
-  setImgLoadListener(img, naturalDimensionsHandler);
-  setImgLoadListener(img, function(e) {
-    window.URL.revokeObjectURL(e.target.src);
-  });
-
-  return img;
-}
-
-function getImageFromDataUrl(url) {
-  var img = document.createElement('img');
-  img.src = url;
-  setImgLoadListener(img, naturalDimensionsHandler);
-
-  return img;
-}
-
-init();
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/dataurl.js
+++ /dev/null
@@ -1,56 +0,0 @@
-function init() {
-  function end() {
-    document.documentElement.className = '';
-  }
-
-  function next() {
-    compressAndDisplay(original, end);
-  }
-
-  var original = getImageFromDataUrl(sample);
-  setImgLoadListener(original, next);
-}
-
-function compressAndDisplay(image, next) {
-  var canvas = document.createElement('canvas');
-  canvas.width = image.naturalWidth;
-  canvas.height = image.naturalHeight;
-  var ctx = canvas.getContext('2d');
-  ctx.drawImage(image, 0, 0);
-
-  var dataUrl;
-  // I want to test passing undefined as well
-  if ('quality' in window) {
-    dataUrl = canvas.toDataURL('image/jpeg', quality);
-  } else {
-    dataUrl = canvas.toDataURL('image/jpeg');
-  }
-
-  var img = getImageFromDataUrl(dataUrl);
-  setImgLoadListener(img, next);
-  document.body.appendChild(img);
-}
-
-function setImgLoadListener(img, func) {
-  if (img.complete) {
-    func.call(img, { target: img});
-  } else {
-    img.addEventListener('load', func);
-  }
-}
-
-function naturalDimensionsHandler(e) {
-  var img = e.target;
-  img.width = img.naturalWidth;
-  img.height = img.naturalHeight;
-}
-
-function getImageFromDataUrl(url) {
-  var img = document.createElement('img');
-  img.src = url;
-  setImgLoadListener(img, naturalDimensionsHandler);
-
-  return img;
-}
-
-init();
deleted file mode 100644
index c2da5b3597dc957b4c9800a610fd2a8021bfd863..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index eb41ad3e93a7461b39fc2d4c0e46bff9a5675529..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index aaa79f2d31fd8d4ec1158ecb864455e6eb18bcdc..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index d8b1c9bfb29cd4910af4cfb3f2fac0a7441b4fd8..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index f93356ef22d4df63da17bf60fe2c2855c5130396..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index 6c25c55a1ad5be4396b6910bbc32bb3a0a05d05e..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
index 1de242a17172475176d4bbd9bcda223514d0c680..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
GIT binary patch
literal 0
Hc$@<O00001
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-0-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q0.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-100-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q100.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-25-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q25.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-50-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q50.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-75-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q75.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/quality-92-ref.html
+++ /dev/null
@@ -1,2 +0,0 @@
-<!doctype html>
-<html><body><img src='images/q92.jpg'/></table></body></html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/reftest.list
+++ /dev/null
@@ -1,16 +0,0 @@
-== toblob-quality-0.html quality-0-ref.html
-== toblob-quality-25.html quality-25-ref.html
-== toblob-quality-50.html quality-50-ref.html
-== toblob-quality-75.html quality-75-ref.html
-== toblob-quality-92.html quality-92-ref.html
-== toblob-quality-100.html quality-100-ref.html
-== toblob-quality-undefined.html quality-92-ref.html
-== toblob-quality-default.html quality-92-ref.html
-== todataurl-quality-0.html quality-0-ref.html
-== todataurl-quality-25.html quality-25-ref.html
-== todataurl-quality-50.html quality-50-ref.html
-== todataurl-quality-75.html quality-75-ref.html
-== todataurl-quality-92.html quality-92-ref.html
-== todataurl-quality-100.html quality-100-ref.html
-== todataurl-quality-undefined.html quality-92-ref.html
-== todataurl-quality-default.html quality-92-ref.html
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/sample.js
+++ /dev/null
@@ -1,2 +0,0 @@
-var sample = 
-  '';
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-0.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-100.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 1;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-25.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.25;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-50.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.50;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-75.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.75;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-92.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.92;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-default.html
+++ /dev/null
@@ -1,7 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/toblob-quality-undefined.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = undefined;
-    </script>
-    <script src='sample.js'></script>
-    <script src='blob.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-0.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-100.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 1;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-25.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.25;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-50.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.50;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-75.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.75;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-92.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = 0.92;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-default.html
+++ /dev/null
@@ -1,7 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
deleted file mode 100644
--- a/content/html/content/reftests/toblob-todataurl/todataurl-quality-undefined.html
+++ /dev/null
@@ -1,10 +0,0 @@
-<!doctype html>
-<html class='reftest-wait'>
-  <body>
-    <script>
-      var quality = undefined;
-    </script>
-    <script src='sample.js'></script>
-    <script src='dataurl.js'></script>
-  </body>
-</html>
--- a/content/html/content/src/HTMLCanvasElement.cpp
+++ b/content/html/content/src/HTMLCanvasElement.cpp
@@ -471,58 +471,16 @@ HTMLCanvasElement::ExtractData(const nsA
 
   NS_ENSURE_SUCCESS(rv, rv);
 
   imgStream.forget(aStream);
   return NS_OK;
 }
 
 nsresult
-HTMLCanvasElement::ParseParams(JSContext* aCx,
-                               const nsAString& aType,
-                               const JS::Value& aEncoderOptions,
-                               nsAString& aParams,
-                               bool* usingCustomParseOptions)
-{
-  // Quality parameter is only valid for the image/jpeg MIME type
-  if (aType.EqualsLiteral("image/jpeg")) {
-    if (aEncoderOptions.isNumber()) {
-      double quality = aEncoderOptions.toNumber();
-      // Quality must be between 0.0 and 1.0, inclusive
-      if (quality >= 0.0 && quality <= 1.0) {
-        aParams.AppendLiteral("quality=");
-        aParams.AppendInt(NS_lround(quality * 100.0));
-      }
-    }
-  }
-
-  // If we haven't parsed the aParams check for proprietary options.
-  // The proprietary option -moz-parse-options will take a image lib encoder
-  // parse options string as is and pass it to the encoder.
-  *usingCustomParseOptions = false;
-  if (aParams.Length() == 0 && aEncoderOptions.isString()) {
-    NS_NAMED_LITERAL_STRING(mozParseOptions, "-moz-parse-options:");
-    nsDependentJSString paramString;
-    if (!paramString.init(aCx, aEncoderOptions.toString())) {
-      return NS_ERROR_FAILURE;
-    }
-    if (StringBeginsWith(paramString, mozParseOptions)) {
-      nsDependentSubstring parseOptions = Substring(paramString,
-                                                    mozParseOptions.Length(),
-                                                    paramString.Length() -
-                                                    mozParseOptions.Length());
-      aParams.Append(parseOptions);
-      *usingCustomParseOptions = true;
-    }
-  }
-
-  return NS_OK;
-}
-
-nsresult
 HTMLCanvasElement::ToDataURLImpl(JSContext* aCx,
                                  const nsAString& aMimeType,
                                  const JS::Value& aEncoderOptions,
                                  nsAString& aDataURL)
 {
   bool fallbackToPNG = false;
 
   nsIntSize size = GetWidthHeight();
@@ -533,20 +491,47 @@ HTMLCanvasElement::ToDataURLImpl(JSConte
 
   nsAutoString type;
   nsresult rv = nsContentUtils::ASCIIToLower(aMimeType, type);
   if (NS_FAILED(rv)) {
     return rv;
   }
 
   nsAutoString params;
-  bool usingCustomParseOptions;
-  rv = ParseParams(aCx, type, aEncoderOptions, params, &usingCustomParseOptions);
-  if (NS_FAILED(rv)) {
-    return rv;
+
+  // Quality parameter is only valid for the image/jpeg MIME type
+  if (type.EqualsLiteral("image/jpeg")) {
+    if (aEncoderOptions.isNumber()) {
+      double quality = aEncoderOptions.toNumber();
+      // Quality must be between 0.0 and 1.0, inclusive
+      if (quality >= 0.0 && quality <= 1.0) {
+        params.AppendLiteral("quality=");
+        params.AppendInt(NS_lround(quality * 100.0));
+      }
+    }
+  }
+
+  // If we haven't parsed the params check for proprietary options.
+  // The proprietary option -moz-parse-options will take a image lib encoder
+  // parse options string as is and pass it to the encoder.
+  bool usingCustomParseOptions = false;
+  if (params.Length() == 0 && aEncoderOptions.isString()) {
+    NS_NAMED_LITERAL_STRING(mozParseOptions, "-moz-parse-options:");
+    nsDependentJSString paramString;
+    if (!paramString.init(aCx, aEncoderOptions.toString())) {
+      return NS_ERROR_FAILURE;
+    }
+    if (StringBeginsWith(paramString, mozParseOptions)) {
+      nsDependentSubstring parseOptions = Substring(paramString,
+                                                    mozParseOptions.Length(),
+                                                    paramString.Length() -
+                                                    mozParseOptions.Length());
+      params.Append(parseOptions);
+      usingCustomParseOptions = true;
+    }
   }
 
   nsCOMPtr<nsIInputStream> stream;
   rv = ExtractData(type, params, getter_AddRefs(stream), fallbackToPNG);
 
   // If there are unrecognized custom parse options, we should fall back to
   // the default values for the encoder without any options at all.
   if (rv == NS_ERROR_INVALID_ARG && usingCustomParseOptions) {
@@ -569,53 +554,37 @@ HTMLCanvasElement::ToDataURLImpl(JSConte
   NS_ENSURE_TRUE(count <= UINT32_MAX, NS_ERROR_FILE_TOO_BIG);
 
   return Base64EncodeInputStream(stream, aDataURL, (uint32_t)count, aDataURL.Length());
 }
 
 // XXXkhuey the encoding should be off the main thread, but we're lazy.
 NS_IMETHODIMP
 HTMLCanvasElement::ToBlob(nsIFileCallback* aCallback,
-                          const nsAString& aType,
-                          const JS::Value& aEncoderOptions,
-                          JSContext* aCx)
+                          const nsAString& aType)
 {
   // do a trust check if this is a write-only canvas
   if (mWriteOnly && !nsContentUtils::IsCallerChrome()) {
     return NS_ERROR_DOM_SECURITY_ERR;
   }
 
   if (!aCallback) {
     return NS_ERROR_UNEXPECTED;
   }
 
   nsAutoString type;
   nsresult rv = nsContentUtils::ASCIIToLower(aType, type);
   if (NS_FAILED(rv)) {
     return rv;
   }
 
-  nsAutoString params;
-  bool usingCustomParseOptions;
-  rv = ParseParams(aCx, type, aEncoderOptions, params, &usingCustomParseOptions);
-  if (NS_FAILED(rv)) {
-    return rv;
-  }
-
   bool fallbackToPNG = false;
 
   nsCOMPtr<nsIInputStream> stream;
-  rv = ExtractData(type, params, getter_AddRefs(stream), fallbackToPNG);
-  // If there are unrecognized custom parse options, we should fall back to
-  // the default values for the encoder without any options at all.
-  if (rv == NS_ERROR_INVALID_ARG && usingCustomParseOptions) {
-    fallbackToPNG = false;
-    rv = ExtractData(type, EmptyString(), getter_AddRefs(stream), fallbackToPNG);
-  }
-
+  rv = ExtractData(type, EmptyString(), getter_AddRefs(stream), fallbackToPNG);
   NS_ENSURE_SUCCESS(rv, rv);
 
   if (fallbackToPNG) {
     type.AssignLiteral("image/png");
   }
 
   uint64_t imgSize;
   rv = stream->Available(&imgSize);
--- a/dom/interfaces/html/nsIDOMHTMLCanvasElement.idl
+++ b/dom/interfaces/html/nsIDOMHTMLCanvasElement.idl
@@ -41,17 +41,17 @@ interface nsIPrintCallback : nsISupports
   void render(in nsIDOMMozCanvasPrintState ctx);
 };
 
 [scriptable, function, uuid(6e9ffb59-2067-4aef-a51c-65e65a3e0d81)]
 interface nsIFileCallback : nsISupports {
   void receive(in nsIDOMBlob file);
 };
 
-[scriptable, uuid(788f69a4-30e0-42b4-804d-b99549f9d463)]
+[scriptable, uuid(350fddae-4476-4dcd-bccf-9c9c356354a6)]
 interface nsIDOMHTMLCanvasElement : nsIDOMHTMLElement
 {
   attribute unsigned long width;
   attribute unsigned long height;
   attribute boolean mozOpaque;
 
   // Valid calls are:
   //  toDataURL();              -- defaults to image/png
@@ -61,24 +61,18 @@ interface nsIDOMHTMLCanvasElement : nsID
   DOMString toDataURL([optional] in DOMString type,
                       [optional] in jsval params);
 
   // Valid calls are
   // mozGetAsFile(name);              -- defaults to image/png
   // mozGetAsFile(name, type);        -- uses given type
   nsIDOMFile mozGetAsFile(in DOMString name, [optional] in DOMString type);
 
-  // Valid calls are:
-  //  toBlob();              -- defaults to image/png
-  //  toBlob(type);          -- uses given type
-  //  toBlob(type, params);  -- uses given type, and any valid parameters
-  [implicit_jscontext]
   void toBlob(in nsIFileCallback callback,
-              [optional] in DOMString type,
-              [optional] in jsval params);
+              [optional] in DOMString type);
 
   // A Mozilla-only extension to get a canvas context backed by double-buffered
   // shared memory. Only privileged callers can call this.
   nsISupports MozGetIPCContext(in DOMString contextId);
 
   // A Mozilla-only extension that returns the canvas' image data as a data
   // stream in the desired image format.
   void mozFetchAsStream(in nsIInputStreamCallback callback,
--- a/dom/webidl/HTMLCanvasElement.webidl
+++ b/dom/webidl/HTMLCanvasElement.webidl
@@ -25,19 +25,17 @@ interface HTMLCanvasElement : HTMLElemen
 
   [Throws]
   nsISupports? getContext(DOMString contextId, optional any contextOptions = null);
 
   [Throws]
   DOMString toDataURL(optional DOMString type = "",
                       optional any encoderOptions);
   [Throws]
-  void toBlob(FileCallback _callback,
-              optional DOMString type = "",
-              optional any encoderOptions);
+  void toBlob(FileCallback _callback, optional DOMString type = "");
 };
 
 // Mozilla specific bits
 partial interface HTMLCanvasElement {
   [Pure, SetterThrows]
            attribute boolean mozOpaque;
   [Throws]
   File mozGetAsFile(DOMString name, optional DOMString? type = null);