Left: | ||
Right: |
LEFT | RIGHT |
---|---|
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 |
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 /** | 18 /** |
19 * @fileOverview Element hiding implementation. | 19 * @fileOverview Element hiding implementation. |
20 */ | 20 */ |
21 | 21 |
22 #include <unordered_map> | 22 #pragma once |
23 | |
23 #include <vector> | 24 #include <vector> |
24 | 25 |
25 #include "bindings/runtime.h" | 26 #include "bindings/runtime.h" |
26 #include "intrusive_ptr.h" | 27 #include "intrusive_ptr.h" |
27 #include "StringMap.h" | 28 #include "StringMap.h" |
28 #include "filter/Filter.h" | 29 #include "filter/Filter.h" |
29 #include "filter/ElemHideBase.h" | 30 #include "filter/ElemHideBase.h" |
30 #include "filter/ElemHideException.h" | 31 #include "filter/ElemHideException.h" |
31 | 32 |
32 class _ElemHide_SelectorList : public ref_counted | 33 class ElemHide_SelectorList : public ref_counted |
33 { | 34 { |
34 std::vector<ElemHideBasePtr> mSelectors; | 35 std::vector<ElemHideBasePtr> mSelectors; |
35 public: | 36 public: |
36 size_t BINDINGS_EXPORTED GetSelectorCount() const | 37 size_t BINDINGS_EXPORTED GetSelectorCount() const |
37 { | 38 { |
38 return mSelectors.size(); | 39 return mSelectors.size(); |
39 } | 40 } |
40 DependentString BINDINGS_EXPORTED SelectorAt(size_t idx) const; | 41 OwnedString BINDINGS_EXPORTED SelectorAt(size_t idx) const; |
41 const String& BINDINGS_EXPORTED FilterKeyAt(size_t idx) const; | 42 const String& BINDINGS_EXPORTED FilterKeyAt(size_t idx) const; |
42 | 43 |
43 void push_back(ElemHideBasePtr filter) | 44 void push_back(const ElemHideBasePtr& filter) |
hub
2017/10/26 20:53:30
I'm doing this wrong. We are supposed to return se
hub
2017/10/26 20:58:27
but then FilterKeyAt() needs more than just the se
| |
44 { | 45 { |
45 mSelectors.push_back(filter); | 46 mSelectors.push_back(filter); |
46 } | 47 } |
47 | 48 |
48 void append(const _ElemHide_SelectorList* list) | 49 void append(const ElemHide_SelectorList& list) |
49 { | 50 { |
50 mSelectors.insert(mSelectors.end(), | 51 mSelectors.insert(mSelectors.end(), |
51 list->mSelectors.cbegin(), list->mSelectors.cend()); | 52 list.mSelectors.cbegin(), list.mSelectors.cend()); |
52 } | 53 } |
53 }; | 54 }; |
54 | 55 |
55 class ElemHide : public ref_counted | 56 class ElemHide : public ref_counted |
56 { | 57 { |
57 // All filters. Key is filter text. Exception filters excluded. | 58 // All filters. Key is filter text. Exception filters excluded. |
58 StringMap<ElemHideBasePtr> mFilters; | 59 StringMap<ElemHideBasePtr> mFilters; |
59 // StringMap is non copyable. std::unordered_map<> it is | 60 // Filters by domain. Key is domain. |
60 // Filters by domain. Key is domain. Subkey is filter text. | 61 // In value key is filter text, value is filter or NULL |
61 StringMap<std::unordered_map<DependentString,ElemHideBasePtr,StringHash>> mFil tersByDomain; | 62 OwnedStringMap<OwnedStringMap<ElemHideBasePtr>> mFiltersByDomain; |
62 | 63 |
63 // Exceptions. The key is the selector. | 64 // Exceptions. The key is the selector. |
64 StringMap<std::vector<ElemHideExceptionPtr>> mExceptions; | 65 OwnedStringMap<std::vector<ElemHideExceptionPtr>> mExceptions; |
65 // Known exceptions. Filter text as keys. | 66 // Known exceptions. Filter text as keys. |
66 StringSet mKnownExceptions; | 67 StringSet mKnownExceptions; |
67 | 68 |
68 // Unconditional selectors. Filter text as key | 69 // Unconditional selectors. Filter selector as key. Filter as value. |
69 StringSet mUnconditionalSelectors; | 70 OwnedStringMap<ElemHideBasePtr> mUnconditionalSelectors; |
70 | 71 |
71 mutable intrusive_ptr<_ElemHide_SelectorList> mUnconditionalSelectorsCache; | 72 mutable intrusive_ptr<ElemHide_SelectorList> mUnconditionalSelectorsCache; |
72 | 73 |
73 static ElemHide* mInstance; | |
74 public: | 74 public: |
75 static ElemHide* BINDINGS_EXPORTED Create() | |
76 { | |
77 return new ElemHide(); | |
78 } | |
79 // Used by GetSelectorsForDomain to narrow down selectors to return. | |
80 // Keep these value up to date in the ElemHide.js import script. | |
75 enum Criteria | 81 enum Criteria |
76 { | 82 { |
83 // Return all selectors applying to a particular hostname. | |
77 ALL_MATCHING = 0, | 84 ALL_MATCHING = 0, |
85 // Exclude selectors which apply to all websites without exception. | |
78 NO_UNCONDITIONAL = 1, | 86 NO_UNCONDITIONAL = 1, |
87 // Return only selectors for filters which specifically match the | |
88 // given host name. | |
79 SPECIFIC_ONLY = 2, | 89 SPECIFIC_ONLY = 2, |
80 }; | 90 }; |
81 | |
82 static ElemHide* BINDINGS_EXPORTED GetInstance() | |
83 { | |
84 return mInstance; | |
85 } | |
86 | 91 |
87 void BINDINGS_EXPORTED Clear(); | 92 void BINDINGS_EXPORTED Clear(); |
88 void BINDINGS_EXPORTED Add(ElemHideBase& filter); | 93 void BINDINGS_EXPORTED Add(ElemHideBase& filter); |
89 void BINDINGS_EXPORTED Remove(ElemHideBase& filter); | 94 void BINDINGS_EXPORTED Remove(ElemHideBase& filter); |
90 | 95 |
91 _ElemHide_SelectorList* BINDINGS_EXPORTED GetSelectorsForDomain(const String& domain, Criteria criteria) const; | 96 ElemHide_SelectorList* BINDINGS_EXPORTED GetSelectorsForDomain(const String& d omain, |
92 _ElemHide_SelectorList* BINDINGS_EXPORTED GetUnconditionalSelectors() const; | 97 Criteria criter ia) const; |
98 ElemHide_SelectorList* BINDINGS_EXPORTED GetUnconditionalSelectors() const; | |
93 | 99 |
94 ElemHideException* BINDINGS_EXPORTED GetException(const ElemHideBase& filter, | 100 ElemHideException* BINDINGS_EXPORTED GetException(const ElemHideBase& filter, |
95 DependentString& docDomain) const; | 101 DependentString& docDomain) const; |
96 | 102 |
97 private: | 103 private: |
98 void AddToFiltersByDomain(ElemHideBase& filter); | 104 void AddToFiltersByDomain(const ElemHideBasePtr & filter); |
99 }; | 105 }; |
100 | 106 |
LEFT | RIGHT |