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

Unified Diff: services/window_manager/window_manager_root.h

Issue 1536713004: Revert "Delete the ViewManager and WindowManager services." (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « services/window_manager/window_manager_impl.cc ('k') | services/window_manager/window_manager_root.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/window_manager/window_manager_root.h
diff --git a/services/window_manager/window_manager_root.h b/services/window_manager/window_manager_root.h
new file mode 100644
index 0000000000000000000000000000000000000000..3b92420953f6eccd92cf105f3aa5f0aa3593c725
--- /dev/null
+++ b/services/window_manager/window_manager_root.h
@@ -0,0 +1,200 @@
+// Copyright 2015 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 SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_ROOT_H_
+#define SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_ROOT_H_
+
+#include "base/memory/scoped_ptr.h"
+#include "base/memory/scoped_vector.h"
+#include "mojo/public/cpp/application/application_delegate.h"
+#include "mojo/public/cpp/application/interface_factory_impl.h"
+#include "mojo/public/cpp/bindings/binding.h"
+#include "mojo/public/cpp/bindings/string.h"
+#include "mojo/services/view_manager/cpp/types.h"
+#include "mojo/services/view_manager/cpp/view_manager_client_factory.h"
+#include "mojo/services/view_manager/cpp/view_manager_delegate.h"
+#include "mojo/services/view_manager/cpp/view_observer.h"
+#include "mojo/services/window_manager/interfaces/window_manager_internal.mojom.h"
+#include "services/window_manager/capture_controller_observer.h"
+#include "services/window_manager/focus_controller_observer.h"
+#include "services/window_manager/native_viewport_event_dispatcher_impl.h"
+#include "services/window_manager/view_target.h"
+#include "services/window_manager/window_manager_delegate.h"
+#include "services/window_manager/window_manager_impl.h"
+#include "ui/base/accelerators/accelerator_manager.h"
+#include "ui/events/event_handler.h"
+
+namespace gfx {
+class Size;
+}
+
+namespace window_manager {
+
+class CaptureController;
+class FocusController;
+class FocusRules;
+class ViewEventDispatcher;
+class WindowManagerDelegate;
+class WindowManagerImpl;
+
+// Represents the root of a Mojo-managed window hierarchy. Each root has a
+// 1-to-1 link with a native platform window. WindowManagerRoot manages its own
+// lifetime.
+class WindowManagerRoot
+ : public mojo::ViewManagerDelegate,
+ public mojo::ViewObserver,
+ public ui::EventHandler,
+ public FocusControllerObserver,
+ public CaptureControllerObserver,
+ public mojo::InterfaceFactory<mojo::WindowManagerInternal>,
+ public mojo::InterfaceFactory<mojo::NativeViewportEventDispatcher>,
+ public mojo::WindowManagerInternal {
+ public:
+ WindowManagerRoot(mojo::ApplicationImpl* application_impl,
+ mojo::ApplicationConnection* connection,
+ WindowManagerControllerFactory* controller_factory,
+ mojo::InterfaceRequest<mojo::WindowManager> request);
+ ~WindowManagerRoot() override;
+
+ ViewEventDispatcher* event_dispatcher() {
+ return view_event_dispatcher_.get();
+ }
+
+ // Deregisters connections to the window manager service.
+ void RemoveConnectedService(WindowManagerImpl* service);
+
+ // These are canonical implementations of the window manager API methods.
+ bool SetCapture(mojo::Id view);
+ bool FocusWindow(mojo::Id view);
+ bool ActivateWindow(mojo::Id view);
+
+ void DispatchInputEventToView(mojo::View* view, mojo::EventPtr event);
+ void SetViewportSize(const gfx::Size& size);
+
+ bool IsReady() const;
+
+ FocusController* focus_controller() { return focus_controller_.get(); }
+ CaptureController* capture_controller() { return capture_controller_.get(); }
+
+ void InitFocus(scoped_ptr<FocusRules> rules);
+
+ ui::AcceleratorManager* accelerator_manager() {
+ return &accelerator_manager_;
+ }
+
+ // WindowManagerImpl::Embed() forwards to this. If connected to ViewManager
+ // then forwards to delegate, otherwise waits for connection to establish then
+ // forwards.
+ void Embed(const mojo::String& url,
+ mojo::InterfaceRequest<mojo::ServiceProvider> services,
+ mojo::ServiceProviderPtr exposed_services);
+
+ private:
+ typedef ScopedVector<WindowManagerImpl> ConnectedServices;
+ typedef std::set<mojo::Id> RegisteredViewIdSet;
+
+ void AddConnectedService(scoped_ptr<WindowManagerImpl> service);
+
+ struct PendingEmbed;
+ class WindowManagerInternalImpl;
+
+ mojo::ViewManager* view_manager() {
+ return root_ ? root_->view_manager() : nullptr;
+ }
+
+ bool SetCaptureImpl(mojo::View* view);
+ bool FocusWindowImpl(mojo::View* view);
+ bool ActivateWindowImpl(mojo::View* view);
+
+ ui::Accelerator ConvertEventToAccelerator(const ui::KeyEvent* event);
+
+ // Creates an ViewTarget for every view in the hierarchy beneath |view|,
+ // and adds to the registry so that it can be retrieved later via
+ // GetViewTargetForViewId().
+ // TODO(beng): perhaps View should have a property bag.
+ void RegisterSubtree(mojo::View* view);
+
+ // Recursively invokes Unregister() for |view| and all its descendants.
+ void UnregisterSubtree(mojo::View* view);
+
+ // Deletes the ViewTarget associated with the hierarchy beneath |id|,
+ // and removes from the registry.
+ void Unregister(mojo::View* view);
+
+ // Overridden from ViewManagerDelegate:
+ void OnEmbed(mojo::View* root,
+ mojo::InterfaceRequest<mojo::ServiceProvider> services,
+ mojo::ServiceProviderPtr exposed_services) override;
+ void OnViewManagerDisconnected(mojo::ViewManager* view_manager) override;
+ bool OnPerformAction(mojo::View* view, const std::string& action) override;
+
+ // Overridden from ViewObserver:
+ void OnTreeChanged(const ViewObserver::TreeChangeParams& params) override;
+ void OnViewDestroying(mojo::View* view) override;
+
+ // Overridden from ui::EventHandler:
+ void OnEvent(ui::Event* event) override;
+
+ // Overridden from mojo::FocusControllerObserver:
+ void OnFocused(mojo::View* gained_focus) override;
+ void OnActivated(mojo::View* gained_active) override;
+
+ // Overridden from mojo::CaptureControllerObserver:
+ void OnCaptureChanged(mojo::View* gained_capture) override;
+
+ // Creates the connection to the ViewManager.
+ void LaunchViewManager(mojo::ApplicationImpl* app);
+
+ // InterfaceFactory<WindowManagerInternal>:
+ void Create(
+ mojo::ApplicationConnection* connection,
+ mojo::InterfaceRequest<mojo::WindowManagerInternal> request) override;
+
+ // InterfaceFactory<NativeViewportEventDispatcher>:
+ void Create(mojo::ApplicationConnection* connection,
+ mojo::InterfaceRequest<mojo::NativeViewportEventDispatcher>
+ request) override;
+
+ // WindowManagerInternal:
+ void CreateWindowManagerForViewManagerClient(
+ uint16_t connection_id,
+ mojo::ScopedMessagePipeHandle window_manager_pipe) override;
+ void SetViewManagerClient(
+ mojo::ScopedMessagePipeHandle view_manager_client_request) override;
+
+ mojo::ApplicationImpl* application_impl_;
+ mojo::ApplicationConnection* connection_;
+ scoped_ptr<WindowManagerController> window_manager_controller_;
+
+ ViewManagerDelegate* wrapped_view_manager_delegate_;
+ WindowManagerDelegate* window_manager_delegate_;
+
+ mojo::ViewManagerServicePtr view_manager_service_;
+ scoped_ptr<mojo::ViewManagerClientFactory> view_manager_client_factory_;
+ mojo::View* root_;
+
+ scoped_ptr<FocusController> focus_controller_;
+ scoped_ptr<CaptureController> capture_controller_;
+
+ ui::AcceleratorManager accelerator_manager_;
+
+ ConnectedServices connected_services_;
+ RegisteredViewIdSet registered_view_id_set_;
+
+ mojo::WindowManagerInternalClientPtr window_manager_client_;
+
+ ScopedVector<PendingEmbed> pending_embeds_;
+
+ scoped_ptr<mojo::ViewManagerClient> view_manager_client_;
+
+ scoped_ptr<ViewEventDispatcher> view_event_dispatcher_;
+
+ scoped_ptr<mojo::Binding<WindowManagerInternal>> wm_internal_binding_;
+
+ DISALLOW_COPY_AND_ASSIGN(WindowManagerRoot);
+};
+
+} // namespace window_manager
+
+#endif // SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_APP_H_
« no previous file with comments | « services/window_manager/window_manager_impl.cc ('k') | services/window_manager/window_manager_root.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698