Index: chrome/common/extensions/event_filter.h |
diff --git a/chrome/common/extensions/event_filter.h b/chrome/common/extensions/event_filter.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..26acb4420adf2e433fe49dff38e77c15a9538dd8 |
--- /dev/null |
+++ b/chrome/common/extensions/event_filter.h |
@@ -0,0 +1,119 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_COMMON_EXTENSIONS_EVENT_FILTER_H_ |
+#define CHROME_COMMON_EXTENSIONS_EVENT_FILTER_H_ |
+#pragma once |
+ |
+#include "base/memory/linked_ptr.h" |
+#include "chrome/common/extensions/event_matcher.h" |
+#include "chrome/common/extensions/event_filtering_info.h" |
+#include "chrome/common/extensions/matcher/url_matcher.h" |
+ |
+#include <map> |
+#include <set> |
+ |
+namespace extensions { |
+ |
+// Matches incoming events against a collection of EventMatchers. Each added |
+// EventMatcher is given an id which is returned by MatchEvent() when it is |
+// passed a matching event. |
+class EventFilter { |
+ public: |
+ typedef int MatcherID; |
+ EventFilter(); |
+ ~EventFilter(); |
+ |
+ // Adds an event matcher that will be used in calls to MatchEvent(). Returns |
+ // the id of the matcher, or -1 if there was an error. |
+ MatcherID AddEventMatcher(const std::string& event_name, |
+ scoped_ptr<EventMatcher> matcher); |
+ // Removes an event matcher, returning the name of the event that it was for. |
+ std::string RemoveEventMatcher(MatcherID id); |
+ |
+ // Match an event named |event_name| with filtering info |event_info| against |
+ // our set of event matchers. Returns a set of ids that correspond to the |
+ // event matchers that matched the event. |
+ // TODO(koz): Add a std::string* parameter for retrieving error messages. |
+ std::set<MatcherID> MatchEvent(const std::string& event_name, |
+ const EventFilteringInfo& event_info); |
+ |
+ int GetMatcherCountForEvent(const std::string& event_name); |
+ |
+ // For testing. |
+ bool IsURLMatcherEmpty() const { |
+ return url_matcher_.IsEmpty(); |
+ } |
+ |
+ private: |
+ class EventMatcherEntry { |
+ public: |
+ // Adds |condition_sets| to |url_matcher| on construction and removes them |
+ // again on destruction. |condition_sets| should be the |
+ // URLMatcherConditionSets that match the URL constraints specified by |
+ // |event_matcher|. |
+ EventMatcherEntry(scoped_ptr<EventMatcher> event_matcher, |
+ URLMatcher* url_matcher, |
+ const URLMatcherConditionSet::Vector& condition_sets); |
+ ~EventMatcherEntry(); |
+ |
+ // Prevents the removal of condition sets when this class is destroyed. We |
+ // call this in EventFilter's destructor so that we don't do the costly |
+ // removal of condition sets when the URLMatcher is going to be destroyed |
+ // and clean them up anyway. |
+ void DontRemoveConditionSetsInDestructor(); |
+ |
+ const EventMatcher& event_matcher() const { |
+ return *event_matcher_; |
+ } |
+ |
+ private: |
+ scoped_ptr<EventMatcher> event_matcher_; |
+ // The id sets in url_matcher_ that this EventMatcher owns. |
+ std::vector<URLMatcherConditionSet::ID> condition_set_ids_; |
+ URLMatcher* url_matcher_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(EventMatcherEntry); |
+ }; |
+ |
+ // Maps from a matcher id to an event matcher entry. |
+ typedef std::map<MatcherID, linked_ptr<EventMatcherEntry> > EventMatcherMap; |
+ |
+ // Maps from event name to the map of matchers that are registered for it. |
+ typedef std::map<std::string, EventMatcherMap> EventMatcherMultiMap; |
+ |
+ // Adds the list of filters to the URL matcher, having matches for those URLs |
+ // map to |id|. |
+ bool CreateConditionSets(MatcherID id, |
+ base::ListValue* url_filters, |
+ URLMatcherConditionSet::Vector* condition_sets); |
+ |
+ bool AddDictionaryAsConditionSet( |
+ base::DictionaryValue* url_filter, |
+ URLMatcherConditionSet::Vector* condition_sets); |
+ |
+ URLMatcher url_matcher_; |
+ EventMatcherMultiMap event_matchers_; |
+ |
+ // The next id to assign to an EventMatcher. |
+ MatcherID next_id_; |
+ |
+ // The next id to assign to a condition set passed to URLMatcher. |
+ URLMatcherConditionSet::ID next_condition_set_id_; |
+ |
+ // Maps condition set ids, which URLMatcher operates in, to event matcher |
+ // ids, which the interface to this class operates in. As each EventFilter |
+ // can specify many condition sets this is a many to one relationship. |
+ std::map<URLMatcherConditionSet::ID, MatcherID> |
+ condition_set_id_to_event_matcher_id_; |
+ |
+ // Maps from event matcher ids to the name of the event they match on. |
+ std::map<MatcherID, std::string> id_to_event_name_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(EventFilter); |
+}; |
+ |
+} // namespace extensions |
+ |
+#endif // CHROME_COMMON_EXTENSIONS_EVENT_FILTER_H_ |