OLD | NEW |
1 #ifndef ADBLOCKPLUS_FILTER_ENGINE_H | 1 #ifndef ADBLOCKPLUS_FILTER_ENGINE_H |
2 #define ADBLOCKPLUS_FILTER_ENGINE_H | 2 #define ADBLOCKPLUS_FILTER_ENGINE_H |
3 | 3 |
4 #include <vector> | 4 #include <vector> |
5 #include <map> | 5 #include <map> |
6 #include <string> | 6 #include <string> |
| 7 #include <AdblockPlus/JsValue.h> |
7 | 8 |
8 #include "tr1_memory.h" | 9 #include "tr1_memory.h" |
9 | 10 |
10 namespace AdblockPlus | 11 namespace AdblockPlus |
11 { | 12 { |
12 class JsEngine; | 13 class JsEngine; |
13 class FilterEngine; | 14 class FilterEngine; |
14 | 15 |
| 16 #if FILTER_ENGINE_STUBS |
15 class JsObject | 17 class JsObject |
| 18 #else |
| 19 class JsObject : public JsValue |
| 20 #endif |
16 { | 21 { |
17 public: | 22 public: |
18 std::string GetProperty(const std::string& name, const std::string& defaultV
alue) const; | 23 std::string GetProperty(const std::string& name, const std::string& defaultV
alue) const; |
19 int GetProperty(const std::string& name, int defaultValue) const; | 24 int64_t GetProperty(const std::string& name, int64_t defaultValue) const; |
20 bool GetProperty(const std::string& name, bool defaultValue) const; | 25 bool GetProperty(const std::string& name, bool defaultValue) const; |
21 inline std::string GetProperty(const std::string& name, const char* defaultV
alue) const | 26 inline std::string GetProperty(const std::string& name, const char* defaultV
alue) const |
22 { | 27 { |
23 return GetProperty(name, std::string(defaultValue)); | 28 return GetProperty(name, std::string(defaultValue)); |
24 } | 29 } |
| 30 inline int64_t GetProperty(const std::string& name, int defaultValue) const |
| 31 { |
| 32 return GetProperty(name, static_cast<int64_t>(defaultValue)); |
| 33 } |
25 | 34 |
| 35 #if FILTER_ENGINE_STUBS |
26 void SetProperty(const std::string& name, const std::string& value); | 36 void SetProperty(const std::string& name, const std::string& value); |
27 void SetProperty(const std::string& name, int value); | 37 void SetProperty(const std::string& name, int64_t value); |
28 void SetProperty(const std::string& name, bool value); | 38 void SetProperty(const std::string& name, bool value); |
29 inline void SetProperty(const std::string& name, const char* value) | 39 inline void SetProperty(const std::string& name, const char* value) |
30 { | 40 { |
31 SetProperty(name, std::string(value)); | 41 SetProperty(name, std::string(value)); |
32 } | 42 } |
| 43 inline void SetProperty(const std::string& name, int value) |
| 44 { |
| 45 SetProperty(name, static_cast<int64_t>(value)); |
| 46 } |
| 47 #endif |
33 | 48 |
34 protected: | 49 protected: |
35 #if FILTER_ENGINE_STUBS | 50 #if FILTER_ENGINE_STUBS |
36 JsObject(FilterEngine& filterEngine); | 51 JsObject(FilterEngine& filterEngine); |
37 | 52 |
38 FilterEngine& filterEngine; | 53 FilterEngine& filterEngine; |
39 std::map<std::string, std::string> stringProperties; | 54 std::map<std::string, std::string> stringProperties; |
40 std::map<std::string, int> intProperties; | 55 std::map<std::string, int64_t> intProperties; |
41 std::map<std::string, bool> boolProperties; | 56 std::map<std::string, bool> boolProperties; |
42 #else | 57 #else |
43 JsObject(); | 58 JsObject(JsValuePtr value); |
44 #endif | 59 #endif |
45 }; | 60 }; |
46 | 61 |
47 class Filter : public JsObject, | 62 class Filter : public JsObject, |
48 public std::tr1::enable_shared_from_this<Filter> | 63 public std::tr1::enable_shared_from_this<Filter> |
49 { | 64 { |
50 friend class FilterEngine; | |
51 | |
52 public: | 65 public: |
53 enum Type {TYPE_BLOCKING, TYPE_EXCEPTION, | 66 enum Type {TYPE_BLOCKING, TYPE_EXCEPTION, |
54 TYPE_ELEMHIDE, TYPE_ELEMHIDE_EXCEPTION, | 67 TYPE_ELEMHIDE, TYPE_ELEMHIDE_EXCEPTION, |
55 TYPE_COMMENT, TYPE_INVALID}; | 68 TYPE_COMMENT, TYPE_INVALID}; |
56 | 69 |
57 bool IsListed() const; | 70 bool IsListed(); |
58 void AddToList(); | 71 void AddToList(); |
59 void RemoveFromList(); | 72 void RemoveFromList(); |
| 73 bool operator==(const Filter& filter) const; |
60 | 74 |
| 75 #if FILTER_ENGINE_STUBS |
61 private: | 76 private: |
62 #if FILTER_ENGINE_STUBS | 77 friend class FilterEngine; |
63 Filter(FilterEngine& filterEngine, const std::string& text); | 78 Filter(FilterEngine& filterEngine, const std::string& text); |
64 #else | 79 #else |
65 Filter(); | 80 Filter(JsValuePtr value); |
66 #endif | 81 #endif |
67 }; | 82 }; |
68 | 83 |
69 class Subscription : public JsObject, | 84 class Subscription : public JsObject, |
70 public std::tr1::enable_shared_from_this<Subscription> | 85 public std::tr1::enable_shared_from_this<Subscription> |
71 { | 86 { |
72 friend class FilterEngine; | |
73 | |
74 public: | 87 public: |
75 bool IsListed() const; | 88 bool IsListed(); |
76 void AddToList(); | 89 void AddToList(); |
77 void RemoveFromList(); | 90 void RemoveFromList(); |
78 void UpdateFilters(); | 91 void UpdateFilters(); |
| 92 bool IsUpdating(); |
| 93 bool operator==(const Subscription& subscription) const; |
79 | 94 |
| 95 #if FILTER_ENGINE_STUBS |
80 private: | 96 private: |
81 #if FILTER_ENGINE_STUBS | 97 friend class FilterEngine; |
82 Subscription(FilterEngine& filterEngine, const std::string& url); | 98 Subscription(FilterEngine& filterEngine, const std::string& url); |
83 #else | 99 #else |
84 Subscription(); | 100 Subscription(JsValuePtr value); |
85 #endif | 101 #endif |
86 }; | 102 }; |
87 | 103 |
88 typedef std::tr1::shared_ptr<Filter> FilterPtr; | 104 typedef std::tr1::shared_ptr<Filter> FilterPtr; |
89 typedef std::tr1::shared_ptr<Subscription> SubscriptionPtr; | 105 typedef std::tr1::shared_ptr<Subscription> SubscriptionPtr; |
90 typedef void (*SubscriptionsCallback)(const std::vector<SubscriptionPtr>&); | 106 typedef void (*SubscriptionsCallback)(const std::vector<SubscriptionPtr>&); |
91 | 107 |
92 class FilterEngine | 108 class FilterEngine |
93 { | 109 { |
| 110 #if FILTER_ENGINE_STUBS |
94 friend class Filter; | 111 friend class Filter; |
95 friend class Subscription; | 112 friend class Subscription; |
| 113 #endif |
| 114 |
96 public: | 115 public: |
97 explicit FilterEngine(JsEngine& jsEngine); | 116 explicit FilterEngine(JsEngine& jsEngine); |
98 FilterPtr GetFilter(const std::string& text); | 117 FilterPtr GetFilter(const std::string& text); |
99 SubscriptionPtr GetSubscription(const std::string& url); | 118 SubscriptionPtr GetSubscription(const std::string& url); |
100 const std::vector<FilterPtr>& GetListedFilters() const; | 119 const std::vector<FilterPtr> GetListedFilters() const; |
101 const std::vector<SubscriptionPtr>& GetListedSubscriptions() const; | 120 const std::vector<SubscriptionPtr> GetListedSubscriptions() const; |
102 void FetchAvailableSubscriptions(SubscriptionsCallback callback); | 121 void FetchAvailableSubscriptions(SubscriptionsCallback callback); |
103 FilterPtr Matches(const std::string& url, | 122 FilterPtr Matches(const std::string& url, |
104 const std::string& contentType, | 123 const std::string& contentType, |
105 const std::string& documentUrl); | 124 const std::string& documentUrl); |
106 std::vector<std::string> GetElementHidingSelectors(const std::string& domain
) const; | 125 std::vector<std::string> GetElementHidingSelectors(const std::string& domain
) const; |
107 | 126 |
108 private: | 127 private: |
109 JsEngine& jsEngine; | 128 JsEngine& jsEngine; |
110 #if FILTER_ENGINE_STUBS | 129 #if FILTER_ENGINE_STUBS |
111 std::map<std::string, FilterPtr> knownFilters; | 130 std::map<std::string, FilterPtr> knownFilters; |
112 std::vector<FilterPtr> listedFilters; | 131 std::vector<FilterPtr> listedFilters; |
113 std::map<std::string, SubscriptionPtr> knownSubscriptions; | 132 std::map<std::string, SubscriptionPtr> knownSubscriptions; |
114 std::vector<SubscriptionPtr> listedSubscriptions; | 133 std::vector<SubscriptionPtr> listedSubscriptions; |
115 #endif | 134 #endif |
116 }; | 135 }; |
117 } | 136 } |
118 | 137 |
119 #endif | 138 #endif |
OLD | NEW |