OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "apps/app_load_service.h" | 5 #include "apps/app_load_service.h" |
6 | 6 |
7 #include "apps/app_load_service_factory.h" | 7 #include "apps/app_load_service_factory.h" |
8 #include "apps/app_restore_service.h" | 8 #include "apps/app_restore_service.h" |
9 #include "apps/launcher.h" | 9 #include "apps/launcher.h" |
10 #include "chrome/browser/extensions/extension_service.h" | 10 #include "chrome/browser/extensions/extension_service.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 #include "extensions/browser/notification_types.h" | 21 #include "extensions/browser/notification_types.h" |
22 #include "extensions/common/extension.h" | 22 #include "extensions/common/extension.h" |
23 | 23 |
24 using extensions::Extension; | 24 using extensions::Extension; |
25 using extensions::ExtensionPrefs; | 25 using extensions::ExtensionPrefs; |
26 using extensions::ExtensionSystem; | 26 using extensions::ExtensionSystem; |
27 | 27 |
28 namespace apps { | 28 namespace apps { |
29 | 29 |
30 AppLoadService::PostReloadAction::PostReloadAction() | 30 AppLoadService::PostReloadAction::PostReloadAction() |
31 : action_type(LAUNCH), | 31 : action_type(LAUNCH_FOR_RELOAD), |
32 command_line(base::CommandLine::NO_PROGRAM) { | 32 command_line(base::CommandLine::NO_PROGRAM) { |
33 } | 33 } |
34 | 34 |
35 AppLoadService::AppLoadService(Profile* profile) | 35 AppLoadService::AppLoadService(Profile* profile) |
36 : profile_(profile) { | 36 : profile_(profile) { |
37 registrar_.Add(this, | 37 registrar_.Add(this, |
38 extensions::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING, | 38 extensions::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING, |
39 content::NotificationService::AllSources()); | 39 content::NotificationService::AllSources()); |
40 extensions::ExtensionRegistry::Get(profile_)->AddObserver(this); | 40 extensions::ExtensionRegistry::Get(profile_)->AddObserver(this); |
41 } | 41 } |
(...skipping 22 matching lines...) Expand all Loading... |
64 ExtensionService* extension_service = | 64 ExtensionService* extension_service = |
65 ExtensionSystem::Get(profile_)->extension_service(); | 65 ExtensionSystem::Get(profile_)->extension_service(); |
66 std::string extension_id; | 66 std::string extension_id; |
67 if (!extensions::UnpackedInstaller::Create(extension_service)-> | 67 if (!extensions::UnpackedInstaller::Create(extension_service)-> |
68 LoadFromCommandLine(base::FilePath(extension_path), &extension_id)) { | 68 LoadFromCommandLine(base::FilePath(extension_path), &extension_id)) { |
69 return false; | 69 return false; |
70 } | 70 } |
71 | 71 |
72 // Schedule the app to be launched once loaded. | 72 // Schedule the app to be launched once loaded. |
73 PostReloadAction& action = post_reload_actions_[extension_id]; | 73 PostReloadAction& action = post_reload_actions_[extension_id]; |
74 action.action_type = LAUNCH_WITH_COMMAND_LINE; | 74 action.action_type = LAUNCH_FOR_LOAD_AND_LAUNCH; |
75 action.command_line = command_line; | 75 action.command_line = command_line; |
76 action.current_dir = current_dir; | 76 action.current_dir = current_dir; |
77 return true; | 77 return true; |
78 } | 78 } |
79 | 79 |
80 // static | 80 // static |
81 AppLoadService* AppLoadService::Get(Profile* profile) { | 81 AppLoadService* AppLoadService::Get(Profile* profile) { |
82 return apps::AppLoadServiceFactory::GetForProfile(profile); | 82 return apps::AppLoadServiceFactory::GetForProfile(profile); |
83 } | 83 } |
84 | 84 |
85 void AppLoadService::Observe(int type, | 85 void AppLoadService::Observe(int type, |
86 const content::NotificationSource& source, | 86 const content::NotificationSource& source, |
87 const content::NotificationDetails& details) { | 87 const content::NotificationDetails& details) { |
88 DCHECK_EQ(type, extensions::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING); | 88 DCHECK_EQ(type, extensions::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING); |
89 extensions::ExtensionHost* host = | 89 extensions::ExtensionHost* host = |
90 content::Details<extensions::ExtensionHost>(details).ptr(); | 90 content::Details<extensions::ExtensionHost>(details).ptr(); |
91 const Extension* extension = host->extension(); | 91 const Extension* extension = host->extension(); |
92 // It is possible for an extension to be unloaded before it stops loading. | 92 // It is possible for an extension to be unloaded before it stops loading. |
93 if (!extension) | 93 if (!extension) |
94 return; | 94 return; |
95 std::map<std::string, PostReloadAction>::iterator it = | 95 std::map<std::string, PostReloadAction>::iterator it = |
96 post_reload_actions_.find(extension->id()); | 96 post_reload_actions_.find(extension->id()); |
97 if (it == post_reload_actions_.end()) | 97 if (it == post_reload_actions_.end()) |
98 return; | 98 return; |
99 | 99 |
100 switch (it->second.action_type) { | 100 switch (it->second.action_type) { |
101 case LAUNCH: | 101 case LAUNCH_FOR_RELOAD: |
102 LaunchPlatformApp(profile_, extension); | 102 LaunchPlatformApp(profile_, extension, extensions::SOURCE_RELOAD); |
103 break; | 103 break; |
104 case RESTART: | 104 case RESTART: |
105 RestartPlatformApp(profile_, extension); | 105 RestartPlatformApp(profile_, extension); |
106 break; | 106 break; |
107 case LAUNCH_WITH_COMMAND_LINE: | 107 case LAUNCH_FOR_LOAD_AND_LAUNCH: |
108 LaunchPlatformAppWithCommandLine( | 108 LaunchPlatformAppWithCommandLine(profile_, |
109 profile_, extension, it->second.command_line, it->second.current_dir); | 109 extension, |
| 110 it->second.command_line, |
| 111 it->second.current_dir, |
| 112 extensions::SOURCE_LOAD_AND_LAUNCH); |
110 break; | 113 break; |
111 default: | 114 default: |
112 NOTREACHED(); | 115 NOTREACHED(); |
113 } | 116 } |
114 | 117 |
115 post_reload_actions_.erase(it); | 118 post_reload_actions_.erase(it); |
116 } | 119 } |
117 | 120 |
118 void AppLoadService::OnExtensionUnloaded( | 121 void AppLoadService::OnExtensionUnloaded( |
119 content::BrowserContext* browser_context, | 122 content::BrowserContext* browser_context, |
120 const Extension* extension, | 123 const Extension* extension, |
121 extensions::UnloadedExtensionInfo::Reason reason) { | 124 extensions::UnloadedExtensionInfo::Reason reason) { |
122 if (!extension->is_platform_app()) | 125 if (!extension->is_platform_app()) |
123 return; | 126 return; |
124 | 127 |
125 extensions::ExtensionPrefs* extension_prefs = | 128 extensions::ExtensionPrefs* extension_prefs = |
126 extensions::ExtensionPrefs::Get(browser_context); | 129 extensions::ExtensionPrefs::Get(browser_context); |
127 if (WasUnloadedForReload(extension->id(), reason) && | 130 if (WasUnloadedForReload(extension->id(), reason) && |
128 extension_prefs->IsActive(extension->id()) && | 131 extension_prefs->IsActive(extension->id()) && |
129 !HasPostReloadAction(extension->id())) { | 132 !HasPostReloadAction(extension->id())) { |
130 post_reload_actions_[extension->id()].action_type = LAUNCH; | 133 post_reload_actions_[extension->id()].action_type = LAUNCH_FOR_RELOAD; |
131 } | 134 } |
132 } | 135 } |
133 | 136 |
134 bool AppLoadService::WasUnloadedForReload( | 137 bool AppLoadService::WasUnloadedForReload( |
135 const extensions::ExtensionId& extension_id, | 138 const extensions::ExtensionId& extension_id, |
136 const extensions::UnloadedExtensionInfo::Reason reason) { | 139 const extensions::UnloadedExtensionInfo::Reason reason) { |
137 if (reason == extensions::UnloadedExtensionInfo::REASON_DISABLE) { | 140 if (reason == extensions::UnloadedExtensionInfo::REASON_DISABLE) { |
138 ExtensionPrefs* prefs = ExtensionPrefs::Get(profile_); | 141 ExtensionPrefs* prefs = ExtensionPrefs::Get(profile_); |
139 return (prefs->GetDisableReasons(extension_id) & | 142 return (prefs->GetDisableReasons(extension_id) & |
140 Extension::DISABLE_RELOAD) != 0; | 143 Extension::DISABLE_RELOAD) != 0; |
141 } | 144 } |
142 return false; | 145 return false; |
143 } | 146 } |
144 | 147 |
145 bool AppLoadService::HasPostReloadAction(const std::string& extension_id) { | 148 bool AppLoadService::HasPostReloadAction(const std::string& extension_id) { |
146 return post_reload_actions_.find(extension_id) != post_reload_actions_.end(); | 149 return post_reload_actions_.find(extension_id) != post_reload_actions_.end(); |
147 } | 150 } |
148 | 151 |
149 } // namespace apps | 152 } // namespace apps |
OLD | NEW |