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

Unified Diff: compiled/subscription/UserDefinedSubscription.cpp

Issue 29384812: Issue 4127 - [emscripten] Convert subscription classes to C++ - Part 1 (Closed) Base URL: https://hg.adblockplus.org/adblockpluscore
Patch Set: Addressed comments Created April 13, 2017, 1:02 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/subscription/UserDefinedSubscription.h ('k') | lib/subscriptionClasses.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: compiled/subscription/UserDefinedSubscription.cpp
===================================================================
new file mode 100644
--- /dev/null
+++ b/compiled/subscription/UserDefinedSubscription.cpp
@@ -0,0 +1,88 @@
+/*
+ * This file is part of Adblock Plus <https://adblockplus.org/>,
+ * Copyright (C) 2006-2017 eyeo GmbH
+ *
+ * Adblock Plus is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 3 as
+ * published by the Free Software Foundation.
+ *
+ * Adblock Plus is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <cstdlib>
+
+#include "UserDefinedSubscription.h"
+
+namespace
+{
+ enum FilterCategory
+ {
+ WHITELIST = 1,
+ BLOCKING = 2,
+ ELEMHIDE = 4,
+ };
+
+ const FilterCategory filterTypeToCategory[] = {
+ FilterCategory::BLOCKING, // UNKNOWN
+ FilterCategory::BLOCKING, // INVALID
+ FilterCategory::BLOCKING, // COMMENT
+ FilterCategory::BLOCKING, // BLOCKING
+ FilterCategory::WHITELIST, // WHITELIST
+ FilterCategory::ELEMHIDE, // ELEMHIDE
+ FilterCategory::ELEMHIDE, // ELEMHIDEEXCEPTION
+ FilterCategory::ELEMHIDE, // ELEMHIDEEMULATION
+ };
+
+ static_assert(
+ sizeof(filterTypeToCategory) / sizeof(filterTypeToCategory[0]) == Filter::Type::VALUE_COUNT,
+ "Unexpected number of filter types, was a new type added?"
+ );
+}
+
+UserDefinedSubscription::UserDefinedSubscription(const String& id)
+ : Subscription(Type::USERDEFINED, id), mDefaults(0)
+{
+}
+
+bool UserDefinedSubscription::IsDefaultFor(const Filter* filter) const
+{
+ if (filter->mType >= Filter::Type::VALUE_COUNT)
+ {
+ assert(false, "Filter type exceeds valid range");
+ abort();
+ }
+ return mDefaults & filterTypeToCategory[filter->mType];
+}
+
+void UserDefinedSubscription::MakeDefaultFor(const Filter* filter)
+{
+ if (filter->mType >= Filter::Type::VALUE_COUNT)
+ {
+ assert(false, "Filter type exceeds valid range");
+ abort();
+ }
+ mDefaults |= filterTypeToCategory[filter->mType];
+}
+
+OwnedString UserDefinedSubscription::Serialize() const
+{
+ OwnedString result(Subscription::Serialize());
+ if (mDefaults)
+ {
+ result.append(u"defaults="_str);
+ if (mDefaults & FilterCategory::BLOCKING)
+ result.append(u" blocking"_str);
+ if (mDefaults & FilterCategory::WHITELIST)
+ result.append(u" whitelist"_str);
+ if (mDefaults & FilterCategory::ELEMHIDE)
+ result.append(u" elemhide"_str);
+ result.append(u'\n');
+ }
+ return result;
+}
« no previous file with comments | « compiled/subscription/UserDefinedSubscription.h ('k') | lib/subscriptionClasses.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld