| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <http://adblockplus.org/>, | 2 * This file is part of Adblock Plus <http://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2014 Eyeo GmbH | 3 * Copyright (C) 2006-2014 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 19 matching lines...) Expand all Loading... | |
| 30 * Stores a mapping between URLs and their referrers. | 30 * Stores a mapping between URLs and their referrers. |
| 31 * This can be used to build a frame structure for any URL | 31 * This can be used to build a frame structure for any URL |
| 32 * (see `BuildFrameStructure()`), it's useful for FilterEngine::Matches(). | 32 * (see `BuildFrameStructure()`), it's useful for FilterEngine::Matches(). |
| 33 */ | 33 */ |
| 34 class ReferrerMapping | 34 class ReferrerMapping |
| 35 { | 35 { |
| 36 public: | 36 public: |
| 37 /// The type for URL. | 37 /// The type for URL. |
| 38 typedef std::string Url; | 38 typedef std::string Url; |
| 39 | 39 |
| 40 /// Contains the ordered list of URLs. | 40 /// Contains an ordered list of URLs. |
|
Wladimir Palant
2014/12/09 21:20:03
Nit: *an* ordered list
| |
| 41 typedef std::vector<Url> Urls; | 41 typedef std::vector<Url> Urls; |
| 42 | 42 |
| 43 /// Indicates whether the URL is a frame or not. | 43 /// Indicates whether the URL is a frame or not. |
| 44 enum FrameIndicator | 44 enum FrameIndicator |
| 45 { | 45 { |
| 46 FRAME_INDICATOR_NOT_A_FRAME = 0, FRAME_INDICATOR_FRAME= 1 | 46 FRAME_INDICATOR_NOT_FRAME = 0, FRAME_INDICATOR_FRAME = 1 |
|
Wladimir Palant
2014/12/09 21:20:03
Extreme nit: articles seem wrong in constant names
sergei
2014/12/12 17:07:07
I know, I thought about it but don't remember the
| |
| 47 }; | 47 }; |
| 48 /** | 48 /** |
| 49 * Constructor. | 49 * Constructor. |
| 50 * @param maxCachedUrls Number of URL mappings to store. The higher the | 50 * @param maxCachedUrls Number of URL mappings to store. The higher the |
| 51 * better - clients typically cache requests, and a single cached | 51 * better - clients typically cache requests, and a single cached |
| 52 * request will break the referrer chain. | 52 * request will break the referrer chain. |
| 53 */ | 53 */ |
| 54 ReferrerMapping(const int maxCachedUrls = 5000); | 54 ReferrerMapping(const int maxCachedUrls = 5000); |
| 55 | 55 |
| 56 /** | 56 /** |
| 57 * Records the refferer for a URL. | 57 * Records the refferer for a URL. |
| 58 * @param url Request URL. | 58 * @param url Request URL. |
| 59 * @param referrer Request referrer. | 59 * @param referrer Request referrer. |
| 60 * @param isFrame Indicates whether the url is a frame. | 60 * @param isFrame Indicates whether the url is a frame. |
| 61 */ | 61 */ |
| 62 void Add(const Url& url, const Url& referrer, FrameIndicator isFrame); | 62 void Add(const Url& url, const Url& referrer, FrameIndicator isFrame); |
| 63 | 63 |
| 64 /** | 64 /** |
| 65 * Builds a frame structure for the supplied URL. | 65 * Builds a frame structure for the supplied URL. |
| 66 * This should reconstruct a document's parent frame URLs. | 66 * This should reconstruct a document's parent frame URLs. |
| 67 * @param url URL to build the chain for. | 67 * @param url URL to build the chain for, it is referrer as well. |
| 68 * @return List of URLs, finishing with `url`. | 68 * @return List of URLs, finishing with `url`. |
| 69 */ | 69 */ |
| 70 Urls BuildFrameStructure(const Url& url) const; | 70 Urls BuildFrameStructure(const Url& url) const; |
| 71 | 71 |
| 72 private: | 72 private: |
| 73 const int maxCachedUrls; | 73 const int maxCachedUrls; |
| 74 struct RequestInfo | 74 struct RequestInfo |
| 75 { | 75 { |
| 76 explicit RequestInfo(const Url& referrerArg = Url(), | 76 explicit RequestInfo(const Url& referrerArg = Url(), |
| 77 FrameIndicator frameIndicatorArg = FrameIndicator::FRAME_INDICATOR_NOT_A _FRAME) | 77 FrameIndicator frameIndicatorArg = FrameIndicator::FRAME_INDICATOR_NOT_F RAME) |
|
Wladimir Palant
2014/12/09 21:20:03
Shouldn't you have that default value in method Ad
sergei
2014/12/12 17:07:07
These default arguments are required by std::map,
| |
| 78 : referrer(referrerArg), frameIndicator(frameIndicatorArg) | 78 : referrer(referrerArg), frameIndicator(frameIndicatorArg) |
| 79 { | 79 { |
| 80 } | 80 } |
| 81 bool IsFrame() const | 81 bool IsFrame() const |
| 82 { | 82 { |
| 83 return frameIndicator == FrameIndicator::FRAME_INDICATOR_FRAME; | 83 return frameIndicator == FrameIndicator::FRAME_INDICATOR_FRAME; |
| 84 } | 84 } |
| 85 Url referrer; | 85 Url referrer; |
| 86 FrameIndicator frameIndicator; | 86 FrameIndicator frameIndicator; |
| 87 }; | 87 }; |
| 88 typedef std::map<Url, RequestInfo> ReferrerMap; | 88 typedef std::map<Url, RequestInfo> ReferrerMap; |
| 89 ReferrerMap mapping; | 89 ReferrerMap mapping; |
| 90 std::list<Url> cachedUrls; | 90 std::list<Url> cachedUrls; |
| 91 }; | 91 }; |
| 92 } | 92 } |
| 93 | 93 |
| 94 #endif | 94 #endif |
| LEFT | RIGHT |