| Index: compiled/ElemHideEmulation.cpp |
| =================================================================== |
| new file mode 100644 |
| --- /dev/null |
| +++ b/compiled/ElemHideEmulation.cpp |
| @@ -0,0 +1,51 @@ |
| +/* |
| + * This file is part of Adblock Plus <https://adblockplus.org/>, |
| + * Copyright (C) 2006-present 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 "ElemHide.h" |
| +#include "ElemHideEmulation.h" |
| + |
| +ElemHideEmulation* ElemHideEmulation::mInstance = new ElemHideEmulation(); |
| + |
| +void ElemHideEmulation::Add(ElemHideBase& filter) |
| +{ |
| + mFilters[filter.GetText()] = ElemHideBasePtr(&filter); |
| +} |
| + |
| +void ElemHideEmulation::Remove(ElemHideBase& filter) |
| +{ |
| + mFilters.erase(filter.GetText()); |
| +} |
| + |
| +void ElemHideEmulation::Clear() |
| +{ |
| + mFilters.clear(); |
| +} |
| + |
| +ElemHideEmulation_FilterList* ElemHideEmulation::GetRulesForDomain(DependentString& domain) |
|
sergei
2018/01/25 16:04:00
Just a note: it should accept elemhide now
hub
2018/01/25 19:05:27
It is already done. I just didn't update the revie
|
| +{ |
| + intrusive_ptr<ElemHideEmulation_FilterList> result(new ElemHideEmulation_FilterList); |
|
sergei
2018/01/25 16:04:01
could you please add () to the constructor call?
hub
2018/01/25 19:05:27
Done.
|
| + for (auto filter: mFilters) |
|
sergei
2018/01/25 16:04:01
perhaps it would be better to call it filterEntry
hub
2018/01/25 19:05:27
entry like elsewhere.
Done.
|
| + { |
| + DependentString docDomain(domain); |
| + if (!filter.is_deleted() && |
| + filter.second->IsActiveOnDomain(docDomain, u""_str) && |
|
sergei
2018/01/25 16:04:01
what do you think about having Dereferenceable ite
hub
2018/01/25 19:05:27
filterEntry isn't an iterator, but the entry in th
|
| + !ElemHide::GetInstance()->GetException(*filter.second, domain)) |
| + result->push_back(filter.second); |
| + } |
| + |
| + return result.release(); |
| +} |