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

Unified Diff: compiled/api.h

Issue 29333474: Issue 4125 - [emscripten] Convert filter classes to C++ (Closed)
Patch Set: Improved performance Created Jan. 28, 2016, 2:31 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 | « compiled/WhitelistFilter.cpp ('k') | compiled/api.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: compiled/api.h
===================================================================
new file mode 100644
--- /dev/null
+++ b/compiled/api.h
@@ -0,0 +1,29 @@
+#ifndef ADBLOCK_PLUS_TOOLS_H
+#define ADBLOCK_PLUS_TOOLS_H
+
+#include <emscripten.h>
+
+#define FILTER_PROPERTY(type, name, getter, setter) \
+ private:\
+ type name;\
+ public:\
+ type getter() const\
+ {\
+ return name;\
+ }\
+ void setter(type value)\
+ {\
+ if (name != value)\
+ {\
+ type oldvalue = name;\
+ name = value;\
+ String action(u"filter."_str #name);\
+ FilterPtr filter = shared_from_this();\
+ EM_ASM_ARGS({\
+ var filter = new (exports[Filter_mapping[$2]])($1);\
+ FilterNotifier.triggerListeners(getStringData($0), filter, $3, $4);\
+ }, &action, &filter, GetType(), value, oldvalue);\
+ }\
+ }
+
+#endif
« no previous file with comments | « compiled/WhitelistFilter.cpp ('k') | compiled/api.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld