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

Side by Side Diff: apps/app_load_service.cc

Issue 657023008: Add a new field "source" in launchData of chrome.app.runtime.onLaunched() to trace launch source. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix typo Created 6 years, 1 month 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 unified diff | Download patch
« no previous file with comments | « apps/app_load_service.h ('k') | apps/launcher.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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
OLDNEW
« no previous file with comments | « apps/app_load_service.h ('k') | apps/launcher.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698