Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(416)

Side by Side Diff: chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h

Issue 11569007: Refactoring how conditions without URL attributes are handled. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Polished 1st version Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_
6 #define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_ 6 #define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
42 42
43 // Factory method that instantiates a WebRequestCondition according to 43 // Factory method that instantiates a WebRequestCondition according to
44 // the description |condition| passed by the extension API. 44 // the description |condition| passed by the extension API.
45 static scoped_ptr<WebRequestCondition> Create( 45 static scoped_ptr<WebRequestCondition> Create(
46 URLMatcherConditionFactory* url_matcher_condition_factory, 46 URLMatcherConditionFactory* url_matcher_condition_factory,
47 const base::Value& condition, 47 const base::Value& condition,
48 std::string* error); 48 std::string* error);
49 49
50 // Returns whether the request is a match, given that the URLMatcher found 50 // Returns whether the request is a match, given that the URLMatcher found
51 // a match for |url_matcher_conditions_|. 51 // a match for |url_matcher_conditions_|.
52 bool IsFulfilled(const WebRequestRule::RequestData& request_data) const; 52 bool IsFulfilled(const WebRequestRule::RequestData& request_data) const;
battre 2012/12/18 08:20:44 nit: can you add a new line here, please?
vabr (Chromium) 2012/12/18 18:26:42 Done.
53 // Returns true iff the request is a match and no condition attribute of this
54 // condition is a UrlFilter.
55 bool IsFulfilledIndependentlyOfURL(
56 const WebRequestRule::RequestData& request_data) const;
53 57
54 // Returns a URLMatcherConditionSet::ID which is the canonical representation 58 // Returns a URLMatcherConditionSet::ID which is the canonical representation
55 // for all URL patterns that need to be matched by this WebRequestCondition. 59 // for all URL patterns that need to be matched by this WebRequestCondition.
56 // This ID is registered in a URLMatcher that can inform us in case of a 60 // This ID is registered in a URLMatcher that can inform us in case of a
57 // match. 61 // match.
58 URLMatcherConditionSet::ID url_matcher_condition_set_id() const { 62 URLMatcherConditionSet::ID url_matcher_condition_set_id() const {
63 CHECK(url_matcher_conditions_.get());
vabr (Chromium) 2012/12/13 12:18:06 This check is needed because now it is possible to
Jeffrey Yasskin 2012/12/18 02:24:32 I believe Chrome convention is to DCHECK in this c
vabr (Chromium) 2012/12/18 18:26:42 TIL, thanks! Done.
59 return url_matcher_conditions_->id(); 64 return url_matcher_conditions_->id();
60 } 65 }
61 66
62 // Returns the set of conditions that are checked on the URL. This is the 67 // Returns the set of conditions that are checked on the URL. This is the
63 // primary trigger for WebRequestCondition and therefore never empty. 68 // primary trigger for WebRequestCondition and therefore never empty.
64 // (If it was empty, the URLMatcher would never notify us about network 69 // (If it was empty, the URLMatcher would never notify us about network
65 // requests which might fulfill the entire WebRequestCondition). 70 // requests which might fulfill the entire WebRequestCondition).
66 scoped_refptr<URLMatcherConditionSet> url_matcher_condition_set() const { 71 scoped_refptr<URLMatcherConditionSet> url_matcher_condition_set() const {
67 return url_matcher_conditions_; 72 return url_matcher_conditions_;
68 } 73 }
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
113 118
114 // Returns whether any condition in the condition set is fulfilled 119 // Returns whether any condition in the condition set is fulfilled
115 // based on a match |url_match| and the value of |request_data.request|. 120 // based on a match |url_match| and the value of |request_data.request|.
116 // This function should be called for each URLMatcherConditionSet::ID 121 // This function should be called for each URLMatcherConditionSet::ID
117 // that was found by the URLMatcher to ensure that the each trigger in 122 // that was found by the URLMatcher to ensure that the each trigger in
118 // |match_triggers_| is found. 123 // |match_triggers_| is found.
119 bool IsFulfilled( 124 bool IsFulfilled(
120 URLMatcherConditionSet::ID url_match, 125 URLMatcherConditionSet::ID url_match,
121 const WebRequestRule::RequestData& request_data) const; 126 const WebRequestRule::RequestData& request_data) const;
122 127
128 // Returns whether any condition in the condition set is fulfilled even when
129 // no URL match has been triggered. Same as |IsFulfilled|, but only
130 // considering conditions which don't have UrlFilter attributes.
131 bool IsFulfilledWithoutURLMatcher(
132 const WebRequestRule::RequestData& request_data) const;
133
123 // Appends the URLMatcherConditionSet from all conditions to |condition_sets|. 134 // Appends the URLMatcherConditionSet from all conditions to |condition_sets|.
124 void GetURLMatcherConditionSets( 135 void GetURLMatcherConditionSets(
125 URLMatcherConditionSet::Vector* condition_sets) const; 136 URLMatcherConditionSet::Vector* condition_sets) const;
126 137
138 // Returns whether there are some conditions without UrlFilter attributes.
139 bool has_untriggered_conditions() const {
Jeffrey Yasskin 2012/12/18 02:24:32 "untriggered" isn't a great word for this. Perhaps
vabr (Chromium) 2012/12/18 18:26:42 Done.
140 return has_untriggered_conditions_;
141 }
142
127 private: 143 private:
128 Conditions conditions_;
129
130 typedef std::map<URLMatcherConditionSet::ID, WebRequestCondition*> 144 typedef std::map<URLMatcherConditionSet::ID, WebRequestCondition*>
vabr (Chromium) 2012/12/13 12:18:06 Typedefs should be before variables, so I reshuffl
131 MatchTriggers; 145 MatchTriggers;
146
147 // Returns whether there is a condition among |conditions| which has no
148 // URLMatcherConditionSet assigned.
149 static bool IsSomeConditionWithoutUrlMatcher(
battre 2012/12/18 08:20:44 nit: ContainsConditionWithoutUrlMatcher?
vabr (Chromium) 2012/12/18 18:26:42 Already changed due to Jeffrey's comment (HasCondi
150 const WebRequestConditionSet::Conditions& conditions);
151
132 MatchTriggers match_triggers_; 152 MatchTriggers match_triggers_;
133 153
154 const Conditions conditions_;
155 const bool has_untriggered_conditions_;
156
134 DISALLOW_COPY_AND_ASSIGN(WebRequestConditionSet); 157 DISALLOW_COPY_AND_ASSIGN(WebRequestConditionSet);
135 }; 158 };
136 159
137 } // namespace extensions 160 } // namespace extensions
138 161
139 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI TION_H_ 162 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI TION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698