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: How with CSS property filters Created Jan. 20, 2016, 1:12 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,30 @@
+#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;\
+ std::u16string action(u"filter." #name);\
+ FilterPtr filter = shared_from_this();\
+ EM_ASM_ARGS({\
+ var pointerToFilter = require("filterClasses").pointerToFilter;\
+ var filter = pointerToFilter($1);\
+ FilterNotifier.triggerListeners(getStringData($0), filter, $2, $3);\
+ }, &action, &filter, 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