зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1309384 - merge default and user prefs in Services shim; r=jdescottes
MozReview-Commit-ID: 19rvPSGOsOZ --HG-- extra : rebase_source : 7d949a7a626056a5c6646cba6276b26095eb9bb3
This commit is contained in:
Родитель
524df273d6
Коммит
8f4c815751
|
@ -356,12 +356,15 @@ PrefBranch.prototype = {
|
||||||
* @param {String} keyName the full-qualified name of the preference.
|
* @param {String} keyName the full-qualified name of the preference.
|
||||||
* This is also the name of the key in local storage.
|
* This is also the name of the key in local storage.
|
||||||
* @param {Any} userValue the user value to use if the pref does not exist
|
* @param {Any} userValue the user value to use if the pref does not exist
|
||||||
* @param {Any} defaultValue the default value to use if the pref
|
|
||||||
* does not exist
|
|
||||||
* @param {Boolean} hasUserValue if a new pref is created, whether
|
* @param {Boolean} hasUserValue if a new pref is created, whether
|
||||||
* the default value is also a user value
|
* the default value is also a user value
|
||||||
|
* @param {Any} defaultValue the default value to use if the pref
|
||||||
|
* does not exist
|
||||||
|
* @param {Boolean} init if true, then this call is initialization
|
||||||
|
* from local storage and should override the default prefs
|
||||||
*/
|
*/
|
||||||
_findOrCreatePref: function (keyName, userValue, hasUserValue, defaultValue) {
|
_findOrCreatePref: function (keyName, userValue, hasUserValue, defaultValue,
|
||||||
|
init = false) {
|
||||||
let branch = this._createBranch(keyName.split("."));
|
let branch = this._createBranch(keyName.split("."));
|
||||||
|
|
||||||
if (hasUserValue && typeof (userValue) !== typeof (defaultValue)) {
|
if (hasUserValue && typeof (userValue) !== typeof (defaultValue)) {
|
||||||
|
@ -383,7 +386,7 @@ PrefBranch.prototype = {
|
||||||
throw new Error("unhandled argument type: " + typeof (defaultValue));
|
throw new Error("unhandled argument type: " + typeof (defaultValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (branch._type === PREF_INVALID) {
|
if (init || branch._type === PREF_INVALID) {
|
||||||
branch._storageUpdated(type, userValue, hasUserValue, defaultValue);
|
branch._storageUpdated(type, userValue, hasUserValue, defaultValue);
|
||||||
} else if (branch._type !== type) {
|
} else if (branch._type !== type) {
|
||||||
throw new Error("attempt to change type of pref " + keyName);
|
throw new Error("attempt to change type of pref " + keyName);
|
||||||
|
@ -422,7 +425,7 @@ PrefBranch.prototype = {
|
||||||
* Helper function to initialize the root PrefBranch.
|
* Helper function to initialize the root PrefBranch.
|
||||||
*/
|
*/
|
||||||
_initializeRoot: function () {
|
_initializeRoot: function () {
|
||||||
if (localStorage.length === 0 && Services._defaultPrefsEnabled) {
|
if (Services._defaultPrefsEnabled) {
|
||||||
/* eslint-disable no-eval */
|
/* eslint-disable no-eval */
|
||||||
let devtools = require("raw!prefs!devtools/client/preferences/devtools");
|
let devtools = require("raw!prefs!devtools/client/preferences/devtools");
|
||||||
eval(devtools);
|
eval(devtools);
|
||||||
|
@ -439,7 +442,7 @@ PrefBranch.prototype = {
|
||||||
let {userValue, hasUserValue, defaultValue} =
|
let {userValue, hasUserValue, defaultValue} =
|
||||||
JSON.parse(localStorage.getItem(keyName));
|
JSON.parse(localStorage.getItem(keyName));
|
||||||
this._findOrCreatePref(keyName.slice(PREFIX.length), userValue,
|
this._findOrCreatePref(keyName.slice(PREFIX.length), userValue,
|
||||||
hasUserValue, defaultValue);
|
hasUserValue, defaultValue, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,3 +5,4 @@ support-files =
|
||||||
[test_service_appinfo.html]
|
[test_service_appinfo.html]
|
||||||
[test_service_focus.html]
|
[test_service_focus.html]
|
||||||
[test_service_prefs.html]
|
[test_service_prefs.html]
|
||||||
|
[test_service_prefs_defaults.html]
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<!--
|
||||||
|
https://bugzilla.mozilla.org/show_bug.cgi?id=1309384
|
||||||
|
-->
|
||||||
|
<head>
|
||||||
|
<title>Test for Bug 1309384 - Services.prefs replacement defaults handling</title>
|
||||||
|
<script type="text/javascript" src="/MochiKit/MochiKit.js"></script>
|
||||||
|
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||||
|
<link rel="stylesheet" type="text/css"
|
||||||
|
href="chrome://mochikit/content/tests/SimpleTest/test.css">
|
||||||
|
|
||||||
|
<script type="application/javascript;version=1.8">
|
||||||
|
"use strict";
|
||||||
|
var exports = {}
|
||||||
|
var module = {exports};
|
||||||
|
|
||||||
|
// Allow one require("raw!prefs...") to return some defaults, with the
|
||||||
|
// others being ignored.
|
||||||
|
var firstTime = true;
|
||||||
|
function require(something) {
|
||||||
|
if (!something.startsWith("raw!prefs!")) {
|
||||||
|
throw new Error("whoops");
|
||||||
|
}
|
||||||
|
if (!firstTime) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
firstTime = false;
|
||||||
|
return "pref('pref1', 'pref1default');\n" +
|
||||||
|
"pref('pref2', 'pref2default');\n" +
|
||||||
|
"pref('pref3', 'pref3default');\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Pretend that one of the prefs was modifed by the user in an earlier session.
|
||||||
|
localStorage.setItem("Services.prefs:pref3", JSON.stringify({
|
||||||
|
// string
|
||||||
|
type: 32,
|
||||||
|
defaultValue: "pref3default",
|
||||||
|
hasUserValue: true,
|
||||||
|
userValue: "glass winged butterfly"
|
||||||
|
}));
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script type="application/javascript;version=1.8"
|
||||||
|
src="resource://devtools/client/shared/shim/Services.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<script type="application/javascript;version=1.8">
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
is(Services.prefs.getCharPref("pref1"), "pref1default", "pref1 value");
|
||||||
|
is(Services.prefs.getCharPref("pref2"), "pref2default", "pref2 value");
|
||||||
|
is(Services.prefs.getCharPref("pref3"), "glass winged butterfly", "pref3 value");
|
||||||
|
|
||||||
|
// Only pref3 should be in local storage at this point.
|
||||||
|
is(localStorage.length, 1, "local storage is correct");
|
||||||
|
|
||||||
|
// Clean up.
|
||||||
|
localStorage.clear();
|
||||||
|
|
||||||
|
</script>
|
||||||
|
</body>
|
Загрузка…
Ссылка в новой задаче