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

Unified Diff: chrome/browser/chromeos/events/event_rewriter_controller.h

Issue 240173007: Convert KeyboardDrivenEventRewriter to a ui::EventRewriter. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Changed EventRewriterController, & addressed review comments. Created 6 years, 8 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/events/event_rewriter_controller.h
diff --git a/chrome/browser/chromeos/events/event_rewriter_controller.h b/chrome/browser/chromeos/events/event_rewriter_controller.h
new file mode 100644
index 0000000000000000000000000000000000000000..2884a021520e1b7172d500f2105c55ad62166762
--- /dev/null
+++ b/chrome/browser/chromeos/events/event_rewriter_controller.h
@@ -0,0 +1,64 @@
+// Copyright 2014 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_BROWSER_CHROMEOS_EVENTS_EVENT_REWRITER_CONTROLLER_H_
+#define CHROME_BROWSER_CHROMEOS_EVENTS_EVENT_REWRITER_CONTROLLER_H_
+
+#include <list>
+#include <vector>
+
+#include "base/memory/scoped_ptr.h"
+#include "base/memory/scoped_vector.h"
+#include "ui/aura/env_observer.h"
+#include "ui/events/event_rewriter.h"
+
+namespace ui {
+class EventSource;
+} // namespace ui
+
+namespace chromeos {
+
+// Owns |ui::EventRewriter|s and ensures that they are added to all root
+// windows |EventSource|s, current and future, in the order that they are
+// added to this.
kpschoedel 2014/04/22 19:53:08 Changed to have one EventRewriterController handle
+class EventRewriterController : public aura::EnvObserver {
+ public:
+ explicit EventRewriterController();
sadrul 2014/04/23 19:32:53 Don't need explicit
kpschoedel 2014/04/23 21:33:15 Done. (Previous version had 1 arg.)
+ virtual ~EventRewriterController();
+
+ // Takes ownership of an EventRewriter; can only be called before Init().
+ void AddEventRewriter(scoped_ptr<ui::EventRewriter> rewriter);
+
+ // Add rewriters to any existing root windows; must be called once only
+ // after ash::Shell has been initialized.
sadrul 2014/04/23 19:32:53 I am curious to know why this is necessary. Is it
kpschoedel 2014/04/23 21:33:15 Partly, but more to ensure that all rewriters have
+ void Init();
+
+ void Shutdown();
sadrul 2014/04/23 19:32:53 Document (Destroys and removes all event-rewriters
kpschoedel 2014/04/23 21:33:15 Done.
+
+ // aura::EnvObserver overrides:
+ virtual void OnWindowInitialized(aura::Window* window) OVERRIDE {}
+ virtual void OnHostInitialized(aura::WindowTreeHost* host) OVERRIDE;
+
+ private:
+ typedef std::list<ui::EventSource*> EventSourceList;
+ typedef ScopedVector<ui::EventRewriter> EventRewriters;
+
+ void AddToEventSource(ui::EventSource* source);
+
+ // The |EventRewriter|s managed by this controller.
+ EventRewriters rewriters_;
+
+ // Whether the owned event rewriters have been added to existing
+ // root windows; after this no more rewriters can be added.
+ bool initialized_;
+
+ // Whether the owned event rewriters get added to new root windows.
+ bool operational_;
+
+ DISALLOW_COPY_AND_ASSIGN(EventRewriterController);
+};
+
+} // namespace chromeos
+
+#endif // CHROME_BROWSER_CHROMEOS_EVENTS_EVENT_REWRITER_CONTROLLER_H_

Powered by Google App Engine
This is Rietveld 408576698