Index: src/engine/Main.cpp |
=================================================================== |
--- a/src/engine/Main.cpp |
+++ b/src/engine/Main.cpp |
@@ -114,13 +114,43 @@ |
std::string url; |
request >> url; |
+ AdblockPlus::JsValuePtr valuePtr = filterEngine->GetPref("subscriptions_exceptionsurl"); |
+ std::string aaUrl = ""; |
+ if (valuePtr->IsString()) |
+ { |
+ aaUrl = valuePtr->AsString(); |
+ } |
Eric
2014/06/25 14:34:15
Why the partial type enforcement? Is there any rea
Felix Dahlke
2014/06/30 17:24:04
I guess this is because the pref could be missing,
|
std::vector<AdblockPlus::SubscriptionPtr> subscriptions = filterEngine->GetListedSubscriptions(); |
+ |
+ // Remove all subscriptions, besides the Acceptable Ads |
Felix Dahlke
2014/06/30 17:24:04
Wow, this is hacky. So we currently only support e
Oleksandr
2014/07/18 19:06:42
https://issues.adblockplus.org/ticket/1084
On 2014
|
for (size_t i = 0, count = subscriptions.size(); i < count; i++) |
- subscriptions[i]->RemoveFromList(); |
+ { |
+ if (subscriptions[i].get()->GetProperty("url")->AsString() != aaUrl) |
Felix Dahlke
2014/06/30 17:24:04
Are you sure the .get() is required here? That sho
|
+ { |
+ subscriptions[i]->RemoveFromList(); |
+ } |
+ } |
+ |
+ // Add new subscription |
Felix Dahlke
2014/06/30 17:24:04
Kinda obvious IMHO :P
|
+ filterEngine->GetSubscription(url)->AddToList(); |
+ break; |
+ } |
+ case Communication::PROC_ADD_SUBSCRIPTION: |
+ { |
+ std::string url; |
+ request >> url; |
filterEngine->GetSubscription(url)->AddToList(); |
break; |
} |
+ case Communication::PROC_REMOVE_SUBSCRIPTION: |
+ { |
+ std::string url; |
+ request >> url; |
+ |
+ filterEngine->GetSubscription(url)->RemoveFromList(); |
+ break; |
+ } |
case Communication::PROC_UPDATE_ALL_SUBSCRIPTIONS: |
{ |
std::vector<AdblockPlus::SubscriptionPtr> subscriptions = filterEngine->GetListedSubscriptions(); |