| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present 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 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 103 /** | 103 /** |
| 104 * The file containing the subscriptions. | 104 * The file containing the subscriptions. |
| 105 * @type {string} | 105 * @type {string} |
| 106 */ | 106 */ |
| 107 get sourceFile() | 107 get sourceFile() |
| 108 { | 108 { |
| 109 return "patterns.ini"; | 109 return "patterns.ini"; |
| 110 } | 110 } |
| 111 | 111 |
| 112 /** | 112 /** |
| 113 * Yields all subscriptions in the storage. | 113 * Yields subscriptions in the storage. |
| 114 * @param {?string} [filterText] The filter text for which to look. If | |
| 115 * specified, the function yields only those subscriptions that contain the | |
| 116 * given filter text. By default the function yields all subscriptions. | |
| 114 * @yields {Subscription} | 117 * @yields {Subscription} |
| 115 */ | 118 */ |
| 116 *subscriptions() | 119 *subscriptions(filterText = null) |
| 117 { | 120 { |
| 118 yield* this.knownSubscriptions.values(); | 121 if (filterText == null) |
| 122 { | |
| 123 yield* this.knownSubscriptions.values(); | |
| 124 } | |
| 125 else | |
| 126 { | |
| 127 for (let subscription of this.knownSubscriptions.values()) | |
| 128 { | |
| 129 if (subscription.hasFilterText(filterText)) | |
| 130 yield subscription; | |
| 131 } | |
| 132 } | |
| 119 } | 133 } |
| 120 | 134 |
| 121 /** | 135 /** |
| 122 * The number of subscriptions in the storage. | 136 * The number of subscriptions in the storage. |
| 123 * @type {number} | 137 * @type {number} |
| 124 */ | 138 */ |
| 125 get subscriptionCount() | 139 get subscriptionCount() |
| 126 { | 140 { |
| 127 return this.knownSubscriptions.size; | 141 return this.knownSubscriptions.size; |
| 128 } | 142 } |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 158 /** | 172 /** |
| 159 * Adds a subscription to the storage. | 173 * Adds a subscription to the storage. |
| 160 * @param {Subscription} subscription The subscription to be added. | 174 * @param {Subscription} subscription The subscription to be added. |
| 161 */ | 175 */ |
| 162 addSubscription(subscription) | 176 addSubscription(subscription) |
| 163 { | 177 { |
| 164 if (this.knownSubscriptions.has(subscription.url)) | 178 if (this.knownSubscriptions.has(subscription.url)) |
| 165 return; | 179 return; |
| 166 | 180 |
| 167 this.knownSubscriptions.set(subscription.url, subscription); | 181 this.knownSubscriptions.set(subscription.url, subscription); |
| 168 connectSubscriptionFilters(subscription); | |
| 169 | 182 |
| 170 filterNotifier.emit("subscription.added", subscription); | 183 filterNotifier.emit("subscription.added", subscription); |
| 171 } | 184 } |
| 172 | 185 |
| 173 /** | 186 /** |
| 174 * Removes a subscription from the storage. | 187 * Removes a subscription from the storage. |
| 175 * @param {Subscription} subscription The subscription to be removed. | 188 * @param {Subscription} subscription The subscription to be removed. |
| 176 */ | 189 */ |
| 177 removeSubscription(subscription) | 190 removeSubscription(subscription) |
| 178 { | 191 { |
| 179 if (!this.knownSubscriptions.has(subscription.url)) | 192 if (!this.knownSubscriptions.has(subscription.url)) |
| 180 return; | 193 return; |
| 181 | 194 |
| 182 disconnectSubscriptionFilters(subscription); | |
| 183 | |
| 184 this.knownSubscriptions.delete(subscription.url); | 195 this.knownSubscriptions.delete(subscription.url); |
| 185 | 196 |
| 186 // This should be the last remaining reference to the Subscription | 197 // This should be the last remaining reference to the Subscription |
| 187 // object. | 198 // object. |
| 188 Subscription.knownSubscriptions.delete(subscription.url); | 199 Subscription.knownSubscriptions.delete(subscription.url); |
| 189 | 200 |
| 190 filterNotifier.emit("subscription.removed", subscription); | 201 filterNotifier.emit("subscription.removed", subscription); |
| 191 } | 202 } |
| 192 | 203 |
| 193 /** | 204 /** |
| 194 * Replaces the list of filters in a subscription with a new list. | 205 * Replaces the list of filters in a subscription with a new list. |
| 195 * @param {Subscription} subscription The subscription to be updated. | 206 * @param {Subscription} subscription The subscription to be updated. |
| 196 * @param {Array.<string>} filterText The new filter text. | 207 * @param {Array.<string>} filterText The new filter text. |
| 197 */ | 208 */ |
| 198 updateSubscriptionFilters(subscription, filterText) | 209 updateSubscriptionFilters(subscription, filterText) |
| 199 { | 210 { |
| 200 let oldFilterText = [...subscription.filterText()]; | 211 let oldFilterText = [...subscription.filterText()]; |
| 201 disconnectSubscriptionFilters(subscription, oldFilterText); | |
|
Manish Jethani
2019/02/26 12:29:57
You might think that looking up the subscriptions
hub
2019/03/08 21:36:19
my default config has 6. Add one language, that ma
Manish Jethani
2019/03/30 20:50:35
Each user-defined filter is not a special subscrip
| |
| 202 subscription.clearFilters(); | 212 subscription.clearFilters(); |
| 203 | 213 |
| 204 for (let text of filterText) | 214 for (let text of filterText) |
| 205 subscription.addFilterText(text); | 215 subscription.addFilterText(text); |
| 206 | 216 |
| 207 connectSubscriptionFilters(subscription, filterText); | |
| 208 | |
| 209 filterNotifier.emit("subscription.updated", subscription, oldFilterText); | 217 filterNotifier.emit("subscription.updated", subscription, oldFilterText); |
| 210 } | 218 } |
| 211 | 219 |
| 212 /** | 220 /** |
| 213 * Adds a user-defined filter to the storage. | 221 * Adds a user-defined filter to the storage. |
| 214 * @param {Filter} filter | 222 * @param {Filter} filter |
| 215 * @param {?SpecialSubscription} [subscription] The subscription that the | 223 * @param {?SpecialSubscription} [subscription] The subscription that the |
| 216 * filter should be added to. | 224 * filter should be added to. |
| 217 * @param {number} [position] The position within the subscription at which | 225 * @param {number} [position] The position within the subscription at which |
| 218 * the filter should be added. If not specified, the filter is added at the | 226 * the filter should be added. If not specified, the filter is added at the |
| 219 * end of the subscription. | 227 * end of the subscription. |
| 220 */ | 228 */ |
| 221 addFilter(filter, subscription, position) | 229 addFilter(filter, subscription, position) |
| 222 { | 230 { |
| 223 if (!subscription) | 231 if (!subscription) |
| 224 { | 232 { |
| 225 for (let currentSubscription of filter.subscriptions()) | 233 for (let currentSubscription of this.subscriptions(filter.text)) |
| 226 { | 234 { |
| 227 if (currentSubscription instanceof SpecialSubscription && | 235 if (currentSubscription instanceof SpecialSubscription && |
| 228 !currentSubscription.disabled) | 236 !currentSubscription.disabled) |
| 229 { | 237 { |
| 230 return; // No need to add | 238 return; // No need to add |
| 231 } | 239 } |
| 232 } | 240 } |
| 233 subscription = this.getGroupForFilter(filter); | 241 subscription = this.getGroupForFilter(filter); |
| 234 } | 242 } |
| 235 if (!subscription) | 243 if (!subscription) |
| 236 { | 244 { |
| 237 // No group for this filter exists, create one | 245 // No group for this filter exists, create one |
| 238 subscription = SpecialSubscription.createForFilter(filter); | 246 subscription = SpecialSubscription.createForFilter(filter); |
| 239 this.addSubscription(subscription); | 247 this.addSubscription(subscription); |
| 240 return; | 248 return; |
| 241 } | 249 } |
| 242 | 250 |
| 243 if (typeof position == "undefined") | 251 if (typeof position == "undefined") |
| 244 position = subscription.filterCount; | 252 position = subscription.filterCount; |
| 245 | 253 |
| 246 filter.addSubscription(subscription); | |
| 247 subscription.insertFilterAt(filter, position); | 254 subscription.insertFilterAt(filter, position); |
| 248 filterNotifier.emit("filter.added", filter, subscription, position); | 255 filterNotifier.emit("filter.added", filter, subscription, position); |
| 249 } | 256 } |
| 250 | 257 |
| 251 /** | 258 /** |
| 252 * Removes a user-defined filter from the storage. | 259 * Removes a user-defined filter from the storage. |
| 253 * @param {Filter} filter | 260 * @param {Filter} filter |
| 254 * @param {?SpecialSubscription} [subscription] The subscription that the | 261 * @param {?SpecialSubscription} [subscription] The subscription that the |
| 255 * filter should be removed from. If not specified, the filter will be | 262 * filter should be removed from. If not specified, the filter will be |
| 256 * removed from all subscriptions. | 263 * removed from all subscriptions. |
| 257 * @param {number} [position] The position within the subscription at which | 264 * @param {number} [position] The position within the subscription at which |
| 258 * the filter should be removed. If not specified, all instances of the | 265 * the filter should be removed. If not specified, all instances of the |
| 259 * filter will be removed. | 266 * filter will be removed. |
| 260 */ | 267 */ |
| 261 removeFilter(filter, subscription, position) | 268 removeFilter(filter, subscription, position) |
| 262 { | 269 { |
| 263 let subscriptions = ( | 270 let subscriptions = ( |
| 264 subscription ? [subscription] : filter.subscriptions() | 271 subscription ? [subscription] : this.subscriptions(filter.text) |
| 265 ); | 272 ); |
| 266 for (let currentSubscription of subscriptions) | 273 for (let currentSubscription of subscriptions) |
| 267 { | 274 { |
| 268 if (currentSubscription instanceof SpecialSubscription) | 275 if (currentSubscription instanceof SpecialSubscription) |
| 269 { | 276 { |
| 270 let positions = []; | 277 let positions = []; |
| 271 if (typeof position == "undefined") | 278 if (typeof position == "undefined") |
| 272 { | 279 { |
| 273 let index = -1; | 280 let index = -1; |
| 274 do | 281 do |
| 275 { | 282 { |
| 276 index = currentSubscription.searchFilter(filter, index + 1); | 283 index = currentSubscription.findFilterIndex(filter, index + 1); |
| 277 if (index >= 0) | 284 if (index >= 0) |
| 278 positions.push(index); | 285 positions.push(index); |
| 279 } while (index >= 0); | 286 } while (index >= 0); |
| 280 } | 287 } |
| 281 else | 288 else |
| 282 positions.push(position); | 289 positions.push(position); |
| 283 | 290 |
| 284 for (let j = positions.length - 1; j >= 0; j--) | 291 for (let j = positions.length - 1; j >= 0; j--) |
| 285 { | 292 { |
| 286 let currentPosition = positions[j]; | 293 let currentPosition = positions[j]; |
| 287 let currentFilterText = | 294 let currentFilterText = |
| 288 currentSubscription.filterTextAt(currentPosition); | 295 currentSubscription.filterTextAt(currentPosition); |
| 289 if (currentFilterText && currentFilterText == filter.text) | 296 if (currentFilterText && currentFilterText == filter.text) |
| 290 { | 297 { |
| 291 currentSubscription.deleteFilterAt(currentPosition); | 298 currentSubscription.deleteFilterAt(currentPosition); |
| 292 if (currentSubscription.searchFilter(filter) < 0) | |
| 293 filter.removeSubscription(currentSubscription); | |
| 294 filterNotifier.emit("filter.removed", filter, currentSubscription, | 299 filterNotifier.emit("filter.removed", filter, currentSubscription, |
| 295 currentPosition); | 300 currentPosition); |
| 296 } | 301 } |
| 297 } | 302 } |
| 298 } | 303 } |
| 299 } | 304 } |
| 300 } | 305 } |
| 301 | 306 |
| 302 /** | 307 /** |
| 303 * Moves a user-defined filter to a new position. | 308 * Moves a user-defined filter to a new position. |
| (...skipping 339 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 643 } | 648 } |
| 644 } | 649 } |
| 645 | 650 |
| 646 /** | 651 /** |
| 647 * Reads the user's filters from disk, manages them in memory, and writes them | 652 * Reads the user's filters from disk, manages them in memory, and writes them |
| 648 * back to disk. | 653 * back to disk. |
| 649 */ | 654 */ |
| 650 let filterStorage = new FilterStorage(); | 655 let filterStorage = new FilterStorage(); |
| 651 | 656 |
| 652 exports.filterStorage = filterStorage; | 657 exports.filterStorage = filterStorage; |
| 653 | |
| 654 /** | |
| 655 * Connects a subscription to its filters without any notifications. | |
| 656 * @param {Subscription} subscription The subscription that should be | |
| 657 * connected to its filters. | |
| 658 * @param {?Array.<string>} [filterText] A list of filters (in text form) to | |
| 659 * which the subscription should be connected. If this is not given, the | |
| 660 * subscription is connected to its own filters. | |
| 661 */ | |
| 662 function connectSubscriptionFilters(subscription, filterText) | |
| 663 { | |
| 664 if (!filterStorage.knownSubscriptions.has(subscription.url)) | |
| 665 return; | |
| 666 | |
| 667 for (let text of filterText || subscription.filterText()) | |
| 668 Filter.fromText(text).addSubscription(subscription); | |
| 669 } | |
| 670 | |
| 671 /** | |
| 672 * Disconnects a subscription from its filters without any notifications. | |
| 673 * @param {Subscription} subscription The subscription that should be | |
| 674 * disconnected from its filters. | |
| 675 * @param {?Array.<string>} [filterText] A list of filters (in text form) from | |
| 676 * which the subscription should be disconnected. If this is not given, the | |
| 677 * subscription is disconnected from its own filters. | |
| 678 */ | |
| 679 function disconnectSubscriptionFilters(subscription, filterText) | |
| 680 { | |
| 681 if (!filterStorage.knownSubscriptions.has(subscription.url)) | |
| 682 return; | |
| 683 | |
| 684 for (let text of filterText || subscription.filterText()) | |
| 685 Filter.fromText(text).removeSubscription(subscription); | |
| 686 } | |
| OLD | NEW |