| OLD | NEW |
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <http://adblockplus.org/>, | 2 * This file is part of Adblock Plus <http://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2014 Eyeo GmbH | 3 * Copyright (C) 2006-2014 Eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 | 21 |
| 22 let {Services} = Cu.import("resource://gre/modules/Services.jsm", null); | 22 let {Services} = Cu.import("resource://gre/modules/Services.jsm", null); |
| 23 let {FileUtils} = Cu.import("resource://gre/modules/FileUtils.jsm", null); | 23 let {FileUtils} = Cu.import("resource://gre/modules/FileUtils.jsm", null); |
| 24 let {OS} = Cu.import("resource://gre/modules/osfile.jsm", null); | 24 let {OS} = Cu.import("resource://gre/modules/osfile.jsm", null); |
| 25 let {Task} = Cu.import("resource://gre/modules/Task.jsm", null); | 25 let {Task} = Cu.import("resource://gre/modules/Task.jsm", null); |
| 26 | 26 |
| 27 let {Prefs} = require("prefs"); | 27 let {Prefs} = require("prefs"); |
| 28 let {Utils} = require("utils"); | 28 let {Utils} = require("utils"); |
| 29 | 29 |
| 30 let firstRead = true; | 30 let firstRead = true; |
| 31 const BUFFER_SIZE = 0x8000; // 32kB | 31 const BUFFER_SIZE = 0x80000; // 512kB |
| 32 | 32 |
| 33 let IO = exports.IO = | 33 let IO = exports.IO = |
| 34 { | 34 { |
| 35 /** | 35 /** |
| 36 * Retrieves the platform-dependent line break string. | 36 * Retrieves the platform-dependent line break string. |
| 37 */ | 37 */ |
| 38 get lineBreak() | 38 get lineBreak() |
| 39 { | 39 { |
| 40 let lineBreak = (Services.appinfo.OS == "WINNT" ? "\r\n" : "\n"); | 40 let lineBreak = (Services.appinfo.OS == "WINNT" ? "\r\n" : "\n"); |
| 41 Object.defineProperty(this, "lineBreak", {value: lineBreak}); | 41 Object.defineProperty(this, "lineBreak", {value: lineBreak}); |
| (...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 143 { | 143 { |
| 144 // Still processing data, delay processing this event. | 144 // Still processing data, delay processing this event. |
| 145 error = e; | 145 error = e; |
| 146 return; | 146 return; |
| 147 } | 147 } |
| 148 | 148 |
| 149 callback(e); | 149 callback(e); |
| 150 }; | 150 }; |
| 151 | 151 |
| 152 let decoder = new TextDecoder(); | 152 let decoder = new TextDecoder(); |
| 153 let array = new Uint8Array(BUFFER_SIZE); | |
| 154 Task.spawn(function() | 153 Task.spawn(function() |
| 155 { | 154 { |
| 156 if (firstRead && Services.vc.compare(Utils.platformVersion, "23.0a1") <=
0) | 155 if (firstRead && Services.vc.compare(Utils.platformVersion, "23.0a1") <=
0) |
| 157 { | 156 { |
| 158 // See https://issues.adblockplus.org/ticket/530 - the first file | 157 // See https://issues.adblockplus.org/ticket/530 - the first file |
| 159 // opened cannot be closed due to Gecko bug 858723. Make sure that | 158 // opened cannot be closed due to Gecko bug 858723. Make sure that |
| 160 // our patterns.ini file doesn't stay locked by opening a dummy file | 159 // our patterns.ini file doesn't stay locked by opening a dummy file |
| 161 // first. | 160 // first. |
| 162 try | 161 try |
| 163 { | 162 { |
| 164 let dummyPath = IO.resolveFilePath(Prefs.data_directory + "/dummy").
path; | 163 let dummyPath = IO.resolveFilePath(Prefs.data_directory + "/dummy").
path; |
| 165 let dummy = yield OS.File.open(dummyPath, {write: true, truncate: tr
ue}); | 164 let dummy = yield OS.File.open(dummyPath, {write: true, truncate: tr
ue}); |
| 166 yield dummy.close(); | 165 yield dummy.close(); |
| 167 } | 166 } |
| 168 catch (e) | 167 catch (e) |
| 169 { | 168 { |
| 170 // Dummy might be locked already, we don't care | 169 // Dummy might be locked already, we don't care |
| 171 } | 170 } |
| 172 } | 171 } |
| 173 firstRead = false; | 172 firstRead = false; |
| 174 | 173 |
| 175 let f = yield OS.File.open(file.path, {read: true}); | 174 let f = yield OS.File.open(file.path, {read: true}); |
| 176 let numBytes; | 175 while (true) |
| 177 do | |
| 178 { | 176 { |
| 179 numBytes = yield f.readTo(array); | 177 let array = yield f.read(BUFFER_SIZE); |
| 180 if (numBytes) | 178 if (!array.length) |
| 181 { | 179 break; |
| 182 let data = decoder.decode(numBytes == BUFFER_SIZE ? | |
| 183 array : | |
| 184 array.subarray(0, numBytes), {stream: true
}); | |
| 185 onProgress(data); | |
| 186 } | |
| 187 } while (numBytes); | |
| 188 | 180 |
| 181 let data = decoder.decode(array, {stream: true}); |
| 182 onProgress(data); |
| 183 } |
| 189 yield f.close(); | 184 yield f.close(); |
| 190 }.bind(this)).then(onSuccess, onError); | 185 }.bind(this)).then(onSuccess, onError); |
| 191 } | 186 } |
| 192 catch (e) | 187 catch (e) |
| 193 { | 188 { |
| 194 callback(e); | 189 callback(e); |
| 195 } | 190 } |
| 196 }, | 191 }, |
| 197 | 192 |
| 198 /** | 193 /** |
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 328 else | 323 else |
| 329 callback(e); | 324 callback(e); |
| 330 }); | 325 }); |
| 331 } | 326 } |
| 332 catch(e) | 327 catch(e) |
| 333 { | 328 { |
| 334 callback(e); | 329 callback(e); |
| 335 } | 330 } |
| 336 } | 331 } |
| 337 } | 332 } |
| OLD | NEW |