1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HANDLER_MAC_H_
6 #define CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HANDLER_MAC_H_
11 #include "base/files/file_path.h"
12 #include "chrome/common/mac/app_shim_launch.h"
16 // Registrar, and interface for services that can handle interactions with OSX
18 class AppShimHandler
{
22 // Invoked when the app is successfully launched.
23 virtual void OnAppLaunchComplete(AppShimLaunchResult result
) = 0;
24 // Invoked when the app is closed in the browser process.
25 virtual void OnAppClosed() = 0;
26 // Invoked when the app should be hidden.
27 virtual void OnAppHide() = 0;
28 // Invoked when the app is requesting user attention.
29 virtual void OnAppRequestUserAttention(AppShimAttentionType type
) = 0;
31 // Allows the handler to determine which app this host corresponds to.
32 virtual base::FilePath
GetProfilePath() const = 0;
33 virtual std::string
GetAppId() const = 0;
39 // Register a handler for an |app_mode_id|.
40 static void RegisterHandler(const std::string
& app_mode_id
,
41 AppShimHandler
* handler
);
43 // Remove a handler for an |app_mode_id|.
44 static void RemoveHandler(const std::string
& app_mode_id
);
46 // Returns the handler registered for the given |app_mode_id|. If there is
47 // none registered, it returns the default handler or NULL if there is no
49 static AppShimHandler
* GetForAppMode(const std::string
& app_mode_id
);
51 // Sets the default handler to return when there is no app-specific handler.
52 // Setting this to NULL removes the default handler.
53 static void SetDefaultHandler(AppShimHandler
* handler
);
55 // Terminate Chrome if a browser window has never been opened, there are no
56 // shell windows, and the app list is not visible.
57 static void MaybeTerminate();
59 // Whether browser sessions should be restored right now. This is true if
60 // the browser has been quit but kept alive because Chrome Apps are still
62 static bool ShouldRestoreSession();
64 // Invoked by the shim host when the shim process is launched. The handler
65 // must call OnAppLaunchComplete to inform the shim of the result.
66 // |launch_type| indicates the type of launch.
67 // |files|, if non-empty, holds an array of files paths given as arguments, or
68 // dragged onto the app bundle or dock icon.
69 virtual void OnShimLaunch(Host
* host
,
70 AppShimLaunchType launch_type
,
71 const std::vector
<base::FilePath
>& files
) = 0;
73 // Invoked by the shim host when the connection to the shim process is closed.
74 virtual void OnShimClose(Host
* host
) = 0;
76 // Invoked by the shim host when the shim process receives a focus event.
77 // |files|, if non-empty, holds an array of files dragged onto the app bundle
79 virtual void OnShimFocus(Host
* host
,
80 AppShimFocusType focus_type
,
81 const std::vector
<base::FilePath
>& files
) = 0;
83 // Invoked by the shim host when the shim process is hidden or shown.
84 virtual void OnShimSetHidden(Host
* host
, bool hidden
) = 0;
86 // Invoked by the shim host when the shim process receives a quit event.
87 virtual void OnShimQuit(Host
* host
) = 0;
91 virtual ~AppShimHandler() {}
96 #endif // CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HANDLER_MAC_H_