Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: webextension/io.js

Issue 29408710: Issue 5050 - Make legacy extension use WebExtensions I/O (Closed) Base URL: https://hg.adblockplus.org/adblockplus
Patch Set: Created April 10, 2017, 11:23 a.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webextension/io.js
===================================================================
new file mode 100644
--- /dev/null
+++ b/webextension/io.js
@@ -0,0 +1,109 @@
+/*
+ * This file is part of Adblock Plus <https://adblockplus.org/>,
+ * Copyright (C) 2006-2017 eyeo GmbH
+ *
+ * Adblock Plus is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 3 as
+ * published by the Free Software Foundation.
+ *
+ * Adblock Plus is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+"use strict";
Wladimir Palant 2017/04/10 11:35:17 Note that the code here is based on io.js from adb
+
+(function(exports)
+{
+ const keyPrefix = "file:";
+
+ function fileToKey(fileName)
+ {
+ return keyPrefix + fileName;
+ }
+
+ function loadFile(file)
+ {
+ let key = fileToKey(file);
+
+ return browser.storage.local.get(key).then(items =>
+ {
+ if (items.hasOwnProperty(key))
+ return items[key];
+
+ throw "NoSuchFile";
+ });
+ }
+
+ function saveFile(file, data)
+ {
+ return browser.storage.local.set({
+ [fileToKey(file)]: {
+ content: Array.from(data),
+ lastModified: Date.now()
+ }
+ });
+ }
+
+ function removeFile(file)
+ {
+ return browser.storage.local.remove(fileToKey(file));
+ }
+
+ exports.IO =
+ {
+ readFromFile(file)
+ {
+ return loadFile(file).then(entry =>
+ {
+ return entry.content;
+ });
+ },
+
+ writeToFile(file, data)
+ {
+ return saveFile(file, data);
+ },
+
+ copyFile(fromFile, toFile)
+ {
+ return loadFile(fromFile).then(entry =>
+ {
+ return saveFile(toFile, entry.content);
+ });
+ },
+
+ renameFile(fromFile, newName)
+ {
+ return loadFile(fromFile).then(entry =>
+ {
+ return browser.storage.local.set({
+ [fileToKey(newName)]: entry
+ });
+ }).then(() =>
+ {
+ return removeFile(fromFile);
+ });
+ },
+
+ removeFile(file)
+ {
+ return removeFile(file);
+ },
+
+ statFile(file)
+ {
+ return loadFile(file).then(entry =>
+ {
+ return {
+ exists: true,
+ lastModified: entry.lastModified
+ };
+ });
Wladimir Palant 2017/04/10 11:35:17 Note that statFile would normally catch NoSuchFile
+ }
+ };
+})(this);
« lib/io.js ('K') | « webextension/background.js ('k') | webextension/manifest.json » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld