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

Unified Diff: compiled/ActiveFilter.h

Issue 29333474: Issue 4125 - [emscripten] Convert filter classes to C++ (Closed)
Patch Set: Addressed Sergei`s comments again and added some asserts Created Feb. 23, 2016, 12:30 p.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « compile ('k') | compiled/ActiveFilter.cpp » ('j') | compiled/RegExpFilter.cpp » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: compiled/ActiveFilter.h
===================================================================
new file mode 100644
--- /dev/null
+++ b/compiled/ActiveFilter.h
@@ -0,0 +1,54 @@
+#pragma once
+
+#include <emscripten.h>
+
+#include "Filter.h"
+#include "StringMap.h"
+
+#define FILTER_PROPERTY(type, name, getter, setter) \
+ private:\
+ type name;\
+ public:\
+ type EMSCRIPTEN_KEEPALIVE getter() const\
+ {\
+ return name;\
+ }\
+ void EMSCRIPTEN_KEEPALIVE setter(type value)\
+ {\
+ if (name != value)\
+ {\
+ type oldvalue = name;\
+ name = value;\
+ DependentString action(u"filter."_str #name);\
+ EM_ASM_ARGS({\
+ var filter = new (exports[Filter_mapping[$2]])($1);\
+ FilterNotifier.triggerListeners(getStringData($0), filter, $3, $4);\
+ }, &action, this, GetType(), value, oldvalue);\
+ }\
+ }
+
+class ActiveFilter : public Filter
+{
+protected:
+ typedef StringMap<bool> DomainMap;
+ typedef StringSet SitekeySet;
+ void ParseDomains(const String& domains, String::value_type separator) const;
+ void AddSitekey(const String& sitekey) const;
+ virtual DomainMap* GetDomains() const;
+ virtual SitekeySet* GetSitekeys() const;
+ mutable std::unique_ptr<DomainMap> mDomains;
+ mutable std::unique_ptr<SitekeySet> mSitekeys;
+private:
+ bool mIgnoreTrailingDot;
+public:
+ ActiveFilter(const String& text, bool ignoreTrailingDot);
+ FILTER_PROPERTY(bool, mDisabled, GetDisabled, SetDisabled);
+ FILTER_PROPERTY(unsigned int, mHitCount, GetHitCount, SetHitCount);
+ FILTER_PROPERTY(unsigned int, mLastHit, GetLastHit, SetLastHit);
+ static void ToLower(DependentString&& str);
+ bool EMSCRIPTEN_KEEPALIVE IsActiveOnDomain(DependentString& docDomain,
+ const String& sitekey) const;
+ bool EMSCRIPTEN_KEEPALIVE IsActiveOnlyOnDomain(DependentString& docDomain) const;
+ bool EMSCRIPTEN_KEEPALIVE IsGeneric() const;
+ OwnedString EMSCRIPTEN_KEEPALIVE Serialize() const;
+};
« no previous file with comments | « compile ('k') | compiled/ActiveFilter.cpp » ('j') | compiled/RegExpFilter.cpp » ('J')

Powered by Google App Engine
This is Rietveld