summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorhallgren <hallgren@chalmers.se>2014-04-09 20:49:53 +0000
committerhallgren <hallgren@chalmers.se>2014-04-09 20:49:53 +0000
commit402cccc3ca1621acac217dac4c9297cb7b75d2ab (patch)
tree2201f4c383e3bdd852f5cd0640bbe5d1026b4a51 /src
parent96f36d8f0a689aa09c1e92e36eaf598dd13ba978 (diff)
localstorage.js: bug fix
If you stored "false" and tried to retrieve it with a default value, you got the default value instead of "false".
Diffstat (limited to 'src')
-rw-r--r--src/www/js/localstorage.js8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/www/js/localstorage.js b/src/www/js/localstorage.js
index 3c6a0fa12..e1ef76c16 100644
--- a/src/www/js/localstorage.js
+++ b/src/www/js/localstorage.js
@@ -15,15 +15,15 @@ var fakedLocalStorage = [] // a shared substitute for persistent localStorage
// An interface to localStorage, to store JSON data under a unique prefix
function appLocalStorage(appPrefix,privateStorage) {
- function parse(s) {
- try { return JSON.parse(s) } catch(e) { return null }
+ function parse(s,def) {
+ try { return JSON.parse(s) } catch(e) { return def }
}
function methods(storage) {
return {
get: function (name,def) {
var id=appPrefix+name
- return storage[id] && parse(storage[id]) || def;
+ return parse(storage[id]||"",def);
},
put: function (name,value) {
var id=appPrefix+name;
@@ -34,7 +34,7 @@ function appLocalStorage(appPrefix,privateStorage) {
delete storage[id]
},
ls: function(prefix) {
- var pre=appPrefix+prefix
+ var pre=appPrefix+(prefix||"")
var files=[]
for(var i in storage)
if(hasPrefix(i,pre)) files.push(i.substr(pre.length))