// 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 ASH_SHELL_H_ #define ASH_SHELL_H_ #pragma once #include #include #include "ash/ash_export.h" #include "base/basictypes.h" #include "base/gtest_prod_util.h" #include "base/memory/scoped_ptr.h" #include "base/compiler_specific.h" #include "base/memory/weak_ptr.h" class CommandLine; namespace aura { class EventFilter; class RootWindow; class Window; } namespace gfx { class Rect; class Size; } namespace ash { class AcceleratorController; class Launcher; class PowerButtonController; class ShellDelegate; class WindowCycleController; namespace internal { class ActivationController; class AcceleratorFilter; class AppList; class DragDropController; class InputMethodEventFilter; class ShadowController; class StackingController; class TooltipController; class WindowModalityController; class WorkspaceController; } // Shell is a singleton object that presents the Shell API and implements the // RootWindow's delegate interface. class ASH_EXPORT Shell { public: // Upon creation, the Shell sets itself as the RootWindow's delegate, which // takes ownership of the Shell. // A shell must be explicitly created so that it can call |Init()| with the // delegate set. |delegate| can be NULL (if not required for initialization). static Shell* CreateInstance(ShellDelegate* delegate); // Should never be called before |CreateInstance()|. static Shell* GetInstance(); static void DeleteInstance(); aura::Window* GetContainer(int container_id); const aura::Window* GetContainer(int container_id) const; // Adds or removes |filter| from the RootWindowEventFilter. void AddRootWindowEventFilter(aura::EventFilter* filter); void RemoveRootWindowEventFilter(aura::EventFilter* filter); size_t GetRootWindowEventFilterCount() const; // Toggles between overview mode and normal mode. void ToggleOverview(); // Toggles app list. void ToggleAppList(); // Returns true if the screen is locked. bool IsScreenLocked() const; // Returns true if a modal dialog window is currently open. bool IsModalWindowOpen() const; // See enum WindowMode for details. bool IsWindowModeCompact() const { return window_mode_ == COMPACT_MODE; } AcceleratorController* accelerator_controller() { return accelerator_controller_.get(); } internal::TooltipController* tooltip_controller() { return tooltip_controller_.get(); } PowerButtonController* power_button_controller() { return power_button_controller_.get(); } WindowCycleController* window_cycle_controller() { return window_cycle_controller_.get(); } ShellDelegate* delegate() { return delegate_.get(); } Launcher* launcher() { return launcher_.get(); } // Made available for tests. internal::ShadowController* shadow_controller() { return shadow_controller_.get(); } private: FRIEND_TEST_ALL_PREFIXES(ShellTest, ComputeWindowMode); typedef std::pair WindowAndBoundsPair; // In compact window mode we fill the screen with a single maximized window, // similar to ChromeOS R17 and earlier. In normal mode we have draggable // windows. enum WindowMode { NORMAL_MODE, COMPACT_MODE }; explicit Shell(ShellDelegate* delegate); virtual ~Shell(); void Init(); // Returns the appropriate window mode to use based on the primary monitor's // |monitor_size| and the user's |command_line|. WindowMode ComputeWindowMode(const gfx::Size& monitor_size, CommandLine* command_line) const; void InitLayoutManagers(aura::RootWindow* root_window); // Enables WorkspaceManager. void EnableWorkspaceManager(); static Shell* instance_; std::vector to_restore_; base::WeakPtrFactory method_factory_; scoped_ptr accelerator_controller_; scoped_ptr delegate_; scoped_ptr launcher_; scoped_ptr app_list_; scoped_ptr stacking_controller_; scoped_ptr activation_controller_; scoped_ptr window_modality_controller_; scoped_ptr drag_drop_controller_; scoped_ptr workspace_controller_; scoped_ptr shadow_controller_; scoped_ptr tooltip_controller_; scoped_ptr power_button_controller_; scoped_ptr window_cycle_controller_; // An event filter that pre-handles all key events to send them to an IME. scoped_ptr input_method_filter_; // An event filter that pre-handles global accelerators. scoped_ptr accelerator_filter_; // The |window_mode_| never changes after the shell is initialized. // Switching modes requires a restart. WindowMode window_mode_; DISALLOW_COPY_AND_ASSIGN(Shell); }; } // namespace ash #endif // ASH_SHELL_H_