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

Side by Side Diff: compiled/bindings/main.cpp

Issue 29556737: Issue 5141 - Convert filter match to C++ (Closed) Base URL: https://hg.adblockplus.org/adblockpluscore/
Patch Set: Some more cleanup Created Sept. 29, 2017, 4:12 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * This file is part of Adblock Plus <https://adblockplus.org/>, 2 * This file is part of Adblock Plus <https://adblockplus.org/>,
3 * Copyright (C) 2006-present eyeo GmbH 3 * Copyright (C) 2006-present eyeo GmbH
4 * 4 *
5 * Adblock Plus is free software: you can redistribute it and/or modify 5 * Adblock Plus is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 3 as 6 * it under the terms of the GNU General Public License version 3 as
7 * published by the Free Software Foundation. 7 * published by the Free Software Foundation.
8 * 8 *
9 * Adblock Plus is distributed in the hope that it will be useful, 9 * Adblock Plus is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
(...skipping 16 matching lines...) Expand all
27 #include "../filter/BlockingFilter.h" 27 #include "../filter/BlockingFilter.h"
28 #include "../filter/WhitelistFilter.h" 28 #include "../filter/WhitelistFilter.h"
29 #include "../filter/ElemHideBase.h" 29 #include "../filter/ElemHideBase.h"
30 #include "../filter/ElemHideFilter.h" 30 #include "../filter/ElemHideFilter.h"
31 #include "../filter/ElemHideException.h" 31 #include "../filter/ElemHideException.h"
32 #include "../filter/ElemHideEmulationFilter.h" 32 #include "../filter/ElemHideEmulationFilter.h"
33 #include "../subscription/Subscription.h" 33 #include "../subscription/Subscription.h"
34 #include "../subscription/DownloadableSubscription.h" 34 #include "../subscription/DownloadableSubscription.h"
35 #include "../subscription/UserDefinedSubscription.h" 35 #include "../subscription/UserDefinedSubscription.h"
36 #include "../storage/FilterStorage.h" 36 #include "../storage/FilterStorage.h"
37 #include "../filter/Matcher.h"
37 #include "../FilterNotifier.h" 38 #include "../FilterNotifier.h"
38 39
39 int main() 40 int main()
40 { 41 {
41 try 42 try
42 { 43 {
43 class_<Filter>("Filter") 44 class_<Filter>("Filter")
44 .property("text", &Filter::GetText) 45 .property("text", &Filter::GetText)
45 .function("serialize", &Filter::Serialize) 46 .function("serialize", &Filter::Serialize)
46 .class_function("fromText", &Filter::FromText) 47 .class_function("fromText", &Filter::FromText)
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after
124 .property("softExpiration", &DownloadableSubscription::GetSoftExpiration , &DownloadableSubscription::SetSoftExpiration) 125 .property("softExpiration", &DownloadableSubscription::GetSoftExpiration , &DownloadableSubscription::SetSoftExpiration)
125 .property("lastDownload", &DownloadableSubscription::GetLastDownload, &D ownloadableSubscription::SetLastDownload) 126 .property("lastDownload", &DownloadableSubscription::GetLastDownload, &D ownloadableSubscription::SetLastDownload)
126 .property("downloadStatus", &DownloadableSubscription::GetDownloadStatus , &DownloadableSubscription::SetDownloadStatus) 127 .property("downloadStatus", &DownloadableSubscription::GetDownloadStatus , &DownloadableSubscription::SetDownloadStatus)
127 .property("lastSuccess", &DownloadableSubscription::GetLastSuccess, &Dow nloadableSubscription::SetLastSuccess) 128 .property("lastSuccess", &DownloadableSubscription::GetLastSuccess, &Dow nloadableSubscription::SetLastSuccess)
128 .property("errors", &DownloadableSubscription::GetErrorCount, &Downloada bleSubscription::SetErrorCount) 129 .property("errors", &DownloadableSubscription::GetErrorCount, &Downloada bleSubscription::SetErrorCount)
129 .property("version", &DownloadableSubscription::GetDataRevision, &Downlo adableSubscription::SetDataRevision) 130 .property("version", &DownloadableSubscription::GetDataRevision, &Downlo adableSubscription::SetDataRevision)
130 .property("requiredVersion", &DownloadableSubscription::GetRequiredVersi on, &DownloadableSubscription::SetRequiredVersion) 131 .property("requiredVersion", &DownloadableSubscription::GetRequiredVersi on, &DownloadableSubscription::SetRequiredVersion)
131 .property("downloadCount", &DownloadableSubscription::GetDownloadCount, &DownloadableSubscription::SetDownloadCount) 132 .property("downloadCount", &DownloadableSubscription::GetDownloadCount, &DownloadableSubscription::SetDownloadCount)
132 .function("serialize", &DownloadableSubscription::Serialize); 133 .function("serialize", &DownloadableSubscription::Serialize);
133 134
135 class_<ReMatchResults>("ReMatchResults")
136 .function("push", &ReMatchResults::push);
137
138 class_<CombinedMatcher>("CombinedMatcher")
139 .function("add", &CombinedMatcher::Add)
140 .function("remove", &CombinedMatcher::Remove)
141 .function("matchesAny", &CombinedMatcher::MatchesAny)
142 .function("clear", &CombinedMatcher::Clear)
143 .function("hasFilter", &CombinedMatcher::HasFilter)
144 .function("getKeywordForFilter", &CombinedMatcher::GetKeywordForFilter)
145 .function("findKeyword", &CombinedMatcher::FindKeyword);
hub 2017/09/29 16:17:35 the function bindings are mostly needed for the te
146
147 class_<Matcher>("Matcher")
148 .function("add", &Matcher::Add)
149 .function("remove", &Matcher::Remove)
150 .function("matchesAny", &Matcher::MatchesAny)
151 .function("clear", &Matcher::Clear)
152 .function("hasFilter", &Matcher::HasFilter)
153 .function("getKeywordForFilter", &Matcher::GetKeywordForFilter)
154 .function("findKeyword", &Matcher::FindKeyword);
155
134 singleton<FilterStorage>("FilterStorage", &FilterStorage::GetInstance) 156 singleton<FilterStorage>("FilterStorage", &FilterStorage::GetInstance)
135 .property("subscriptionCount", &FilterStorage::GetSubscriptionCount) 157 .property("subscriptionCount", &FilterStorage::GetSubscriptionCount)
136 .function("subscriptionAt", &FilterStorage::SubscriptionAt) 158 .function("subscriptionAt", &FilterStorage::SubscriptionAt)
137 .function("indexOfSubscription", &FilterStorage::IndexOfSubscription) 159 .function("indexOfSubscription", &FilterStorage::IndexOfSubscription)
138 .function("getSubscriptionForFilter", &FilterStorage::GetSubscriptionFor Filter) 160 .function("getSubscriptionForFilter", &FilterStorage::GetSubscriptionFor Filter)
139 .function("addSubscription", &FilterStorage::AddSubscription) 161 .function("addSubscription", &FilterStorage::AddSubscription)
140 .function("removeSubscription", &FilterStorage::RemoveSubscription) 162 .function("removeSubscription", &FilterStorage::RemoveSubscription)
141 .function("moveSubscription", &FilterStorage::MoveSubscription); 163 .function("moveSubscription", &FilterStorage::MoveSubscription);
142 164
143 printBindings(); 165 printBindings();
144 RegExpFilter::GenerateCustomBindings(); 166 RegExpFilter::GenerateCustomBindings();
145 FilterNotifier::GenerateCustomBindings(); 167 FilterNotifier::GenerateCustomBindings();
146 168
147 return 0; 169 return 0;
148 } 170 }
149 catch (const std::exception& e) 171 catch (const std::exception& e)
150 { 172 {
151 EM_ASM_ARGS( 173 EM_ASM_ARGS(
152 console.error("Error occurred generating JavaScript bindings: " + 174 console.error("Error occurred generating JavaScript bindings: " +
153 Module.AsciiToString($0)), e.what() 175 Module.AsciiToString($0)), e.what()
154 ); 176 );
155 return 1; 177 return 1;
156 } 178 }
157 } 179 }
OLDNEW

Powered by Google App Engine
This is Rietveld