Left: | ||
Right: |
LEFT | RIGHT |
---|---|
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-2013 Eyeo GmbH | 3 * Copyright (C) 2006-2014 Eyeo GmbH |
Wladimir Palant
2014/04/04 14:00:35
Note: Please update this when rebasing.
Sebastian Noack
2014/04/07 13:15:25
Done.
| |
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 |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
12 * GNU General Public License for more details. | 12 * GNU General Public License for more details. |
13 * | 13 * |
14 * You should have received a copy of the GNU General Public License | 14 * You should have received a copy of the GNU General Public License |
15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
16 */ | 16 */ |
17 | 17 |
18 (function() | 18 (function() |
19 { | 19 { |
20 var nonEmptyPageMaps = {__proto__: null}; | 20 var nonEmptyPageMaps = {__proto__: null}; |
Wladimir Palant
2014/04/04 14:00:35
Note: we will leak every PageMap object ever creat
Sebastian Noack
2014/04/07 13:15:25
We only keep track of non-empty PageMaps, and page
| |
21 var pageMapCounter = 0; | 21 var pageMapCounter = 0; |
22 | 22 |
23 var PageMap = ext.PageMap = function() | 23 var PageMap = ext.PageMap = function() |
24 { | 24 { |
25 this._map = {__proto__: null}; | 25 this._map = {__proto__: null}; |
26 this._id = ++pageMapCounter; | 26 this._id = ++pageMapCounter; |
27 }; | 27 }; |
28 PageMap.prototype = { | 28 PageMap.prototype = { |
29 _delete: function(id) | 29 _delete: function(id) |
30 { | 30 { |
31 delete this._map[id]; | 31 delete this._map[id]; |
32 | 32 |
33 if (Object.keys(this._map).length == 0) | 33 if (Object.keys(this._map).length == 0) |
34 delete nonEmptyPageMaps[this._id]; | 34 delete nonEmptyPageMaps[this._id]; |
Wladimir Palant
2014/04/04 14:00:35
This isn't really great from the performance point
| |
35 }, | 35 }, |
36 get: function(page) | 36 get: function(page) |
37 { | 37 { |
38 return this._map[page._id]; | 38 return this._map[page._id]; |
39 }, | 39 }, |
40 set: function(page, value) | 40 set: function(page, value) |
41 { | 41 { |
42 this._map[page._id] = value; | 42 this._map[page._id] = value; |
43 nonEmptyPageMaps[this._id] = this; | 43 nonEmptyPageMaps[this._id] = this; |
44 }, | 44 }, |
(...skipping 11 matching lines...) Expand all Loading... | |
56 this._delete(page._id); | 56 this._delete(page._id); |
57 } | 57 } |
58 }; | 58 }; |
59 | 59 |
60 ext._removeFromAllPageMaps = function(pageId) | 60 ext._removeFromAllPageMaps = function(pageId) |
61 { | 61 { |
62 for (var pageMapId in nonEmptyPageMaps) | 62 for (var pageMapId in nonEmptyPageMaps) |
63 nonEmptyPageMaps[pageMapId]._delete(pageId); | 63 nonEmptyPageMaps[pageMapId]._delete(pageId); |
64 }; | 64 }; |
65 })(); | 65 })(); |
LEFT | RIGHT |