diff --git a/Cargo.lock b/Cargo.lock index 4d99f2229c15..effd71b9f837 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2937,6 +2937,7 @@ dependencies = [ "fxhash 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", "gleam 0.6.8 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.43 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.5 (registry+https://github.com/rust-lang/crates.io-index)", "num-traits 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", "plane-split 0.13.3 (registry+https://github.com/rust-lang/crates.io-index)", diff --git a/browser/branding/aurora/pref/firefox-branding.js b/browser/branding/aurora/pref/firefox-branding.js index eab20db6facd..f83ef604ad7b 100644 --- a/browser/branding/aurora/pref/firefox-branding.js +++ b/browser/branding/aurora/pref/firefox-branding.js @@ -9,10 +9,6 @@ pref("startup.homepage_welcome_url", "https://www.mozilla.org/%LOCALE%/firefox/% pref("startup.homepage_welcome_url.additional", ""); // The time interval between checks for a new version (in seconds) pref("app.update.interval", 28800); // 8 hours -// The time interval between the downloading of mar file chunks in the -// background (in seconds) -// 0 means "download everything at once" -pref("app.update.download.backgroundInterval", 0); // Give the user x seconds to react before showing the big UI. default=192 hours pref("app.update.promptWaitTime", 691200); // URL user can browse to manually if for some reason all update installation diff --git a/browser/branding/nightly/pref/firefox-branding.js b/browser/branding/nightly/pref/firefox-branding.js index 183244f348fd..f82de1b00d20 100644 --- a/browser/branding/nightly/pref/firefox-branding.js +++ b/browser/branding/nightly/pref/firefox-branding.js @@ -7,10 +7,6 @@ pref("startup.homepage_welcome_url", "https://www.mozilla.org/projects/firefox/% pref("startup.homepage_welcome_url.additional", ""); // The time interval between checks for a new version (in seconds) pref("app.update.interval", 7200); // 2 hours -// The time interval between the downloading of mar file chunks in the -// background (in seconds) -// 0 means "download everything at once" -pref("app.update.download.backgroundInterval", 0); // Give the user x seconds to react before showing the big UI. default=12 hours pref("app.update.promptWaitTime", 43200); // URL user can browse to manually if for some reason all update installation diff --git a/browser/branding/official/pref/firefox-branding.js b/browser/branding/official/pref/firefox-branding.js index 11be38308c1e..d902f74ec053 100644 --- a/browser/branding/official/pref/firefox-branding.js +++ b/browser/branding/official/pref/firefox-branding.js @@ -7,10 +7,6 @@ pref("startup.homepage_welcome_url", "about:welcome"); pref("startup.homepage_welcome_url.additional", ""); // Interval: Time between checks for a new version (in seconds) pref("app.update.interval", 43200); // 12 hours -// The time interval between the downloading of mar file chunks in the -// background (in seconds) -// 0 means "download everything at once" -pref("app.update.download.backgroundInterval", 0); // Give the user x seconds to react before showing the big UI. default=192 hours pref("app.update.promptWaitTime", 691200); // app.update.url.manual: URL user can browse to manually if for some reason diff --git a/browser/branding/unofficial/pref/firefox-branding.js b/browser/branding/unofficial/pref/firefox-branding.js index 71f76e57a11d..038f4565c016 100644 --- a/browser/branding/unofficial/pref/firefox-branding.js +++ b/browser/branding/unofficial/pref/firefox-branding.js @@ -7,9 +7,6 @@ pref("startup.homepage_welcome_url", ""); pref("startup.homepage_welcome_url.additional", ""); // The time interval between checks for a new version (in seconds) pref("app.update.interval", 86400); // 24 hours -// The time interval between the downloading of mar file chunks in the -// background (in seconds) -pref("app.update.download.backgroundInterval", 60); // Give the user x seconds to react before showing the big UI. default=24 hours pref("app.update.promptWaitTime", 86400); // URL user can browse to manually if for some reason all update installation diff --git a/browser/components/nsBrowserContentHandler.js b/browser/components/nsBrowserContentHandler.js index 888f94b2c1b4..9266e2517a8b 100644 --- a/browser/components/nsBrowserContentHandler.js +++ b/browser/components/nsBrowserContentHandler.js @@ -123,12 +123,12 @@ function getPostUpdateOverridePage(defaultOverridePage) { // history. if (um.activeUpdate) { var update = um.activeUpdate - .QueryInterface(Ci.nsIPropertyBag); + .QueryInterface(Ci.nsIWritablePropertyBag); } else { // If the updates.xml file is deleted then getUpdateAt will throw. try { update = um.getUpdateAt(0) - .QueryInterface(Ci.nsIPropertyBag); + .QueryInterface(Ci.nsIWritablePropertyBag); } catch (e) { Cu.reportError("Unable to find update: " + e); return defaultOverridePage; diff --git a/browser/components/nsBrowserGlue.js b/browser/components/nsBrowserGlue.js index 891a8caabbf7..dcffe1eeb554 100644 --- a/browser/components/nsBrowserGlue.js +++ b/browser/components/nsBrowserGlue.js @@ -1865,7 +1865,7 @@ BrowserGlue.prototype = { getService(Ci.nsIUpdateManager); try { // If the updates.xml file is deleted then getUpdateAt will throw. - var update = um.getUpdateAt(0).QueryInterface(Ci.nsIPropertyBag); + var update = um.getUpdateAt(0).QueryInterface(Ci.nsIWritablePropertyBag); } catch (e) { // This should never happen. Cu.reportError("Unable to find update: " + e); diff --git a/browser/components/search/searchplugins/google-2018.xml b/browser/components/search/searchplugins/google-2018.xml index 48fa1bef5551..a078c1de505c 100644 --- a/browser/components/search/searchplugins/google-2018.xml +++ b/browser/components/search/searchplugins/google-2018.xml @@ -6,7 +6,7 @@ Google Google Search UTF-8 -resource://search-plugins/images/google.ico + diff --git a/browser/components/search/searchplugins/google-b-1-d.xml b/browser/components/search/searchplugins/google-b-1-d.xml deleted file mode 100644 index 2d43390a0e70..000000000000 --- a/browser/components/search/searchplugins/google-b-1-d.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - -Google -Google Search -UTF-8 -resource://search-plugins/images/google.ico - - - - - - diff --git a/browser/components/search/searchplugins/google-b-1-e.xml b/browser/components/search/searchplugins/google-b-1-e.xml deleted file mode 100644 index ea251fc80161..000000000000 --- a/browser/components/search/searchplugins/google-b-1-e.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - -Google -Google Search -UTF-8 -resource://search-plugins/images/google.ico - - - - - - diff --git a/browser/components/search/searchplugins/google-b-d.xml b/browser/components/search/searchplugins/google-b-d.xml deleted file mode 100644 index 9b7f5e77185e..000000000000 --- a/browser/components/search/searchplugins/google-b-d.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - -Google -Google Search -UTF-8 -resource://search-plugins/images/google.ico - - - - - - diff --git a/browser/components/search/searchplugins/google-b-e.xml b/browser/components/search/searchplugins/google-b-e.xml deleted file mode 100644 index 43b48a0a175d..000000000000 --- a/browser/components/search/searchplugins/google-b-e.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - -Google -Google Search -UTF-8 -resource://search-plugins/images/google.ico - - - - - - diff --git a/browser/components/search/searchplugins/google.xml b/browser/components/search/searchplugins/google.xml index f41c8cbe335a..c71fa350433d 100644 --- a/browser/components/search/searchplugins/google.xml +++ b/browser/components/search/searchplugins/google.xml @@ -6,7 +6,7 @@ Google Google Search UTF-8 -resource://search-plugins/images/google.ico + diff --git a/browser/components/search/searchplugins/images/google.ico b/browser/components/search/searchplugins/images/google.ico deleted file mode 100644 index 82339b3b1dbb..000000000000 Binary files a/browser/components/search/searchplugins/images/google.ico and /dev/null differ diff --git a/browser/components/search/searchplugins/list.json b/browser/components/search/searchplugins/list.json index 334e9911d4e1..4cede962866a 100644 --- a/browser/components/search/searchplugins/list.json +++ b/browser/components/search/searchplugins/list.json @@ -3,12 +3,12 @@ "searchDefault": "Google", "searchOrder": ["Google", "Bing"], "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "bing", "ddg", "ebay", "twitter", "wikipedia" + "google", "amazondotcom", "bing", "ddg", "ebay", "twitter", "wikipedia" ] }, "regionOverrides": { "US": { - "google-b-d": "google-b-1-d" + "google": "google-2018" }, "CA": { "ebay": "ebay-ca", @@ -54,68 +54,68 @@ "en-US": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "bing", "ddg", "ebay", "twitter", "wikipedia" + "google", "amazondotcom", "bing", "ddg", "ebay", "twitter", "wikipedia" ] }, "experimental-hidden": { "visibleDefaultEngines": [ - "amazon-ca", "amazon-au", "google-2018", "yandex-en", "google", "google-b-1-e", "google-b-e" + "amazon-ca", "amazon-au", "google-2018", "yandex-en" ] } }, "ach": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia" ] } }, "af": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-af" + "google", "bing", "amazondotcom", "ddg", "wikipedia-af" ] } }, "an": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ebay-es", "wikipedia-an", "ddg", "twitter" + "google", "bing", "ebay-es", "wikipedia-an", "ddg", "twitter" ] } }, "ar": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-ar" + "google", "bing", "amazondotcom", "ddg", "wikipedia-ar" ] } }, "as": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-in", "ddg", "wikipedia-as" + "google", "amazon-in", "ddg", "wikipedia-as" ] } }, "ast": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "diccionariu-alla", "ddg", "ebay-es", "wikipedia-ast" + "google", "bing", "diccionariu-alla", "ddg", "ebay-es", "wikipedia-ast" ] } }, "az": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "azerdict", "bing", "ddg", "wikipedia-az", "yandex-az" + "google", "amazondotcom", "azerdict", "bing", "ddg", "wikipedia-az", "yandex-az" ] } }, "be": { "default": { "visibleDefaultEngines": [ - "yandex-by", "google-b-d", "ddg", "wikipedia-be", "wikipedia-be-tarask" + "yandex-by", "google", "ddg", "wikipedia-be", "wikipedia-be-tarask" ] }, "BY": { @@ -134,56 +134,56 @@ "bg": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "ddg", "pazaruvaj", "portalbgdict", "wikipedia-bg" + "google", "amazondotcom", "ddg", "pazaruvaj", "portalbgdict", "wikipedia-bg" ] } }, "bn-BD": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "wikipedia-bn" + "google", "bing", "ddg", "wikipedia-bn" ] } }, "bn-IN": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-in", "bing", "ddg", "rediff", "wikipedia-bn" + "google", "amazon-in", "bing", "ddg", "rediff", "wikipedia-bn" ] } }, "br": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-france", "ddg", "ebay-fr", "freelang", "klask", "wikipedia-br" + "google", "amazon-france", "ddg", "ebay-fr", "freelang", "klask", "wikipedia-br" ] } }, "bs": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "olx", "twitter", "wikipedia-bs" + "google", "ddg", "olx", "twitter", "wikipedia-bs" ] } }, "ca": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "diec2", "ddg", "ebay-es", "twitter", "wikipedia-ca" + "google", "bing", "diec2", "ddg", "ebay-es", "twitter", "wikipedia-ca" ] } }, "cak": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-es" + "google", "bing", "amazondotcom", "ddg", "wikipedia-es" ] } }, "crh": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "twitter", "wikipedia-crh" + "google", "ddg", "twitter", "wikipedia-crh" ] } }, @@ -191,56 +191,56 @@ "default": { "searchOrder": ["Google", "Seznam"], "visibleDefaultEngines": [ - "google-b-d", "seznam-cz", "ddg", "heureka-cz", "mapy-cz", "wikipedia-cz" + "google", "seznam-cz", "ddg", "heureka-cz", "mapy-cz", "wikipedia-cz" ] } }, "cy": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "ddg", "ebay-uk", "palasprint", "termau", "wikipedia-cy" + "google", "amazon-en-GB", "ddg", "ebay-uk", "palasprint", "termau", "wikipedia-cy" ] } }, "da": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-en-GB", "ddg", "wikipedia-da" + "google", "bing", "amazon-en-GB", "ddg", "wikipedia-da" ] } }, "de": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom-de", "bing", "ddg", "ebay-de", "ecosia", "leo_ende_de", "wikipedia-de" + "google", "amazondotcom-de", "bing", "ddg", "ebay-de", "ecosia", "leo_ende_de", "wikipedia-de" ] } }, "dsb": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom-de", "ddg", "ebay-de", "leo_ende_de", "wikipedia-dsb" + "google", "bing", "amazondotcom-de", "ddg", "ebay-de", "leo_ende_de", "wikipedia-dsb" ] } }, "el": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "bing", "ddg", "wikipedia-el" + "google", "amazon-en-GB", "bing", "ddg", "wikipedia-el" ] } }, "en-CA": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-ca", "bing", "ddg", "ebay-ca", "twitter", "wikipedia" + "google", "amazon-ca", "bing", "ddg", "ebay-ca", "twitter", "wikipedia" ] } }, "en-GB": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-en-GB", "chambers-en-GB", "ddg", "ebay-uk", "twitter", "wikipedia" + "google", "bing", "amazon-en-GB", "chambers-en-GB", "ddg", "ebay-uk", "twitter", "wikipedia" ] }, "experimental-hidden": { @@ -252,42 +252,42 @@ "en-ZA": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia" ] } }, "eo": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "reta-vortaro", "wikipedia-eo" + "google", "bing", "amazondotcom", "ddg", "reta-vortaro", "wikipedia-eo" ] } }, "es-AR": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "drae", "ddg", "mercadolibre-ar", "wikipedia-es" + "google", "amazondotcom", "drae", "ddg", "mercadolibre-ar", "wikipedia-es" ] } }, "es-CL": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "drae", "ddg", "mercadolibre-cl", "wikipedia-es" + "google", "bing", "drae", "ddg", "mercadolibre-cl", "wikipedia-es" ] } }, "es-ES": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "drae", "ddg", "ebay-es", "twitter", "wikipedia-es" + "google", "bing", "drae", "ddg", "ebay-es", "twitter", "wikipedia-es" ] } }, "es-MX": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "mercadolibre-mx", "wikipedia-es" + "google", "bing", "ddg", "mercadolibre-mx", "wikipedia-es" ] }, "experimental-hidden": { @@ -299,49 +299,49 @@ "et": { "default": { "visibleDefaultEngines": [ - "google-b-d", "neti-ee", "ddg", "osta-ee", "wikipedia-et", "eki-ee" + "google", "neti-ee", "ddg", "osta-ee", "wikipedia-et", "eki-ee" ] } }, "eu": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-en-GB", "ddg", "ebay-es", "elebila", "wikipedia-eu" + "google", "bing", "amazon-en-GB", "ddg", "ebay-es", "elebila", "wikipedia-eu" ] } }, "fa": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "bing", "ddg", "wikipedia-fa" + "google", "amazondotcom", "bing", "ddg", "wikipedia-fa" ] } }, "ff": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-france", "ddg", "cnrtl-tlfi-fr", "wikipedia-fr" + "google", "bing", "amazon-france", "ddg", "cnrtl-tlfi-fr", "wikipedia-fr" ] } }, "fi": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "bookplus-fi", "ddg", "wikipedia-fi" + "google", "bing", "bookplus-fi", "ddg", "wikipedia-fi" ] } }, "fr": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-france", "ddg", "ebay-fr", "cnrtl-tlfi-fr", "qwant", "wikipedia-fr" + "google", "bing", "amazon-france", "ddg", "ebay-fr", "cnrtl-tlfi-fr", "qwant", "wikipedia-fr" ] } }, "fy-NL": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "bolcom-fy-NL", "ddg", "ebay-nl", "marktplaats-fy-NL", "wikipedia-fy-NL" + "google", "bing", "bolcom-fy-NL", "ddg", "ebay-nl", "marktplaats-fy-NL", "wikipedia-fy-NL" ] }, "experimental-hidden": { @@ -353,105 +353,105 @@ "ga-IE": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "ddg", "ebay-ie", "tearma", "twitter", "wikipedia-ga-IE" + "google", "amazon-en-GB", "ddg", "ebay-ie", "tearma", "twitter", "wikipedia-ga-IE" ] } }, "gd": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "bbc-alba", "ddg", "ebay-uk", "faclair-beag", "wikipedia-gd" + "google", "amazon-en-GB", "bbc-alba", "ddg", "ebay-uk", "faclair-beag", "wikipedia-gd" ] } }, "gl": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "ddg", "ebay-es", "wikipedia-gl" + "google", "amazon-en-GB", "ddg", "ebay-es", "wikipedia-gl" ] } }, "gn": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-gn" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-gn" ] } }, "gu-IN": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "gujaratilexicon", "wikipedia-gu" + "google", "bing", "amazon-in", "ddg", "gujaratilexicon", "wikipedia-gu" ] } }, "he": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "wikipedia-he", "morfix-dic" + "google", "ddg", "wikipedia-he", "morfix-dic" ] } }, "hi-IN": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "wikipedia-hi" + "google", "bing", "ddg", "wikipedia-hi" ] } }, "hr": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "bing", "ddg", "eudict", "twitter", "wikipedia-hr" + "google", "amazon-en-GB", "bing", "ddg", "eudict", "twitter", "wikipedia-hr" ] } }, "hsb": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom-de", "ddg", "ebay-de", "leo_ende_de", "wikipedia-hsb" + "google", "bing", "amazondotcom-de", "ddg", "ebay-de", "leo_ende_de", "wikipedia-hsb" ] } }, "hu": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "sztaki-en-hu", "vatera", "wikipedia-hu" + "google", "ddg", "sztaki-en-hu", "vatera", "wikipedia-hu" ] } }, "hy-AM": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "ddg", "list-am", "wikipedia-hy" + "google", "amazondotcom", "ddg", "list-am", "wikipedia-hy" ] } }, "ia": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ia" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ia" ] } }, "id": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "wikipedia-id" + "google", "ddg", "wikipedia-id" ] } }, "is": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "leit-is", "wikipedia-is" + "google", "bing", "amazondotcom", "ddg", "leit-is", "wikipedia-is" ] } }, "it": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-it", "ddg", "ebay-it", "hoepli", "wikipedia-it" + "google", "bing", "amazon-it", "ddg", "ebay-it", "hoepli", "wikipedia-it" ] } }, @@ -459,7 +459,7 @@ "default": { "searchOrder": ["Google", "Yahoo! JAPAN", "Bing", "Amazon.co.jp", "楽天市場", "ヤフオク!", "教えて!goo", "Twitter", "Wikipedia (ja)"], "visibleDefaultEngines": [ - "google-b-d", "yahoo-jp", "bing", "amazon-jp", "rakuten", "yahoo-jp-auctions", "oshiete-goo", "twitter-ja", "wikipedia-ja", "ddg" + "google", "yahoo-jp", "bing", "amazon-jp", "rakuten", "yahoo-jp-auctions", "oshiete-goo", "twitter-ja", "wikipedia-ja", "ddg" ] } }, @@ -467,28 +467,28 @@ "default": { "searchOrder": ["Google", "Yahoo! JAPAN", "Bing", "Amazon.co.jp", "楽天市場", "ヤフオク!", "教えて!goo", "Twitter", "Wikipedia (ja)"], "visibleDefaultEngines": [ - "google-b-d", "yahoo-jp", "bing", "amazon-jp", "rakuten", "yahoo-jp-auctions", "oshiete-goo", "twitter-ja", "wikipedia-ja", "ddg" + "google", "yahoo-jp", "bing", "amazon-jp", "rakuten", "yahoo-jp-auctions", "oshiete-goo", "twitter-ja", "wikipedia-ja", "ddg" ] } }, "ka": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ka" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ka" ] } }, "kab": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "wikipedia-kab" + "google", "bing", "ddg", "wikipedia-kab" ] } }, "kk": { "default": { "visibleDefaultEngines": [ - "yandex-kk", "google-b-d", "ddg", "flip", "kaz-kk", "twitter", "wikipedia-kk" + "yandex-kk", "google", "ddg", "flip", "kaz-kk", "twitter", "wikipedia-kk" ] }, "KZ": { @@ -507,119 +507,119 @@ "km": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-km" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-km" ] } }, "kn": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "kannadastore", "wikipedia-kn" + "google", "bing", "amazon-in", "ddg", "kannadastore", "wikipedia-kn" ] } }, "ko": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "naver-kr", "danawa-kr", "daum-kr", "wikipedia-kr" + "google", "ddg", "naver-kr", "danawa-kr", "daum-kr", "wikipedia-kr" ] } }, "lij": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-it", "ddg", "ebay-it", "paroledigenova-lij", "wikipedia-lij" + "google", "bing", "amazon-it", "ddg", "ebay-it", "paroledigenova-lij", "wikipedia-lij" ] } }, "lo": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "wikipedia-lo", "twitter" + "google", "bing", "ddg", "wikipedia-lo", "twitter" ] } }, "lt": { "default": { "visibleDefaultEngines": [ - "google-b-d", "wikipedia-lt", "bing", "amazondotcom", "ddg", "twitter" + "google", "wikipedia-lt", "bing", "amazondotcom", "ddg", "twitter" ] } }, "ltg": { "default": { "visibleDefaultEngines": [ - "google-b-d", "dict-enlv", "ddg", "salidzinilv", "sslv", "wikipedia-ltg" + "google", "dict-enlv", "ddg", "salidzinilv", "sslv", "wikipedia-ltg" ] } }, "lv": { "default": { "visibleDefaultEngines": [ - "google-b-d", "dict-enlv", "ddg", "salidzinilv", "sslv", "wikipedia-lv" + "google", "dict-enlv", "ddg", "salidzinilv", "sslv", "wikipedia-lv" ] } }, "mai": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "twitter", "wikipedia-hi" + "google", "bing", "amazon-in", "ddg", "twitter", "wikipedia-hi" ] } }, "mk": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-mk" + "google", "bing", "amazondotcom", "ddg", "wikipedia-mk" ] } }, "ml": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "rediff", "webdunia", "wikipedia", "wikipedia-ml" + "google", "bing", "amazon-in", "ddg", "rediff", "webdunia", "wikipedia", "wikipedia-ml" ] } }, "mr": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-in", "ddg", "rediff", "wikipedia-mr" + "google", "amazon-in", "ddg", "rediff", "wikipedia-mr" ] } }, "ms": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ms" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-ms" ] } }, "my": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-my" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-my" ] } }, "nb-NO": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "bing", "ddg", "gulesider-NO", "bok-NO", "qxl-NO", "wikipedia-NO" + "google", "amazon-en-GB", "bing", "ddg", "gulesider-NO", "bok-NO", "qxl-NO", "wikipedia-NO" ] } }, "ne-NP": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "twitter", "wikipedia-ne" + "google", "bing", "ddg", "twitter", "wikipedia-ne" ] } }, "nl": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "bolcom-nl", "ddg", "ebay-nl", "marktplaats-nl", "wikipedia-nl" + "google", "bing", "bolcom-nl", "ddg", "ebay-nl", "marktplaats-nl", "wikipedia-nl" ] }, "experimental-hidden": { @@ -631,42 +631,42 @@ "nn-NO": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-en-GB", "ddg", "gulesider-NO", "bok-NO", "qxl-NO", "wikipedia-NN" + "google", "bing", "amazon-en-GB", "ddg", "gulesider-NO", "bok-NO", "qxl-NO", "wikipedia-NN" ] } }, "oc": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "twitter", "wikipedia-oc", "wiktionary-oc" + "google", "bing", "ddg", "twitter", "wikipedia-oc", "wiktionary-oc" ] } }, "or": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "wikipedia-or" + "google", "bing", "amazon-in", "ddg", "wikipedia-or" ] } }, "pa-IN": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "wikipedia-pa" + "google", "bing", "amazon-in", "ddg", "wikipedia-pa" ] } }, "pl": { "default": { "visibleDefaultEngines": [ - "google-b-d", "allegro-pl", "ddg", "pwn-pl", "wikipedia-pl", "wolnelektury-pl" + "google", "allegro-pl", "ddg", "pwn-pl", "wikipedia-pl", "wolnelektury-pl" ] } }, "pt-BR": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "buscape", "ddg", "mercadolivre", "twitter", "wikipedia-pt" + "google", "bing", "buscape", "ddg", "mercadolivre", "twitter", "wikipedia-pt" ] }, "experimental-hidden": { @@ -678,28 +678,28 @@ "pt-PT": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "ddg", "priberam", "sapo", "wikipedia-pt" + "google", "amazon-en-GB", "ddg", "priberam", "sapo", "wikipedia-pt" ] } }, "rm": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "ebay-ch", "leo_ende_de-rm", "pledarigrond", "wikipedia-rm" + "google", "bing", "ddg", "ebay-ch", "leo_ende_de-rm", "pledarigrond", "wikipedia-rm" ] } }, "ro": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-ro" + "google", "bing", "amazondotcom", "ddg", "wikipedia-ro" ] } }, "ru": { "default": { "visibleDefaultEngines": [ - "yandex-ru", "google-b-d", "ddg", "ozonru", "priceru", "wikipedia-ru", "mailru" + "yandex-ru", "google", "ddg", "ozonru", "priceru", "wikipedia-ru", "mailru" ] }, "RU": { @@ -718,84 +718,84 @@ "si": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "ddg", "wikipedia-si" + "google", "amazondotcom", "ddg", "wikipedia-si" ] } }, "sk": { "default": { "visibleDefaultEngines": [ - "google-b-d", "azet-sk", "atlas-sk", "ddg", "slovnik-sk", "wikipedia-sk", "zoznam-sk" + "google", "azet-sk", "atlas-sk", "ddg", "slovnik-sk", "wikipedia-sk", "zoznam-sk" ] } }, "sl": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ceneji", "ddg", "najdi-si", "odpiralni", "twitter", "wikipedia-sl" + "google", "ceneji", "ddg", "najdi-si", "odpiralni", "twitter", "wikipedia-sl" ] } }, "son": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-france", "ddg", "cnrtl-tlfi-fr", "wikipedia-fr" + "google", "bing", "amazon-france", "ddg", "cnrtl-tlfi-fr", "wikipedia-fr" ] } }, "sq": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-en-GB", "ddg", "wikipedia-sq" + "google", "bing", "amazon-en-GB", "ddg", "wikipedia-sq" ] } }, "sr": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-en-GB", "bing", "ddg", "wikipedia-sr", "pogodak" + "google", "amazon-en-GB", "bing", "ddg", "wikipedia-sr", "pogodak" ] } }, "sv-SE": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "allaannonser-sv-SE", "ddg", "prisjakt-sv-SE", "tyda-sv-SE", "wikipedia-sv-SE" + "google", "bing", "allaannonser-sv-SE", "ddg", "prisjakt-sv-SE", "tyda-sv-SE", "wikipedia-sv-SE" ] } }, "ta": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-in", "ddg", "wikipedia-ta" + "google", "amazon-in", "ddg", "wikipedia-ta" ] } }, "te": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazon-in", "ddg", "wikipedia-te", "wiktionary-te" + "google", "amazon-in", "ddg", "wikipedia-te", "wiktionary-te" ] } }, "th": { "default": { "visibleDefaultEngines": [ - "google-b-d", "amazondotcom", "bing", "ddg", "longdo", "wikipedia-th" + "google", "amazondotcom", "bing", "ddg", "longdo", "wikipedia-th" ] } }, "tl": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-tl" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-tl" ] } }, "tr": { "default": { "visibleDefaultEngines": [ - "yandex-tr", "google-b-d", "ddg", "twitter", "wikipedia-tr" + "yandex-tr", "google", "ddg", "twitter", "wikipedia-tr" ] }, "TR": { @@ -814,56 +814,56 @@ "trs": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "wikipedia-es" + "google", "bing", "amazondotcom", "ddg", "wikipedia-es" ] } }, "uk": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "meta-ua", "ddg", "wikipedia-uk", "hotline-ua" + "google", "bing", "meta-ua", "ddg", "wikipedia-uk", "hotline-ua" ] } }, "ur": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-in", "ddg", "twitter", "wikipedia-ur" + "google", "bing", "amazon-in", "ddg", "twitter", "wikipedia-ur" ] } }, "uz": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-uz" + "google", "bing", "amazondotcom", "ddg", "twitter", "wikipedia-uz" ] } }, "vi": { "default": { "visibleDefaultEngines": [ - "google-b-d", "coccoc", "ddg", "wikipedia-vi" + "google", "coccoc", "ddg", "wikipedia-vi" ] } }, "wo": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "amazon-france", "ddg", "ebay-fr", "twitter", "wikipedia-wo" + "google", "bing", "amazon-france", "ddg", "ebay-fr", "twitter", "wikipedia-wo" ] } }, "xh": { "default": { "visibleDefaultEngines": [ - "google-b-d", "bing", "ddg", "wikipedia" + "google", "bing", "ddg", "wikipedia" ] } }, "zh-CN": { "default": { "visibleDefaultEngines": [ - "baidu", "google-b-d", "bing", "ddg", "wikipedia-zh-CN", "amazondotcn" + "baidu", "google", "bing", "ddg", "wikipedia-zh-CN", "amazondotcn" ] }, "CN": { @@ -873,7 +873,7 @@ "zh-TW": { "default": { "visibleDefaultEngines": [ - "google-b-d", "ddg", "readmoo", "wikipedia-zh-TW" + "google", "ddg", "readmoo", "wikipedia-zh-TW" ] } } diff --git a/browser/components/search/test/browser/browser_google.js b/browser/components/search/test/browser/browser_google.js index 54caecd54f62..449bbb8dfabd 100644 --- a/browser/components/search/test/browser/browser_google.js +++ b/browser/components/search/test/browser/browser_google.js @@ -15,7 +15,7 @@ let expectedEngine = { hidden: false, wrappedJSObject: { queryCharset: "UTF-8", - "_iconURL": "resource://search-plugins/images/google.ico", + "_iconURL": "", _urls: [ { type: "application/x-suggestions+json", @@ -47,12 +47,13 @@ function test() { let region = Services.prefs.getCharPref("browser.search.region"); let code = ""; + let keywordCode = ""; switch (region) { case "US": - code = "firefox-b-1-d"; + code = "firefox-b-1"; break; case "DE": - code = "firefox-b-d"; + code = "firefox-b"; break; case "RU": // Covered by test but doesn't use a code @@ -61,10 +62,17 @@ function test() { if (code) { expectedEngine.searchForm += `client=${code}&`; + keywordCode = `${code}-ab`; let urlParams = expectedEngine.wrappedJSObject._urls[1].params; urlParams.unshift({ name: "client", value: code, + purpose: "searchbar", + }); + urlParams.unshift({ + name: "client", + value: keywordCode, + purpose: "keyword", }); } expectedEngine.searchForm += "q="; @@ -72,7 +80,7 @@ function test() { let url; // Test search URLs (including purposes). - let purposes = ["", "contextmenu", "searchbar", "homepage", "newtab", "keyword"]; + let purposes = ["", "contextmenu", "searchbar", "homepage", "newtab"]; let urlParams; for (let purpose of purposes) { url = engine.getSubmission("foo", null, purpose).uri.spec; @@ -80,6 +88,10 @@ function test() { is(urlParams.get("client"), code, "Check ${purpose} search URL for code"); is(urlParams.get("q"), "foo", `Check ${purpose} search URL for 'foo'`); } + url = engine.getSubmission("foo", null, "keyword").uri.spec; + urlParams = new URLSearchParams(url.split("?")[1]); + is(urlParams.get("client"), keywordCode, "Check keyword search URL for code"); + is(urlParams.get("q"), "foo", `Check keyword search URL for 'foo'`); // Check search suggestion URL. url = engine.getSubmission("foo", "application/x-suggestions+json").uri.spec; diff --git a/browser/components/search/test/browser/browser_google_behavior.js b/browser/components/search/test/browser/browser_google_behavior.js index dae4ba1f59d0..11f3fab3fef5 100644 --- a/browser/components/search/test/browser/browser_google_behavior.js +++ b/browser/components/search/test/browser/browser_google_behavior.js @@ -24,10 +24,10 @@ let region = Services.prefs.getCharPref("browser.search.region"); let code = ""; switch (region) { case "US": - code = "firefox-b-1-d"; + code = "firefox-b-1"; break; case "DE": - code = "firefox-b-d"; + code = "firefox-b"; break; } @@ -36,7 +36,7 @@ if (code) { codes.context = code; codes.newTab = code; codes.submission = code; - codes.keyword = code; + codes.keyword = `${code}-ab`; } function promiseContentSearchReady(browser) { diff --git a/dom/svg/DOMSVGPathSegList.cpp b/dom/svg/DOMSVGPathSegList.cpp index e6ef42aaa9d4..0d9d1b722251 100644 --- a/dom/svg/DOMSVGPathSegList.cpp +++ b/dom/svg/DOMSVGPathSegList.cpp @@ -4,7 +4,6 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include "SVGElement.h" #include "DOMSVGPathSegList.h" #include "DOMSVGPathSeg.h" #include "nsError.h" @@ -12,8 +11,11 @@ #include "nsCOMPtr.h" #include "nsSVGAttrTearoffTable.h" #include "SVGPathSegUtils.h" +#include "mozilla/dom/SVGElement.h" #include "mozilla/dom/SVGPathSegListBinding.h" +using namespace mozilla::dom; + // See the comment in this file's header. namespace mozilla { diff --git a/dom/svg/DOMSVGPointList.cpp b/dom/svg/DOMSVGPointList.cpp index f4fbf969c99b..5fced476efc0 100644 --- a/dom/svg/DOMSVGPointList.cpp +++ b/dom/svg/DOMSVGPointList.cpp @@ -4,7 +4,6 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include "SVGElement.h" #include "DOMSVGPointList.h" #include "DOMSVGPoint.h" #include "nsError.h" @@ -12,9 +11,12 @@ #include "nsCOMPtr.h" #include "nsSVGAttrTearoffTable.h" #include "nsContentUtils.h" +#include "mozilla/dom/SVGElement.h" #include "mozilla/dom/SVGPointListBinding.h" #include +using namespace mozilla::dom; + // See the comment in this file's header. // local helper functions diff --git a/dom/svg/SVGAnimatedNumberList.cpp b/dom/svg/SVGAnimatedNumberList.cpp index 0092b170cb14..8ef63873a53d 100644 --- a/dom/svg/SVGAnimatedNumberList.cpp +++ b/dom/svg/SVGAnimatedNumberList.cpp @@ -7,12 +7,14 @@ #include "SVGAnimatedNumberList.h" #include "DOMSVGAnimatedNumberList.h" +#include "mozilla/dom/SVGElement.h" #include "mozilla/Move.h" -#include "SVGElement.h" #include "nsSVGAttrTearoffTable.h" #include "nsSMILValue.h" #include "SVGNumberListSMILType.h" +using namespace mozilla::dom; + namespace mozilla { nsresult SVGAnimatedNumberList::SetBaseValueString(const nsAString &aValue) { diff --git a/dom/svg/SVGAnimatedPathSegList.cpp b/dom/svg/SVGAnimatedPathSegList.cpp index cc4882f72cb1..189816b2eb31 100644 --- a/dom/svg/SVGAnimatedPathSegList.cpp +++ b/dom/svg/SVGAnimatedPathSegList.cpp @@ -13,6 +13,8 @@ #include "nsSMILValue.h" #include "SVGPathSegListSMILType.h" +using namespace mozilla::dom; + // See the comments in this file's header! namespace mozilla { diff --git a/dom/svg/SVGAnimatedPointList.cpp b/dom/svg/SVGAnimatedPointList.cpp index 8499e8a790ef..720414209eaa 100644 --- a/dom/svg/SVGAnimatedPointList.cpp +++ b/dom/svg/SVGAnimatedPointList.cpp @@ -7,12 +7,14 @@ #include "SVGAnimatedPointList.h" #include "DOMSVGPointList.h" +#include "mozilla/dom/SVGElement.h" #include "mozilla/Move.h" -#include "SVGElement.h" #include "nsSVGAttrTearoffTable.h" #include "nsSMILValue.h" #include "SVGPointListSMILType.h" +using namespace mozilla::dom; + // See the comments in this file's header! namespace mozilla { diff --git a/dom/svg/SVGContentUtils.cpp b/dom/svg/SVGContentUtils.cpp index 55a2e743ca21..7b2fd432761a 100644 --- a/dom/svg/SVGContentUtils.cpp +++ b/dom/svg/SVGContentUtils.cpp @@ -34,10 +34,95 @@ #include "SVGPathData.h" #include "SVGPathElement.h" +using namespace mozilla; using namespace mozilla::dom; using namespace mozilla::dom::SVGPreserveAspectRatio_Binding; using namespace mozilla::gfx; +static bool ParseNumber(RangedPtr& aIter, + const RangedPtr& aEnd, double& aValue) { + int32_t sign; + if (!SVGContentUtils::ParseOptionalSign(aIter, aEnd, sign)) { + return false; + } + + // Absolute value of the integer part of the mantissa. + double intPart = 0.0; + + bool gotDot = *aIter == '.'; + + if (!gotDot) { + if (!mozilla::IsAsciiDigit(*aIter)) { + return false; + } + do { + intPart = 10.0 * intPart + mozilla::AsciiAlphanumericToNumber(*aIter); + ++aIter; + } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); + + if (aIter != aEnd) { + gotDot = *aIter == '.'; + } + } + + // Fractional part of the mantissa. + double fracPart = 0.0; + + if (gotDot) { + ++aIter; + if (aIter == aEnd || !mozilla::IsAsciiDigit(*aIter)) { + return false; + } + + // Power of ten by which we need to divide the fraction + double divisor = 1.0; + + do { + fracPart = 10.0 * fracPart + mozilla::AsciiAlphanumericToNumber(*aIter); + divisor *= 10.0; + ++aIter; + } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); + + fracPart /= divisor; + } + + bool gotE = false; + int32_t exponent = 0; + int32_t expSign; + + if (aIter != aEnd && (*aIter == 'e' || *aIter == 'E')) { + RangedPtr expIter(aIter); + + ++expIter; + if (expIter != aEnd) { + expSign = *expIter == '-' ? -1 : 1; + if (*expIter == '-' || *expIter == '+') { + ++expIter; + } + if (expIter != aEnd && mozilla::IsAsciiDigit(*expIter)) { + // At this point we're sure this is an exponent + // and not the start of a unit such as em or ex. + gotE = true; + } + } + + if (gotE) { + aIter = expIter; + do { + exponent = 10.0 * exponent + mozilla::AsciiAlphanumericToNumber(*aIter); + ++aIter; + } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); + } + } + + // Assemble the number + aValue = sign * (intPart + fracPart); + if (gotE) { + aValue *= pow(10.0, expSign * exponent); + } + return true; +} + namespace mozilla { SVGSVGElement* SVGContentUtils::GetOuterSVGElement(SVGElement* aSVGElement) { @@ -589,90 +674,6 @@ gfx::Matrix SVGContentUtils::GetViewBoxTransform( return gfx::Matrix(a, 0.0f, 0.0f, d, e, f); } -static bool ParseNumber(RangedPtr& aIter, - const RangedPtr& aEnd, double& aValue) { - int32_t sign; - if (!SVGContentUtils::ParseOptionalSign(aIter, aEnd, sign)) { - return false; - } - - // Absolute value of the integer part of the mantissa. - double intPart = 0.0; - - bool gotDot = *aIter == '.'; - - if (!gotDot) { - if (!mozilla::IsAsciiDigit(*aIter)) { - return false; - } - do { - intPart = 10.0 * intPart + mozilla::AsciiAlphanumericToNumber(*aIter); - ++aIter; - } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); - - if (aIter != aEnd) { - gotDot = *aIter == '.'; - } - } - - // Fractional part of the mantissa. - double fracPart = 0.0; - - if (gotDot) { - ++aIter; - if (aIter == aEnd || !mozilla::IsAsciiDigit(*aIter)) { - return false; - } - - // Power of ten by which we need to divide the fraction - double divisor = 1.0; - - do { - fracPart = 10.0 * fracPart + mozilla::AsciiAlphanumericToNumber(*aIter); - divisor *= 10.0; - ++aIter; - } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); - - fracPart /= divisor; - } - - bool gotE = false; - int32_t exponent = 0; - int32_t expSign; - - if (aIter != aEnd && (*aIter == 'e' || *aIter == 'E')) { - RangedPtr expIter(aIter); - - ++expIter; - if (expIter != aEnd) { - expSign = *expIter == '-' ? -1 : 1; - if (*expIter == '-' || *expIter == '+') { - ++expIter; - } - if (expIter != aEnd && mozilla::IsAsciiDigit(*expIter)) { - // At this point we're sure this is an exponent - // and not the start of a unit such as em or ex. - gotE = true; - } - } - - if (gotE) { - aIter = expIter; - do { - exponent = 10.0 * exponent + mozilla::AsciiAlphanumericToNumber(*aIter); - ++aIter; - } while (aIter != aEnd && mozilla::IsAsciiDigit(*aIter)); - } - } - - // Assemble the number - aValue = sign * (intPart + fracPart); - if (gotE) { - aValue *= pow(10.0, expSign * exponent); - } - return true; -} - template bool SVGContentUtils::ParseNumber(RangedPtr& aIter, const RangedPtr& aEnd, diff --git a/dom/svg/SVGDataParser.h b/dom/svg/SVGDataParser.h index 818e7b9093df..a7617e853671 100644 --- a/dom/svg/SVGDataParser.h +++ b/dom/svg/SVGDataParser.h @@ -7,8 +7,9 @@ #ifndef __NS_SVGDATAPARSER_H__ #define __NS_SVGDATAPARSER_H__ +#include #include "mozilla/RangedPtr.h" -#include "nsString.h" +#include "nsStringFwd.h" namespace mozilla { diff --git a/dom/svg/SVGElementFactory.h b/dom/svg/SVGElementFactory.h index 0a41c52072a8..1f3acebc11f8 100644 --- a/dom/svg/SVGElementFactory.h +++ b/dom/svg/SVGElementFactory.h @@ -7,7 +7,13 @@ #ifndef mozilla_dom_SVGElementFactory_h #define mozilla_dom_SVGElementFactory_h +#include "nsError.h" +#include "mozilla/AlreadyAddRefed.h" +#include "mozilla/dom/FromParser.h" +#include "mozilla/dom/NodeInfo.h" + class nsAtom; +class nsIContent; namespace mozilla { namespace dom { diff --git a/dom/svg/SVGLength.cpp b/dom/svg/SVGLength.cpp index a7edd09791b8..a0961a3322e6 100644 --- a/dom/svg/SVGLength.cpp +++ b/dom/svg/SVGLength.cpp @@ -4,19 +4,20 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include "mozilla/ArrayUtils.h" - #include "SVGLength.h" -#include "SVGElement.h" + +#include "mozilla/ArrayUtils.h" +#include "mozilla/dom/SVGElement.h" #include "mozilla/dom/SVGSVGElement.h" #include "nsTextFormatter.h" #include "SVGContentUtils.h" #include #include -namespace mozilla { +using namespace mozilla::dom; +using namespace mozilla::dom::SVGLength_Binding; -using namespace mozilla; +namespace mozilla { // Declare some helpers defined below: static void GetUnitString(nsAString& unit, uint16_t unitType); diff --git a/dom/svg/SVGMarkerElement.cpp b/dom/svg/SVGMarkerElement.cpp index 81f57ace86b3..6e5175c61c6b 100644 --- a/dom/svg/SVGMarkerElement.cpp +++ b/dom/svg/SVGMarkerElement.cpp @@ -11,6 +11,7 @@ #include "SVGAnimatedPreserveAspectRatio.h" #include "nsError.h" #include "mozilla/dom/SVGAngle.h" +#include "mozilla/dom/SVGGeometryElement.h" #include "mozilla/dom/SVGLengthBinding.h" #include "mozilla/dom/SVGMarkerElement.h" #include "mozilla/dom/SVGMarkerElementBinding.h" diff --git a/dom/svg/SVGPathSegListSMILType.cpp b/dom/svg/SVGPathSegListSMILType.cpp index 193dcc3944e2..0d40f15e9d11 100644 --- a/dom/svg/SVGPathSegListSMILType.cpp +++ b/dom/svg/SVGPathSegListSMILType.cpp @@ -11,6 +11,8 @@ #include "SVGPathSegUtils.h" #include "SVGPathData.h" +using namespace mozilla::dom::SVGPathSeg_Binding; + // Indices of boolean flags within 'arc' segment chunks in path-data arrays // (where '0' would correspond to the index of the encoded segment type): #define LARGE_ARC_FLAG_IDX 4 diff --git a/dom/svg/SVGPathSegUtils.cpp b/dom/svg/SVGPathSegUtils.cpp index 3d786771b9e3..a15ff8db6f0c 100644 --- a/dom/svg/SVGPathSegUtils.cpp +++ b/dom/svg/SVGPathSegUtils.cpp @@ -13,6 +13,7 @@ #include "nsTextFormatter.h" using namespace mozilla; +using namespace mozilla::dom::SVGPathSeg_Binding; using namespace mozilla::gfx; static const float PATH_SEG_LENGTH_TOLERANCE = 0.0000001f; diff --git a/dom/svg/SVGSVGElement.cpp b/dom/svg/SVGSVGElement.cpp index ec7666259523..7cb647bc67b1 100644 --- a/dom/svg/SVGSVGElement.cpp +++ b/dom/svg/SVGSVGElement.cpp @@ -8,6 +8,7 @@ #include "mozilla/dom/SVGSVGElement.h" #include "mozilla/dom/SVGSVGElementBinding.h" #include "mozilla/dom/SVGMatrix.h" +#include "mozilla/dom/SVGRect.h" #include "mozilla/dom/SVGViewElement.h" #include "mozilla/EventDispatcher.h" diff --git a/dom/svg/SVGStringList.cpp b/dom/svg/SVGStringList.cpp index 6d3d037c314a..15a2ab826c14 100644 --- a/dom/svg/SVGStringList.cpp +++ b/dom/svg/SVGStringList.cpp @@ -7,6 +7,7 @@ #include "SVGStringList.h" #include "nsError.h" #include "nsCharSeparatedTokenizer.h" +#include "nsContentUtils.h" #include "nsString.h" #include "nsWhitespaceTokenizer.h" #include "SVGContentUtils.h" diff --git a/dom/svg/SVGTests.cpp b/dom/svg/SVGTests.cpp index b213aca9df5c..bfdd79754fc4 100644 --- a/dom/svg/SVGTests.cpp +++ b/dom/svg/SVGTests.cpp @@ -6,6 +6,8 @@ #include "mozilla/dom/SVGTests.h" #include "DOMSVGStringList.h" +#include "nsIContent.h" +#include "nsIContentInlines.h" #include "nsSVGFeatures.h" #include "mozilla/dom/SVGSwitchElement.h" #include "nsCharSeparatedTokenizer.h" diff --git a/gfx/webrender_bindings/revision.txt b/gfx/webrender_bindings/revision.txt index f71364c4eaeb..b25d5b3e28ea 100644 --- a/gfx/webrender_bindings/revision.txt +++ b/gfx/webrender_bindings/revision.txt @@ -1 +1 @@ -6bdd0d26afe3fc5a24f10c19d4ca8569d0182a37 +8476ed5e134e54f2facb01ea45e8a2008c8ba8da diff --git a/gfx/wr/Cargo.lock b/gfx/wr/Cargo.lock index 905b404fb43b..35794460e9aa 100644 --- a/gfx/wr/Cargo.lock +++ b/gfx/wr/Cargo.lock @@ -1547,6 +1547,7 @@ dependencies = [ "gleam 0.6.8 (registry+https://github.com/rust-lang/crates.io-index)", "image 0.20.1 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.42 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)", "mozangle 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", "num-traits 0.2.4 (registry+https://github.com/rust-lang/crates.io-index)", diff --git a/gfx/wr/webrender/Cargo.toml b/gfx/wr/webrender/Cargo.toml index d386b90be071..7dae53dcc89d 100644 --- a/gfx/wr/webrender/Cargo.toml +++ b/gfx/wr/webrender/Cargo.toml @@ -72,6 +72,7 @@ rand = "0.4" [target.'cfg(any(target_os = "android", all(unix, not(target_os = "macos"))))'.dependencies] freetype = { version = "0.4", default-features = false } +libc = "0.2" [target.'cfg(target_os = "windows")'.dependencies] dwrote = "0.6.3" diff --git a/gfx/wr/webrender/src/clip.rs b/gfx/wr/webrender/src/clip.rs index 461d5d0e4669..ae68d7938112 100644 --- a/gfx/wr/webrender/src/clip.rs +++ b/gfx/wr/webrender/src/clip.rs @@ -18,7 +18,7 @@ use image::{self, Repetition}; use intern; use internal_types::FastHashSet; use prim_store::{ClipData, ImageMaskData, SpaceMapper, VisibleMaskImageTile}; -use prim_store::{PointKey, SizeKey, RectangleKey}; +use prim_store::{PointKey, PrimitiveInstance, SizeKey, RectangleKey}; use render_task::to_cache_size; use resource_cache::{ImageRequest, ResourceCache}; use std::{cmp, u32}; @@ -198,7 +198,7 @@ impl ClipChainId { // A clip chain node is an id for a range of clip sources, // and a link to a parent clip chain node, or ClipChainId::NONE. -#[derive(Clone)] +#[derive(Clone, Debug)] pub struct ClipChainNode { pub handle: ClipDataHandle, pub local_pos: LayoutPoint, @@ -516,7 +516,7 @@ impl ClipStore { // information, and a clip chain id, build an optimized clip chain instance. pub fn build_clip_chain_instance( &mut self, - clip_chain_id: ClipChainId, + prim_instance: &PrimitiveInstance, local_prim_rect: LayoutRect, local_prim_clip_rect: LayoutRect, spatial_node_index: SpatialNodeIndex, @@ -536,7 +536,7 @@ impl ClipStore { // smallest possible local/device clip area. self.clip_node_info.clear(); - let mut current_clip_chain_id = clip_chain_id; + let mut current_clip_chain_id = prim_instance.clip_chain_id; // for each clip chain node while current_clip_chain_id != ClipChainId::NONE { @@ -551,10 +551,12 @@ impl ClipStore { collector.insert(current_clip_chain_id); } None => { + if prim_instance.is_chased() { + println!("\t\tclip node (from chain) {:?} at {:?}", + clip_chain_node.spatial_node_index, clip_chain_node.local_pos); + } if !add_clip_node_to_current_chain( - clip_chain_node.handle, - clip_chain_node.spatial_node_index, - clip_chain_node.local_pos, + clip_chain_node, spatial_node_index, &mut local_clip_rect, &mut self.clip_node_info, @@ -573,15 +575,14 @@ impl ClipStore { // handled as part of this rasterization root. if let Some(clip_node_collector) = clip_node_collector { for clip_chain_id in &clip_node_collector.clips { - let (handle, clip_spatial_node_index, local_pos) = { - let clip_chain_node = &self.clip_chain_nodes[clip_chain_id.0 as usize]; - (clip_chain_node.handle, clip_chain_node.spatial_node_index, clip_chain_node.local_pos) - }; + let clip_chain_node = &self.clip_chain_nodes[clip_chain_id.0 as usize]; + if prim_instance.is_chased() { + println!("\t\tclip node (from collector) {:?} at {:?}", + clip_chain_node.spatial_node_index, clip_chain_node.local_pos); + } if !add_clip_node_to_current_chain( - handle, - clip_spatial_node_index, - local_pos, + clip_chain_node, spatial_node_index, &mut local_clip_rect, &mut self.clip_node_info, @@ -655,6 +656,10 @@ impl ClipStore { resource_cache, ); + if prim_instance.is_chased() { + println!("\t\tpartial {:?}", node.item); + } + // As a special case, a partial accept of a clip rect that is // in the same coordinate system as the primitive doesn't need // a clip mask. Instead, it can be handled by the primitive @@ -1362,77 +1367,73 @@ impl ClipNodeCollector { // for the current clip chain. Returns false if the clip // results in the entire primitive being culled out. fn add_clip_node_to_current_chain( - handle: ClipDataHandle, - clip_spatial_node_index: SpatialNodeIndex, - local_pos: LayoutPoint, + node: &ClipChainNode, spatial_node_index: SpatialNodeIndex, local_clip_rect: &mut LayoutRect, clip_node_info: &mut Vec, clip_data_store: &ClipDataStore, clip_scroll_tree: &ClipScrollTree, ) -> bool { - let clip_node = &clip_data_store[handle]; - let clip_spatial_node = &clip_scroll_tree.spatial_nodes[clip_spatial_node_index.0]; + let clip_node = &clip_data_store[node.handle]; + let clip_spatial_node = &clip_scroll_tree.spatial_nodes[node.spatial_node_index.0]; let ref_spatial_node = &clip_scroll_tree.spatial_nodes[spatial_node_index.0]; // Determine the most efficient way to convert between coordinate // systems of the primitive and clip node. - let conversion = if spatial_node_index == clip_spatial_node_index { - Some(ClipSpaceConversion::Local) + let conversion = if spatial_node_index == node.spatial_node_index { + ClipSpaceConversion::Local } else if ref_spatial_node.coordinate_system_id == clip_spatial_node.coordinate_system_id { let scale_offset = ref_spatial_node.coordinate_system_relative_scale_offset .inverse() .accumulate(&clip_spatial_node.coordinate_system_relative_scale_offset); - Some(ClipSpaceConversion::ScaleOffset(scale_offset)) + ClipSpaceConversion::ScaleOffset(scale_offset) } else { - let xf = clip_scroll_tree.get_relative_transform( - clip_spatial_node_index, + match clip_scroll_tree.get_relative_transform( + node.spatial_node_index, ROOT_SPATIAL_NODE_INDEX, - ); - - xf.map(|xf| { - ClipSpaceConversion::Transform(xf.with_destination::()) - }) + ) { + None => return true, + Some(xf) => ClipSpaceConversion::Transform(xf.with_destination::()), + } }; // If we can convert spaces, try to reduce the size of the region // requested, and cache the conversion information for the next step. - if let Some(conversion) = conversion { - if let Some(clip_rect) = clip_node.item.get_local_clip_rect(local_pos) { - match conversion { - ClipSpaceConversion::Local => { - *local_clip_rect = match local_clip_rect.intersection(&clip_rect) { - Some(rect) => rect, - None => return false, - }; - } - ClipSpaceConversion::ScaleOffset(ref scale_offset) => { - let clip_rect = scale_offset.map_rect(&clip_rect); - *local_clip_rect = match local_clip_rect.intersection(&clip_rect) { - Some(rect) => rect, - None => return false, - }; - } - ClipSpaceConversion::Transform(..) => { - // TODO(gw): In the future, we can reduce the size - // of the pic_clip_rect here. To do this, - // we can use project_rect or the - // inverse_rect_footprint method, depending - // on the relationship of the clip, pic - // and primitive spatial nodes. - // I have left this for now until we - // find some good test cases where this - // would be a worthwhile perf win. - } + if let Some(clip_rect) = clip_node.item.get_local_clip_rect(node.local_pos) { + match conversion { + ClipSpaceConversion::Local => { + *local_clip_rect = match local_clip_rect.intersection(&clip_rect) { + Some(rect) => rect, + None => return false, + }; + } + ClipSpaceConversion::ScaleOffset(ref scale_offset) => { + let clip_rect = scale_offset.map_rect(&clip_rect); + *local_clip_rect = match local_clip_rect.intersection(&clip_rect) { + Some(rect) => rect, + None => return false, + }; + } + ClipSpaceConversion::Transform(..) => { + // TODO(gw): In the future, we can reduce the size + // of the pic_clip_rect here. To do this, + // we can use project_rect or the + // inverse_rect_footprint method, depending + // on the relationship of the clip, pic + // and primitive spatial nodes. + // I have left this for now until we + // find some good test cases where this + // would be a worthwhile perf win. } } - clip_node_info.push(ClipNodeInfo { - conversion, - local_pos, - handle, - spatial_node_index: clip_spatial_node_index, - }) } + clip_node_info.push(ClipNodeInfo { + conversion, + local_pos: node.local_pos, + handle: node.handle, + spatial_node_index: node.spatial_node_index, + }); + true } diff --git a/gfx/wr/webrender/src/lib.rs b/gfx/wr/webrender/src/lib.rs index f4c0cce0fb7c..d5a6c2cc61c8 100644 --- a/gfx/wr/webrender/src/lib.rs +++ b/gfx/wr/webrender/src/lib.rs @@ -153,6 +153,8 @@ extern crate core_text; #[cfg(all(unix, not(target_os = "macos")))] extern crate freetype; +#[cfg(all(unix, not(target_os = "macos")))] +extern crate libc; #[cfg(target_os = "windows")] extern crate dwrote; diff --git a/gfx/wr/webrender/src/platform/macos/font.rs b/gfx/wr/webrender/src/platform/macos/font.rs index 0543efba8ea4..770c94c851d5 100644 --- a/gfx/wr/webrender/src/platform/macos/font.rs +++ b/gfx/wr/webrender/src/platform/macos/font.rs @@ -339,10 +339,7 @@ impl FontContext { match self.ct_fonts.entry((font_key, size, variations.to_vec())) { Entry::Occupied(entry) => Some((*entry.get()).clone()), Entry::Vacant(entry) => { - let cg_font = match self.cg_fonts.get(&font_key) { - None => return None, - Some(cg_font) => cg_font, - }; + let cg_font = self.cg_fonts.get(&font_key)?; let ct_font = new_ct_font_with_variations(cg_font, size.to_f64_px(), variations); entry.insert(ct_font.clone()); Some(ct_font) diff --git a/gfx/wr/webrender/src/platform/unix/font.rs b/gfx/wr/webrender/src/platform/unix/font.rs index 6d1e98c60842..bec591256f8c 100644 --- a/gfx/wr/webrender/src/platform/unix/font.rs +++ b/gfx/wr/webrender/src/platform/unix/font.rs @@ -4,7 +4,7 @@ use api::{ColorU, GlyphDimensions, FontKey, FontRenderMode}; use api::{FontInstancePlatformOptions, FontLCDFilter, FontHinting}; -use api::{FontInstanceFlags, NativeFontHandle}; +use api::{FontInstanceFlags, FontVariation, NativeFontHandle}; use freetype::freetype::{FT_BBox, FT_Outline_Translate, FT_Pixel_Mode, FT_Render_Mode}; use freetype::freetype::{FT_Done_Face, FT_Error, FT_Get_Char_Index, FT_Int32}; use freetype::freetype::{FT_Done_FreeType, FT_Library_SetLcdFilter, FT_Pos}; @@ -12,20 +12,26 @@ use freetype::freetype::{FT_F26Dot6, FT_Face, FT_Glyph_Format, FT_Long, FT_UInt} use freetype::freetype::{FT_GlyphSlot, FT_LcdFilter, FT_New_Face, FT_New_Memory_Face}; use freetype::freetype::{FT_Init_FreeType, FT_Load_Glyph, FT_Render_Glyph}; use freetype::freetype::{FT_Library, FT_Outline_Get_CBox, FT_Set_Char_Size, FT_Select_Size}; -use freetype::freetype::{FT_Fixed, FT_Matrix, FT_Set_Transform}; +use freetype::freetype::{FT_Fixed, FT_Matrix, FT_Set_Transform, FT_String, FT_ULong}; +use freetype::freetype::{FT_Err_Unimplemented_Feature}; use freetype::freetype::{FT_LOAD_COLOR, FT_LOAD_DEFAULT, FT_LOAD_FORCE_AUTOHINT}; use freetype::freetype::{FT_LOAD_IGNORE_GLOBAL_ADVANCE_WIDTH, FT_LOAD_NO_AUTOHINT}; use freetype::freetype::{FT_LOAD_NO_BITMAP, FT_LOAD_NO_HINTING, FT_LOAD_VERTICAL_LAYOUT}; use freetype::freetype::{FT_FACE_FLAG_SCALABLE, FT_FACE_FLAG_FIXED_SIZES}; +use freetype::freetype::{FT_FACE_FLAG_MULTIPLE_MASTERS}; use freetype::succeeded; use glyph_rasterizer::{FontInstance, GlyphFormat, GlyphKey, GlyphRasterResult, RasterizedGlyph}; #[cfg(feature = "pathfinder")] use glyph_rasterizer::NativeFontHandleWrapper; use internal_types::{FastHashMap, ResourceCacheError}; +#[cfg(not(target_os = "android"))] +use libc::{dlsym, RTLD_DEFAULT}; +use libc::free; #[cfg(feature = "pathfinder")] use pathfinder_font_renderer::freetype as pf_freetype; use std::{cmp, mem, ptr, slice}; use std::cmp::max; +use std::collections::hash_map::Entry; use std::ffi::CString; use std::sync::Arc; @@ -38,16 +44,141 @@ const FT_LOAD_TARGET_MONO: FT_UInt = 2 << 16; const FT_LOAD_TARGET_LCD: FT_UInt = 3 << 16; const FT_LOAD_TARGET_LCD_V: FT_UInt = 4 << 16; -struct Face { - face: FT_Face, +#[repr(C)] +struct FT_Var_Axis { + pub name: *mut FT_String, + pub minimum: FT_Fixed, + pub def: FT_Fixed, + pub maximum: FT_Fixed, + pub tag: FT_ULong, + pub strid: FT_UInt, +} + +#[repr(C)] +struct FT_Var_Named_Style { + pub coords: *mut FT_Fixed, + pub strid: FT_UInt, + pub psid: FT_UInt, +} + +#[repr(C)] +struct FT_MM_Var { + pub num_axis: FT_UInt, + pub num_designs: FT_UInt, + pub num_namedstyles: FT_UInt, + pub axis: *mut FT_Var_Axis, + pub namedstyle: *mut FT_Var_Named_Style, +} + +#[inline] +pub fn unimplemented(error: FT_Error) -> bool { + error == FT_Err_Unimplemented_Feature as FT_Error +} + +// Use dlsym to check for symbols. If not available. just return an unimplemented error. +#[cfg(not(target_os = "android"))] +macro_rules! ft_dyn_fn { + ($func_name:ident($($arg_name:ident:$arg_type:ty),*) -> FT_Error) => { + #[allow(non_snake_case)] + unsafe fn $func_name($($arg_name:$arg_type),*) -> FT_Error { + extern "C" fn unimpl_func($(_:$arg_type),*) -> FT_Error { + FT_Err_Unimplemented_Feature as FT_Error + } + lazy_static! { + static ref func: unsafe extern "C" fn($($arg_type),*) -> FT_Error = { + unsafe { + let cname = CString::new(stringify!($func_name)).unwrap(); + let ptr = dlsym(RTLD_DEFAULT, cname.as_ptr()); + if !ptr.is_null() { mem::transmute(ptr) } else { unimpl_func } + } + }; + } + (*func)($($arg_name),*) + } + } +} + +// On Android, just statically link in the symbols... +#[cfg(target_os = "android")] +macro_rules! ft_dyn_fn { + ($($proto:tt)+) => { extern "C" { fn $($proto)+; } } +} + +ft_dyn_fn!(FT_Get_MM_Var(face: FT_Face, desc: *mut *mut FT_MM_Var) -> FT_Error); +ft_dyn_fn!(FT_Done_MM_Var(library: FT_Library, desc: *mut FT_MM_Var) -> FT_Error); +ft_dyn_fn!(FT_Set_Var_Design_Coordinates(face: FT_Face, num_vals: FT_UInt, vals: *mut FT_Fixed) -> FT_Error); + +extern "C" { + fn FT_GlyphSlot_Embolden(slot: FT_GlyphSlot); +} + +enum FontFile { + Pathname(CString), + Data(Arc>), +} + +struct FontFace { // Raw byte data has to live until the font is deleted, according to // https://www.freetype.org/freetype2/docs/reference/ft2-base_interface.html#FT_New_Memory_Face - _bytes: Option>>, + file: FontFile, + index: u32, + face: FT_Face, + mm_var: *mut FT_MM_Var, +} + +impl Drop for FontFace { + fn drop(&mut self) { + unsafe { + if !self.mm_var.is_null() && + unimplemented(FT_Done_MM_Var((*(*self.face).glyph).library, self.mm_var)) { + free(self.mm_var as _); + } + + FT_Done_Face(self.face); + } + } +} + +struct VariationFace(FT_Face); + +impl Drop for VariationFace { + fn drop(&mut self) { + unsafe { FT_Done_Face(self.0) }; + } +} + +fn new_ft_face(font_key: &FontKey, lib: FT_Library, file: &FontFile, index: u32) -> Option { + unsafe { + let mut face: FT_Face = ptr::null_mut(); + let result = match file { + FontFile::Pathname(ref cstr) => FT_New_Face( + lib, + cstr.as_ptr(), + index as FT_Long, + &mut face, + ), + FontFile::Data(ref bytes) => FT_New_Memory_Face( + lib, + bytes.as_ptr(), + bytes.len() as FT_Long, + index as FT_Long, + &mut face, + ), + }; + if succeeded(result) && !face.is_null() { + Some(face) + } else { + warn!("WARN: webrender failed to load font"); + debug!("font={:?}, result={:?}", font_key, result); + None + } + } } pub struct FontContext { lib: FT_Library, - faces: FastHashMap, + faces: FastHashMap, + variations: FastHashMap<(FontKey, Vec), VariationFace>, lcd_extra_pixels: i64, } @@ -56,10 +187,6 @@ pub struct FontContext { // a given FontContext so it is safe to move the latter between threads. unsafe impl Send for FontContext {} -extern "C" { - fn FT_GlyphSlot_Embolden(slot: FT_GlyphSlot); -} - fn get_skew_bounds(bottom: i32, top: i32, skew_factor: f32) -> (f32, f32) { let skew_min = ((bottom as f32 + 0.5) * skew_factor).floor(); let skew_max = ((top as f32 - 0.5) * skew_factor).ceil(); @@ -165,6 +292,7 @@ impl FontContext { Ok(FontContext { lib, faces: FastHashMap::default(), + variations: FastHashMap::default(), lcd_extra_pixels, }) } else { @@ -181,72 +309,78 @@ impl FontContext { pub fn add_raw_font(&mut self, font_key: &FontKey, bytes: Arc>, index: u32) { if !self.faces.contains_key(&font_key) { - let mut face: FT_Face = ptr::null_mut(); - let result = unsafe { - FT_New_Memory_Face( - self.lib, - bytes.as_ptr(), - bytes.len() as FT_Long, - index as FT_Long, - &mut face, - ) - }; - if succeeded(result) && !face.is_null() { - self.faces.insert( - *font_key, - Face { - face, - _bytes: Some(bytes), - }, - ); - } else { - warn!("WARN: webrender failed to load font"); - debug!("font={:?}", font_key); + let file = FontFile::Data(bytes); + if let Some(face) = new_ft_face(font_key, self.lib, &file, index) { + self.faces.insert(*font_key, FontFace { file, index, face, mm_var: ptr::null_mut() }); } } } pub fn add_native_font(&mut self, font_key: &FontKey, native_font_handle: NativeFontHandle) { if !self.faces.contains_key(&font_key) { - let mut face: FT_Face = ptr::null_mut(); - let pathname = CString::new(native_font_handle.pathname).unwrap(); - let result = unsafe { - FT_New_Face( - self.lib, - pathname.as_ptr(), - native_font_handle.index as FT_Long, - &mut face, - ) - }; - if succeeded(result) && !face.is_null() { - self.faces.insert( - *font_key, - Face { - face, - _bytes: None, - }, - ); - } else { - warn!("WARN: webrender failed to load font"); - debug!("font={:?}, path={:?}", font_key, pathname); + let file = FontFile::Pathname(CString::new(native_font_handle.pathname).unwrap()); + let index = native_font_handle.index; + if let Some(face) = new_ft_face(font_key, self.lib, &file, index) { + self.faces.insert(*font_key, FontFace { file, index, face, mm_var: ptr::null_mut() }); } } } pub fn delete_font(&mut self, font_key: &FontKey) { - if let Some(face) = self.faces.remove(font_key) { - let result = unsafe { FT_Done_Face(face.face) }; - assert!(succeeded(result)); + if let Some(_) = self.faces.remove(font_key) { + self.variations.retain(|k, _| k.0 != *font_key); } } - pub fn delete_font_instance(&mut self, _instance: &FontInstance) { - // This backend does not yet support variations, so there is nothing to do here. + pub fn delete_font_instance(&mut self, instance: &FontInstance) { + // Ensure we don't keep around excessive amounts of stale variations. + if !instance.variations.is_empty() { + self.variations.remove(&(instance.font_key, instance.variations.clone())); + } } - fn load_glyph(&self, font: &FontInstance, glyph: &GlyphKey) -> Option<(FT_GlyphSlot, f32)> { - debug_assert!(self.faces.contains_key(&font.font_key)); - let face = self.faces.get(&font.font_key).unwrap(); + fn get_ft_face(&mut self, font: &FontInstance) -> Option { + if font.variations.is_empty() { + return Some(self.faces.get(&font.font_key)?.face); + } + match self.variations.entry((font.font_key, font.variations.clone())) { + Entry::Occupied(entry) => Some(entry.get().0), + Entry::Vacant(entry) => unsafe { + let normal_face = self.faces.get_mut(&font.font_key)?; + if ((*normal_face.face).face_flags & (FT_FACE_FLAG_MULTIPLE_MASTERS as FT_Long)) == 0 { + return Some(normal_face.face); + } + // Clone a new FT face and attempt to set the variation values on it. + // Leave unspecified values at the defaults. + let var_face = new_ft_face(&font.font_key, self.lib, &normal_face.file, normal_face.index)?; + if !normal_face.mm_var.is_null() || + succeeded(FT_Get_MM_Var(normal_face.face, &mut normal_face.mm_var)) { + let mm_var = normal_face.mm_var; + let num_axis = (*mm_var).num_axis; + let mut coords: Vec = Vec::with_capacity(num_axis as usize); + for i in 0 .. num_axis { + let axis = (*mm_var).axis.offset(i as isize); + let mut value = (*axis).def; + for var in &font.variations { + if var.tag as FT_ULong == (*axis).tag { + value = (var.value * 65536.0 + 0.5) as FT_Fixed; + value = cmp::min(value, (*axis).maximum); + value = cmp::max(value, (*axis).minimum); + break; + } + } + coords.push(value); + } + FT_Set_Var_Design_Coordinates(var_face, num_axis, coords.as_mut_ptr()); + } + entry.insert(VariationFace(var_face)); + Some(var_face) + } + } + } + + fn load_glyph(&mut self, font: &FontInstance, glyph: &GlyphKey) -> Option<(FT_GlyphSlot, f32)> { + let face = self.get_ft_face(font)?; let mut load_flags = FT_LOAD_DEFAULT; let FontInstancePlatformOptions { mut hinting, .. } = font.platform_options.unwrap_or_default(); @@ -293,12 +427,12 @@ impl FontContext { let (x_scale, y_scale) = font.transform.compute_scale().unwrap_or((1.0, 1.0)); let scale = font.oversized_scale_factor(x_scale, y_scale); let req_size = font.size.to_f64_px(); - let face_flags = unsafe { (*face.face).face_flags }; + let face_flags = unsafe { (*face).face_flags }; let mut result = if (face_flags & (FT_FACE_FLAG_FIXED_SIZES as FT_Long)) != 0 && (face_flags & (FT_FACE_FLAG_SCALABLE as FT_Long)) == 0 && (load_flags & FT_LOAD_NO_BITMAP) == 0 { - unsafe { FT_Set_Transform(face.face, ptr::null_mut(), ptr::null_mut()) }; - self.choose_bitmap_size(face.face, req_size * y_scale / scale) + unsafe { FT_Set_Transform(face, ptr::null_mut(), ptr::null_mut()) }; + self.choose_bitmap_size(face, req_size * y_scale / scale) } else { let mut shape = font.transform.invert_scale(x_scale, y_scale); if font.flags.contains(FontInstanceFlags::FLIP_X) { @@ -320,9 +454,9 @@ impl FontContext { yy: (shape.scale_y * 65536.0) as FT_Fixed, }; unsafe { - FT_Set_Transform(face.face, &mut ft_shape, ptr::null_mut()); + FT_Set_Transform(face, &mut ft_shape, ptr::null_mut()); FT_Set_Char_Size( - face.face, + face, (req_size * x_scale / scale * 64.0 + 0.5) as FT_F26Dot6, (req_size * y_scale / scale * 64.0 + 0.5) as FT_F26Dot6, 0, @@ -332,11 +466,11 @@ impl FontContext { }; if succeeded(result) { - result = unsafe { FT_Load_Glyph(face.face, glyph.index() as FT_UInt, load_flags as FT_Int32) }; + result = unsafe { FT_Load_Glyph(face, glyph.index() as FT_UInt, load_flags as FT_Int32) }; }; if succeeded(result) { - let slot = unsafe { (*face.face).glyph }; + let slot = unsafe { (*face).glyph }; assert!(slot != ptr::null_mut()); if font.flags.contains(FontInstanceFlags::SYNTHETIC_BOLD) { @@ -504,9 +638,9 @@ impl FontContext { } pub fn get_glyph_index(&mut self, font_key: FontKey, ch: char) -> Option { - let face = self.faces.get(&font_key).expect("Unknown font key!"); + let face = self.faces.get(&font_key)?.face; unsafe { - let idx = FT_Get_Char_Index(face.face, ch as _); + let idx = FT_Get_Char_Index(face, ch as _); if idx != 0 { Some(idx) } else { @@ -823,6 +957,8 @@ impl FontContext { impl Drop for FontContext { fn drop(&mut self) { + self.variations.clear(); + self.faces.clear(); unsafe { FT_Done_FreeType(self.lib); } diff --git a/gfx/wr/webrender/src/prim_store/mod.rs b/gfx/wr/webrender/src/prim_store/mod.rs index 33436475407e..1ede345c99b2 100644 --- a/gfx/wr/webrender/src/prim_store/mod.rs +++ b/gfx/wr/webrender/src/prim_store/mod.rs @@ -2036,7 +2036,7 @@ impl PrimitiveStore { let clip_chain = frame_state .clip_store .build_clip_chain_instance( - prim_instance.clip_chain_id, + prim_instance, local_rect, prim_local_clip_rect, prim_context.spatial_node_index, @@ -3117,7 +3117,7 @@ impl PrimitiveInstance { let segment_clip_chain = frame_state .clip_store .build_clip_chain_instance( - self.clip_chain_id, + self, segment.local_rect.translate(&LayoutVector2D::new(prim_origin.x, prim_origin.y)), prim_local_clip_rect, prim_context.spatial_node_index, diff --git a/js/public/Id.h b/js/public/Id.h index 575f08d300db..34c700e33387 100644 --- a/js/public/Id.h +++ b/js/public/Id.h @@ -53,6 +53,9 @@ struct PropertyKey { bool operator==(const PropertyKey& rhs) const { return asBits == rhs.asBits; } bool operator!=(const PropertyKey& rhs) const { return asBits != rhs.asBits; } + + MOZ_ALWAYS_INLINE bool isInt() const { return !!(asBits & JSID_TYPE_INT_BIT); } + } JS_HAZ_GC_POINTER; } // namespace JS @@ -91,6 +94,7 @@ static MOZ_ALWAYS_INLINE bool JSID_IS_INT(jsid id) { static MOZ_ALWAYS_INLINE int32_t JSID_TO_INT(jsid id) { MOZ_ASSERT(JSID_IS_INT(id)); + MOZ_ASSERT(id.isInt()); uint32_t bits = static_cast(JSID_BITS(id)) >> 1; return static_cast(bits); } diff --git a/layout/base/AccessibleCaretManager.cpp b/layout/base/AccessibleCaretManager.cpp index 782062f5b4cb..cdbf755ed5fc 100644 --- a/layout/base/AccessibleCaretManager.cpp +++ b/layout/base/AccessibleCaretManager.cpp @@ -502,9 +502,7 @@ nsresult AccessibleCaretManager::SelectWordOrShortcut(const nsPoint& aPoint) { #ifdef MOZ_WIDGET_ANDROID // On Android, we need IgnoreRootScrollFrame for correct hit testing when // zoomed in or out. - // - // FIXME(emilio): But do we really want to override the other two flags? - options = nsLayoutUtils::FrameForPointOption::IgnoreRootScrollFrame; + options += nsLayoutUtils::FrameForPointOption::IgnoreRootScrollFrame; #endif AutoWeakFrame ptFrame = diff --git a/toolkit/components/search/nsSearchService.js b/toolkit/components/search/nsSearchService.js index f4692e240d42..27ee63acb94d 100644 --- a/toolkit/components/search/nsSearchService.js +++ b/toolkit/components/search/nsSearchService.js @@ -581,34 +581,6 @@ function fetchRegion(ss) { }); } -// This converts our legacy google engines to the -// new codes. We have to manually change them here -// because we can't change the default name in absearch. -function convertGoogleEngines(engineNames) { - let overrides = { - "google": "google-b-d", - "google-2018": "google-b-1-d", - }; - - let esrOverrides = { - "google": "google-b-e", - "google-2018": "google-b-1-e", - "google-b-d": "google-b-e", - "google-b-1-d": "google-b-1-e", - }; - - if (AppConstants.MOZ_APP_VERSION_DISPLAY.endsWith("esr")) { - overrides = esrOverrides; - } - for (let engine in overrides) { - let index = engineNames.indexOf(engine); - if (index > -1) { - engineNames[index] = overrides[engine]; - } - } - return engineNames; -} - // This will make an HTTP request to a Mozilla server that will return // JSON data telling us what engine should be set as the default for // the current region, and how soon we should check again. @@ -3596,8 +3568,6 @@ SearchService.prototype = { } } - engineNames = convertGoogleEngines(engineNames); - for (let name of engineNames) { uris.push(APP_SEARCH_PREFIX + name + ".xml"); } diff --git a/toolkit/mozapps/update/content/updates.js b/toolkit/mozapps/update/content/updates.js index f2591fd67e91..321a42475ee5 100644 --- a/toolkit/mozapps/update/content/updates.js +++ b/toolkit/mozapps/update/content/updates.js @@ -820,7 +820,7 @@ var gDownloadingPage = { this._pauseButton.setAttribute("tooltiptext", gUpdates.getAUSString("pauseButtonResume")); this._pauseButton.setAttribute("paused", "true"); - var p = u.selectedPatch.QueryInterface(Ci.nsIPropertyBag); + var p = u.selectedPatch.QueryInterface(Ci.nsIWritablePropertyBag); var status = p.getProperty("status"); if (status) { let pausedStatus = gUpdates.getAUSString("downloadPausedStatus", [status]); diff --git a/toolkit/mozapps/update/nsUpdateService.js b/toolkit/mozapps/update/nsUpdateService.js index 71ba83a0afc0..867149caa79d 100644 --- a/toolkit/mozapps/update/nsUpdateService.js +++ b/toolkit/mozapps/update/nsUpdateService.js @@ -16,7 +16,6 @@ XPCOMUtils.defineLazyGlobalGetters(this, ["DOMParser", "XMLHttpRequest"]); const UPDATESERVICE_CID = Components.ID("{B3C290A6-3943-4B89-8BBE-C01EB7B3B311}"); const PREF_APP_UPDATE_ALTWINDOWTYPE = "app.update.altwindowtype"; -const PREF_APP_UPDATE_BACKGROUNDINTERVAL = "app.update.download.backgroundInterval"; const PREF_APP_UPDATE_BACKGROUNDERRORS = "app.update.backgroundErrors"; const PREF_APP_UPDATE_BACKGROUNDMAXERRORS = "app.update.backgroundMaxErrors"; const PREF_APP_UPDATE_CANCELATIONS = "app.update.cancelations"; @@ -156,8 +155,6 @@ const NETWORK_ERROR_OFFLINE = 111; const HTTP_ERROR_OFFSET = 1000; const DOWNLOAD_CHUNK_SIZE = 300000; // bytes -const DOWNLOAD_BACKGROUND_INTERVAL = 600; // seconds -const DOWNLOAD_FOREGROUND_INTERVAL = 0; const UPDATE_WINDOW_NAME = "Update:Wizard"; @@ -1330,8 +1327,6 @@ function Update(update) { this.unsupported = false; this.channel = "default"; this.promptWaitTime = Services.prefs.getIntPref(PREF_APP_UPDATE_PROMPTWAITTIME, 43200); - this.backgroundInterval = Services.prefs.getIntPref(PREF_APP_UPDATE_BACKGROUNDINTERVAL, - DOWNLOAD_BACKGROUND_INTERVAL); // Null , assume this is a message container and do no // further initialization @@ -1386,10 +1381,6 @@ function Update(update) { if (!isNaN(attr.value)) { this.promptWaitTime = parseInt(attr.value); } - } else if (attr.name == "backgroundInterval") { - if (!isNaN(attr.value)) { - this.backgroundInterval = parseInt(attr.value); - } } else if (attr.name == "unsupported") { this.unsupported = attr.value == "true"; } else { @@ -1420,9 +1411,6 @@ function Update(update) { this.displayVersion = this.appVersion; } - // Don't allow the background download interval to be greater than 10 minutes. - this.backgroundInterval = Math.min(this.backgroundInterval, 600); - // The Update Name is either the string provided by the element, or // the string: " " var name = ""; @@ -1528,7 +1516,6 @@ Update.prototype = { } var update = updates.createElementNS(URI_UPDATE_NS, "update"); update.setAttribute("appVersion", this.appVersion); - update.setAttribute("backgroundInterval", this.backgroundInterval); update.setAttribute("buildID", this.buildID); update.setAttribute("channel", this.channel); update.setAttribute("displayVersion", this.displayVersion); @@ -3552,9 +3539,9 @@ Downloader.prototype = { let patchFile = getUpdatesDir().clone(); patchFile.append(FILE_UPDATE_MAR); - update.QueryInterface(Ci.nsIPropertyBag); - let interval = this.background ? update.getProperty("backgroundInterval") - : DOWNLOAD_FOREGROUND_INTERVAL; + + // The interval is 0 since there is no need to throttle downloads. + let interval = 0; LOG("Downloader:downloadUpdate - url: " + this._patch.URL + ", path: " + patchFile.path + ", interval: " + interval); @@ -3903,6 +3890,7 @@ Downloader.prototype = { // downloading) and if at any point this was a foreground download // notify the user about the error. If the update was a background // update there is no notification since the user won't be expecting it. + this._update.QueryInterface(Ci.nsIWritablePropertyBag); if (!Services.wm.getMostRecentWindow(UPDATE_WINDOW_NAME) && this._update.getProperty("foregroundDownload") == "true") { let prompter = Cc["@mozilla.org/updates/update-prompt;1"]. diff --git a/toolkit/mozapps/update/tests/chrome/utils.js b/toolkit/mozapps/update/tests/chrome/utils.js index 53443f733940..c3b7d8573466 100644 --- a/toolkit/mozapps/update/tests/chrome/utils.js +++ b/toolkit/mozapps/update/tests/chrome/utils.js @@ -816,7 +816,6 @@ function setupPrefs() { Services.prefs.setIntPref(PREF_APP_UPDATE_PROMPTWAITTIME, 0); Services.prefs.setBoolPref(PREF_APP_UPDATE_SILENT, false); Services.prefs.setBoolPref(PREF_APP_UPDATE_DOORHANGER, false); - Services.prefs.setIntPref(PREF_APP_UPDATE_DOWNLOADBACKGROUNDINTERVAL, 0); } /** @@ -915,10 +914,6 @@ function resetPrefs() { if (Services.prefs.prefHasUserValue(PREF_APP_UPDATE_DOORHANGER)) { Services.prefs.clearUserPref(PREF_APP_UPDATE_DOORHANGER); } - - if (Services.prefs.prefHasUserValue(PREF_APP_UPDATE_DOWNLOADBACKGROUNDINTERVAL)) { - Services.prefs.clearUserPref(PREF_APP_UPDATE_DOWNLOADBACKGROUNDINTERVAL); - } } function setupTimer(aTestTimeout) { diff --git a/toolkit/mozapps/update/tests/data/shared.js b/toolkit/mozapps/update/tests/data/shared.js index 4ec0fb943e70..e81696565a40 100644 --- a/toolkit/mozapps/update/tests/data/shared.js +++ b/toolkit/mozapps/update/tests/data/shared.js @@ -18,7 +18,6 @@ const PREF_APP_UPDATE_CHANNEL = "app.update.channel"; const PREF_APP_UPDATE_DOORHANGER = "app.update.doorhanger"; const PREF_APP_UPDATE_DOWNLOADPROMPTATTEMPTS = "app.update.download.attempts"; const PREF_APP_UPDATE_DOWNLOADPROMPTMAXATTEMPTS = "app.update.download.maxAttempts"; -const PREF_APP_UPDATE_DOWNLOADBACKGROUNDINTERVAL = "app.update.download.backgroundInterval"; const PREF_APP_UPDATE_DISABLEDFORTESTING = "app.update.disabledForTesting"; const PREF_APP_UPDATE_IDLETIME = "app.update.idletime"; const PREF_APP_UPDATE_LOG = "app.update.log"; diff --git a/toolkit/mozapps/update/tests/data/sharedUpdateXML.js b/toolkit/mozapps/update/tests/data/sharedUpdateXML.js index 2ae6dffd2baf..6d80fdd0b686 100644 --- a/toolkit/mozapps/update/tests/data/sharedUpdateXML.js +++ b/toolkit/mozapps/update/tests/data/sharedUpdateXML.js @@ -118,7 +118,6 @@ function getRemoteUpdatesXMLString(aUpdates) { function getRemoteUpdateString(aUpdateProps, aPatches) { const updateProps = { appVersion: DEFAULT_UPDATE_VERSION, - backgroundInterval: null, buildID: "20080811053724", custom1: null, custom2: null, @@ -215,7 +214,6 @@ function getLocalUpdateString(aUpdateProps, aPatches) { set appVersion(val) { this._appVersion = val; }, - backgroundInterval: null, buildID: "20080811053724", channel: gDefaultPrefBranch.getCharPref(PREF_APP_UPDATE_CHANNEL), custom1: null, @@ -310,8 +308,6 @@ function getUpdateString(aUpdateProps) { let detailsURL = "detailsURL=\"" + aUpdateProps.detailsURL + "\" "; let promptWaitTime = aUpdateProps.promptWaitTime ? "promptWaitTime=\"" + aUpdateProps.promptWaitTime + "\" " : ""; - let backgroundInterval = aUpdateProps.backgroundInterval ? - "backgroundInterval=\"" + aUpdateProps.backgroundInterval + "\" " : ""; let custom1 = aUpdateProps.custom1 ? aUpdateProps.custom1 + " " : ""; let custom2 = aUpdateProps.custom2 ? aUpdateProps.custom2 + " " : ""; let buildID = "buildID=\"" + aUpdateProps.buildID + "\""; @@ -322,7 +318,6 @@ function getUpdateString(aUpdateProps) { appVersion + detailsURL + promptWaitTime + - backgroundInterval + custom1 + custom2 + buildID; diff --git a/toolkit/mozapps/update/tests/unit_aus_update/remoteUpdateXML.js b/toolkit/mozapps/update/tests/unit_aus_update/remoteUpdateXML.js index c176d5f0f2c2..c9cd42e5f8ff 100644 --- a/toolkit/mozapps/update/tests/unit_aus_update/remoteUpdateXML.js +++ b/toolkit/mozapps/update/tests/unit_aus_update/remoteUpdateXML.js @@ -15,10 +15,6 @@ function run_test() { setUpdateURL(gURLData + gHTTPHandlerPath); setUpdateChannel("test_channel"); - // This test expects that the app.update.download.backgroundInterval - // preference doesn't already exist. - Services.prefs.deleteBranch("app.update.download.backgroundInterval"); - standardInit(); executeSoon(run_test_pt01); } @@ -67,7 +63,6 @@ function run_test_pt02() { buildID: "20080811053724", detailsURL: "http://details/", promptWaitTime: "345600", - backgroundInterval: "1200", custom1: "custom1_attr=\"custom1 value\"", custom2: "custom2_attr=\"custom2 value\""}; let updates = getRemoteUpdateString(updateProps, patches); @@ -92,7 +87,7 @@ function check_test_pt02() { Assert.equal(gUpdateCount, 1, "the update count" + MSG_SHOULD_EQUAL); - let bestUpdate = gAUS.selectUpdate(gUpdates, gUpdateCount).QueryInterface(Ci.nsIPropertyBag); + let bestUpdate = gAUS.selectUpdate(gUpdates, gUpdateCount).QueryInterface(Ci.nsIWritablePropertyBag); Assert.equal(bestUpdate.type, "minor", "the update type attribute" + MSG_SHOULD_EQUAL); Assert.equal(bestUpdate.name, "Minor Test", @@ -107,9 +102,6 @@ function check_test_pt02() { "the update detailsURL attribute" + MSG_SHOULD_EQUAL); Assert.equal(bestUpdate.promptWaitTime, "345600", "the update promptWaitTime attribute" + MSG_SHOULD_EQUAL); - // The default and maximum value for backgroundInterval is 600 - Assert.equal(bestUpdate.getProperty("backgroundInterval"), "600", - "the update backgroundInterval attribute" + MSG_SHOULD_EQUAL); Assert.equal(bestUpdate.serviceURL, gURLData + gHTTPHandlerPath + "?force=1", "the update serviceURL attribute" + MSG_SHOULD_EQUAL); Assert.equal(bestUpdate.channel, "test_channel", diff --git a/toolkit/mozapps/update/tests/unit_aus_update/updateManagerXML.js b/toolkit/mozapps/update/tests/unit_aus_update/updateManagerXML.js index 8d846885f26a..8d551c16d7e2 100644 --- a/toolkit/mozapps/update/tests/unit_aus_update/updateManagerXML.js +++ b/toolkit/mozapps/update/tests/unit_aus_update/updateManagerXML.js @@ -12,10 +12,6 @@ function run_test() { setUpdateChannel("test_channel"); - // This test expects that the app.update.download.backgroundInterval - // preference doesn't already exist. - Services.prefs.deleteBranch("app.update.download.backgroundInterval"); - let patchProps = {type: "partial", url: "http://partial/", size: "86", @@ -35,7 +31,6 @@ function run_test() { channel: "test_channel", foregroundDownload: "true", promptWaitTime: "345600", - backgroundInterval: "300", previousAppVersion: "3.0", custom1: "custom1_attr=\"custom1 value\"", custom2: "custom2_attr=\"custom2 value\""}; @@ -72,7 +67,7 @@ function run_test() { "the update manager updateCount attribute" + MSG_SHOULD_EQUAL); debugDump("checking the activeUpdate properties"); - let update = gUpdateManager.getUpdateAt(0).QueryInterface(Ci.nsIPropertyBag); + let update = gUpdateManager.getUpdateAt(0).QueryInterface(Ci.nsIWritablePropertyBag); Assert.equal(update.state, STATE_SUCCEEDED, "the update state attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.type, "major", @@ -100,8 +95,6 @@ function run_test() { "the update channel attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.promptWaitTime, "345600", "the update promptWaitTime attribute" + MSG_SHOULD_EQUAL); - Assert.equal(update.getProperty("backgroundInterval"), "300", - "the update backgroundInterval attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.previousAppVersion, "3.0", "the update previousAppVersion attribute" + MSG_SHOULD_EQUAL); // Custom attributes @@ -124,7 +117,7 @@ function run_test() { "the update patch state attribute" + MSG_SHOULD_EQUAL); debugDump("checking the first update properties"); - update = gUpdateManager.getUpdateAt(1).QueryInterface(Ci.nsIPropertyBag); + update = gUpdateManager.getUpdateAt(1).QueryInterface(Ci.nsIWritablePropertyBag); Assert.equal(update.state, STATE_FAILED, "the update state attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.name, "Existing", @@ -151,9 +144,6 @@ function run_test() { "the update channel attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.promptWaitTime, "691200", "the update promptWaitTime attribute" + MSG_SHOULD_EQUAL); - // The default and maximum value for backgroundInterval is 600 - Assert.equal(update.getProperty("backgroundInterval"), "600", - "the update backgroundInterval attribute" + MSG_SHOULD_EQUAL); Assert.equal(update.previousAppVersion, null, "the update previousAppVersion attribute" + MSG_SHOULD_EQUAL); // Custom attributes diff --git a/toolkit/themes/linux/global/global.css b/toolkit/themes/linux/global/global.css index b2280fb8bbe4..0d96ca7fc98a 100644 --- a/toolkit/themes/linux/global/global.css +++ b/toolkit/themes/linux/global/global.css @@ -262,23 +262,3 @@ popupnotificationcontent { %include ../../shared/notification-popup.inc.css -/* :::::: autoscroll popup ::::: */ - -.autoscroller { - border: none; - padding: 0; - background-image: url("chrome://global/skin/icons/autoscroll.svg"); - background-size: contain; - background-color: transparent; - background-repeat: no-repeat; - -moz-appearance: none; -} - -.autoscroller[scrolldir="NS"] { - background-image: url("chrome://global/skin/icons/autoscroll-vertical.svg"); -} - -.autoscroller[scrolldir="EW"] { - background-image: url("chrome://global/skin/icons/autoscroll-horizontal.svg"); -} - diff --git a/toolkit/themes/osx/global/global.css b/toolkit/themes/osx/global/global.css index 5e621235617e..f7068ffae694 100644 --- a/toolkit/themes/osx/global/global.css +++ b/toolkit/themes/osx/global/global.css @@ -250,28 +250,6 @@ popupnotificationcontent { %include ../../shared/notification-popup.inc.css -/* :::::: autoscroll popup ::::: */ - -.autoscroller { - border: none; - padding: 0; - background-image: url("chrome://global/skin/icons/autoscroll.svg"); - background-size: contain; - background-color: transparent; - background-position: right top; - background-repeat: no-repeat; - -moz-appearance: none; - -moz-window-shadow: none; -} - -.autoscroller[scrolldir="NS"] { - background-image: url("chrome://global/skin/icons/autoscroll-vertical.svg"); -} - -.autoscroller[scrolldir="EW"] { - background-image: url("chrome://global/skin/icons/autoscroll-horizontal.svg"); -} - /* autorepeatbuttons in menus */ .popup-internal-box > .scrollbutton-up, diff --git a/toolkit/themes/shared/global.inc.css b/toolkit/themes/shared/global.inc.css index 03a4d7e33b42..6da91d1a4ea2 100644 --- a/toolkit/themes/shared/global.inc.css +++ b/toolkit/themes/shared/global.inc.css @@ -28,6 +28,27 @@ height: 20px; } +/* Autoscroll popup */ + +.autoscroller { + border: none; + padding: 0; + background-image: url("chrome://global/skin/icons/autoscroll.svg"); + background-size: contain; + background-color: transparent; + background-repeat: no-repeat; + -moz-appearance: none; + -moz-window-shadow: none; +} + +.autoscroller[scrolldir="NS"] { + background-image: url("chrome://global/skin/icons/autoscroll-vertical.svg"); +} + +.autoscroller[scrolldir="EW"] { + background-image: url("chrome://global/skin/icons/autoscroll-horizontal.svg"); +} + /* Panel footers */ .panel-footer { diff --git a/toolkit/themes/windows/global/global.css b/toolkit/themes/windows/global/global.css index 3beec23af037..bef57c6566f2 100644 --- a/toolkit/themes/windows/global/global.css +++ b/toolkit/themes/windows/global/global.css @@ -267,23 +267,3 @@ popupnotificationcontent { %include ../../shared/notification-popup.inc.css -/* :::::: autoscroll popup ::::: */ - -.autoscroller { - border: none; - padding: 0; - background-image: url("chrome://global/skin/icons/autoscroll.svg"); - background-size: contain; - background-color: transparent; - background-repeat: no-repeat; - -moz-appearance: none; -} - -.autoscroller[scrolldir="NS"] { - background-image: url("chrome://global/skin/icons/autoscroll-vertical.svg"); -} - -.autoscroller[scrolldir="EW"] { - background-image: url("chrome://global/skin/icons/autoscroll-horizontal.svg"); -} -