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

Side by Side Diff: compiled/filter/ElemHideBase.h

Issue 29595633: Issue 5870 - Implement the new ElemHideEmulation filter type (Closed) Base URL: https://hg.adblockplus.org/adblockpluscore/
Patch Set: Refactor consts Created Feb. 1, 2018, 11:30 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
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details. 12 * GNU General Public License for more details.
13 * 13 *
14 * You should have received a copy of the GNU General Public License 14 * You should have received a copy of the GNU General Public License
15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
16 */ 16 */
17 17
18 #pragma once 18 #pragma once
19 19
20 #include <cstddef> 20 #include <cstddef>
21 21
22 #include "ActiveFilter.h" 22 #include "ActiveFilter.h"
23 #include "../bindings/runtime.h" 23 #include "../bindings/runtime.h"
24 24
25 struct ElemHideData 25 struct ElemHideData
26 { 26 {
27 String::size_type mDomainsEnd; 27 String::size_type mDomainsEnd;
28 String::size_type mSelectorStart; 28 String::size_type mSelectorStart;
29 bool mNeedConversion;
sergei 2018/02/05 14:51:06 Do we really need this member for each instance of
hub 2018/02/07 04:13:37 I can move mNeedConversion out of this and pass it
29 30
30 bool HasDomains() const 31 bool HasDomains() const
31 { 32 {
32 return mDomainsEnd != 0; 33 return mDomainsEnd != 0;
33 } 34 }
34 35
35 DependentString GetDomainsSource(String& text) const 36 DependentString GetDomainsSource(String& text) const
36 { 37 {
37 return DependentString(text, 0, mDomainsEnd); 38 return DependentString(text, 0, mDomainsEnd);
38 } 39 }
(...skipping 15 matching lines...) Expand all
54 }; 55 };
55 56
56 class ElemHideBase : public ActiveFilter 57 class ElemHideBase : public ActiveFilter
57 { 58 {
58 protected: 59 protected:
59 ElemHideData mData; 60 ElemHideData mData;
60 public: 61 public:
61 static constexpr Type classType = Type::ELEMHIDEBASE; 62 static constexpr Type classType = Type::ELEMHIDEBASE;
62 explicit ElemHideBase(Type type, const String& text, const ElemHideData& data) ; 63 explicit ElemHideBase(Type type, const String& text, const ElemHideData& data) ;
63 static Type Parse(DependentString& text, ElemHideData& data); 64 static Type Parse(DependentString& text, ElemHideData& data);
65 static OwnedString ConvertFilter(const String& text, String::size_type& at);
64 66
65 OwnedString BINDINGS_EXPORTED GetSelector() const; 67 OwnedString BINDINGS_EXPORTED GetSelector() const;
66 OwnedString BINDINGS_EXPORTED GetSelectorDomain() const; 68 OwnedString BINDINGS_EXPORTED GetSelectorDomain() const;
67 }; 69 };
68 70
69 typedef intrusive_ptr<ElemHideBase> ElemHideBasePtr; 71 typedef intrusive_ptr<ElemHideBase> ElemHideBasePtr;
OLDNEW

Powered by Google App Engine
This is Rietveld