OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/browser/profiles/profile_dependency_manager.h" | 5 #include "chrome/browser/profiles/profile_dependency_manager.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <deque> | 8 #include <deque> |
9 #include <iterator> | 9 #include <iterator> |
10 | 10 |
(...skipping 19 matching lines...) Expand all Loading... | |
30 | 30 |
31 // This method gets the instance of each ServiceFactory. We do this so that | 31 // This method gets the instance of each ServiceFactory. We do this so that |
32 // each ServiceFactory initializes iteslf and registers its dependencies with | 32 // each ServiceFactory initializes iteslf and registers its dependencies with |
33 // the global PreferenceDependencyManager. We need to have a complete | 33 // the global PreferenceDependencyManager. We need to have a complete |
34 // dependency graph when we create a profile so we can dispatch the profile | 34 // dependency graph when we create a profile so we can dispatch the profile |
35 // creation message to the services that want to create their services at | 35 // creation message to the services that want to create their services at |
36 // profile creation time. | 36 // profile creation time. |
37 // | 37 // |
38 // TODO(erg): This needs to be something else. I don't think putting every | 38 // TODO(erg): This needs to be something else. I don't think putting every |
39 // FooServiceFactory here will scale or is desireable long term. | 39 // FooServiceFactory here will scale or is desireable long term. |
40 void AssertFactoriesBuilt() { | 40 void AssertFactoriesBuilt(bool is_testing_profile) { |
41 if (!g_initialized) { | 41 if (!g_initialized || is_testing_profile) { |
Elliot Glaysher
2011/11/21 18:47:06
I don't understand this fix. Won't g_initialized a
Yoyo Zhou
2011/11/21 23:14:52
It looks like rsesek has been working on fixing th
| |
42 BackgroundContentsServiceFactory::GetInstance(); | 42 BackgroundContentsServiceFactory::GetInstance(); |
43 CloudPrintProxyServiceFactory::GetInstance(); | 43 CloudPrintProxyServiceFactory::GetInstance(); |
44 CookieSettings::Factory::GetInstance(); | 44 CookieSettings::Factory::GetInstance(); |
45 SpeechInputExtensionManager::InitializeFactory(); | 45 SpeechInputExtensionManager::InitializeFactory(); |
46 PersonalDataManagerFactory::GetInstance(); | 46 PersonalDataManagerFactory::GetInstance(); |
47 PluginPrefsFactory::GetInstance(); | 47 PluginPrefsFactory::GetInstance(); |
48 prerender::PrerenderManagerFactory::GetInstance(); | 48 prerender::PrerenderManagerFactory::GetInstance(); |
49 SessionServiceFactory::GetInstance(); | 49 SessionServiceFactory::GetInstance(); |
50 TabRestoreServiceFactory::GetInstance(); | 50 TabRestoreServiceFactory::GetInstance(); |
51 TemplateURLServiceFactory::GetInstance(); | 51 TemplateURLServiceFactory::GetInstance(); |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
90 | 90 |
91 void ProfileDependencyManager::CreateProfileServices(Profile* profile, | 91 void ProfileDependencyManager::CreateProfileServices(Profile* profile, |
92 bool is_testing_profile) { | 92 bool is_testing_profile) { |
93 #ifndef NDEBUG | 93 #ifndef NDEBUG |
94 // Unmark |profile| as dead. This exists because of unit tests, which will | 94 // Unmark |profile| as dead. This exists because of unit tests, which will |
95 // often have similar stack structures. 0xWhatever might be created, go out | 95 // often have similar stack structures. 0xWhatever might be created, go out |
96 // of scope, and then a new Profile object might be created at 0xWhatever. | 96 // of scope, and then a new Profile object might be created at 0xWhatever. |
97 dead_profile_pointers_.erase(profile); | 97 dead_profile_pointers_.erase(profile); |
98 #endif | 98 #endif |
99 | 99 |
100 AssertFactoriesBuilt(); | 100 AssertFactoriesBuilt(is_testing_profile); |
101 | 101 |
102 if (destruction_order_.empty()) | 102 if (destruction_order_.empty()) |
103 BuildDestructionOrder(); | 103 BuildDestructionOrder(); |
104 | 104 |
105 // Iterate in reverse destruction order for creation. | 105 // Iterate in reverse destruction order for creation. |
106 for (std::vector<ProfileKeyedServiceFactory*>::reverse_iterator rit = | 106 for (std::vector<ProfileKeyedServiceFactory*>::reverse_iterator rit = |
107 destruction_order_.rbegin(); rit != destruction_order_.rend(); | 107 destruction_order_.rbegin(); rit != destruction_order_.rend(); |
108 ++rit) { | 108 ++rit) { |
109 if (!profile->IsOffTheRecord() && !profile->AsTestingProfile()) { | 109 if (!profile->IsOffTheRecord() && !profile->AsTestingProfile()) { |
110 // We only register preferences on normal profiles because the incognito | 110 // We only register preferences on normal profiles because the incognito |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
206 } | 206 } |
207 } | 207 } |
208 | 208 |
209 if (edges.size()) { | 209 if (edges.size()) { |
210 NOTREACHED() << "Dependency graph has a cycle. We are doomed."; | 210 NOTREACHED() << "Dependency graph has a cycle. We are doomed."; |
211 } | 211 } |
212 | 212 |
213 std::reverse(output.begin(), output.end()); | 213 std::reverse(output.begin(), output.end()); |
214 destruction_order_ = output; | 214 destruction_order_ = output; |
215 } | 215 } |
OLD | NEW |