Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Delta Between Two Patch Sets: compiled/ActiveFilter.h

Issue 29333474: Issue 4125 - [emscripten] Convert filter classes to C++ (Closed)
Left Patch Set: Merged filter parsing and normalization Created Feb. 4, 2016, 3:01 p.m.
Right Patch Set: Addressed comments from Patch Set 28 Created March 21, 2017, 10:04 a.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
Left: Side by side diff | Download
Right: Side by side diff | Download
« no previous file with change/comment | « compile ('k') | compiled/ActiveFilter.cpp » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
1 #ifndef ADBLOCK_PLUS_ACTIVE_FILTER_H 1 #pragma once
2 #define ADBLOCK_PLUS_ACTIVE_FILTER_H
3 2
4 #include <emscripten.h> 3 #include <emscripten.h>
5 4
6 #include "Filter.h" 5 #include "Filter.h"
7 #include "StringMap.h" 6 #include "StringMap.h"
8 7
9 #define FILTER_PROPERTY(type, name, getter, setter) \ 8 #define FILTER_PROPERTY(type, name, getter, setter) \
10 private:\ 9 private:\
11 type name;\ 10 type name;\
12 public:\ 11 public:\
13 type EMSCRIPTEN_KEEPALIVE getter() const\ 12 type EMSCRIPTEN_KEEPALIVE getter() const\
14 {\ 13 {\
15 return name;\ 14 return name;\
16 }\ 15 }\
17 void EMSCRIPTEN_KEEPALIVE setter(type value)\ 16 void EMSCRIPTEN_KEEPALIVE setter(type value)\
18 {\ 17 {\
19 if (name != value)\ 18 if (name != value)\
20 {\ 19 {\
21 type oldvalue = name;\ 20 type oldvalue = name;\
22 name = value;\ 21 name = value;\
23 String action(u"filter."_str #name);\ 22 DependentString action(u"filter."_str #name);\
24 EM_ASM_ARGS({\ 23 EM_ASM_ARGS({\
25 var filter = new (exports[Filter_mapping[$2]])($1);\ 24 var filter = new (exports[Filter_mapping[$2]])($1);\
26 FilterNotifier.triggerListeners(getStringData($0), filter, $3, $4);\ 25 FilterNotifier.triggerListeners(readString($0), filter, $3, $4);\
27 }, &action, this, GetType(), value, oldvalue);\ 26 }, &action, this, mType, value, oldvalue);\
28 }\ 27 }\
29 } 28 }
30 29
31 class ActiveFilter : public Filter 30 class ActiveFilter : public Filter
32 { 31 {
33 protected: 32 protected:
34 typedef StringMap<bool> DomainMap; 33 typedef StringMap<bool> DomainMap;
35 typedef StringSet SitekeySet; 34 typedef StringSet SitekeySet;
36 static void ToLower(String& str, String::size_type start, 35 void ParseDomains(const String& domains, String::value_type separator) const;
37 String::size_type end);
38 void ParseDomains(const String& domains, char16_t separator) const;
39 void AddSitekey(const String& sitekey) const; 36 void AddSitekey(const String& sitekey) const;
40 virtual DomainMap* GetDomains() const; 37 virtual DomainMap* GetDomains() const;
41 virtual SitekeySet* GetSitekeys() const; 38 virtual SitekeySet* GetSitekeys() const;
42 mutable std::unique_ptr<DomainMap> mDomains; 39 mutable std::unique_ptr<DomainMap> mDomains;
43 mutable std::unique_ptr<SitekeySet> mSitekeys; 40 mutable std::unique_ptr<SitekeySet> mSitekeys;
44 private: 41 private:
45 bool mIgnoreTrailingDot; 42 bool mIgnoreTrailingDot;
46 public: 43 public:
47 ActiveFilter(const String& text, bool ignoreTrailingDot); 44 explicit ActiveFilter(Type type, const String& text, bool ignoreTrailingDot);
48 FILTER_PROPERTY(bool, mDisabled, GetDisabled, SetDisabled); 45 FILTER_PROPERTY(bool, mDisabled, GetDisabled, SetDisabled);
49 FILTER_PROPERTY(unsigned int, mHitCount, GetHitCount, SetHitCount); 46 FILTER_PROPERTY(unsigned int, mHitCount, GetHitCount, SetHitCount);
50 FILTER_PROPERTY(unsigned int, mLastHit, GetLastHit, SetLastHit); 47 FILTER_PROPERTY(unsigned int, mLastHit, GetLastHit, SetLastHit);
51 bool EMSCRIPTEN_KEEPALIVE IsActiveOnDomain(String& docDomain, 48 bool EMSCRIPTEN_KEEPALIVE IsActiveOnDomain(DependentString& docDomain,
52 const String& sitekey) const; 49 const String& sitekey) const;
53 bool EMSCRIPTEN_KEEPALIVE IsActiveOnlyOnDomain(String& docDomain) const; 50 bool EMSCRIPTEN_KEEPALIVE IsActiveOnlyOnDomain(DependentString& docDomain) con st;
54 bool EMSCRIPTEN_KEEPALIVE IsGeneric() const; 51 bool EMSCRIPTEN_KEEPALIVE IsGeneric() const;
55 String EMSCRIPTEN_KEEPALIVE Serialize() const; 52 OwnedString EMSCRIPTEN_KEEPALIVE Serialize() const;
56 }; 53 };
57
58 #endif
LEFTRIGHT

Powered by Google App Engine
This is Rietveld