Index: chrome/browser/extensions/external_extension_loader.cc |
diff --git a/chrome/browser/extensions/external_extension_loader.cc b/chrome/browser/extensions/external_extension_loader.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4f4586b4611321dfc0a130099f4ae612df543f74 |
--- /dev/null |
+++ b/chrome/browser/extensions/external_extension_loader.cc |
@@ -0,0 +1,37 @@ |
+// Copyright (c) 2010 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. |
+ |
+#include "chrome/browser/extensions/external_extension_loader.h" |
+ |
+#include "base/logging.h" |
+#include "base/values.h" |
+#include "chrome/browser/browser_thread.h" |
+#include "chrome/browser/extensions/external_extension_provider_impl.h" |
+ |
+void ExternalExtensionLoader::Init( |
+ ExternalExtensionProviderImpl* owner) { |
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
Aaron Boodman
2011/01/06 18:54:40
Don't be a wuss: s/DCHECK/CHECK/g
gfeher
2011/01/07 00:10:01
Done.
|
+ owner_ = owner; |
+} |
+ |
+void ExternalExtensionLoader::StartLoading() { |
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
+ if (running_) return; |
Aaron Boodman
2011/01/06 18:54:40
How would this ever get called twice?
gfeher
2011/01/07 00:10:01
This can get called twice in case of ExternalPolic
|
+ running_ = true; |
+ Load(); |
+} |
+ |
+void ExternalExtensionLoader::OwnerShutdown() { |
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
+ owner_ = NULL; |
+} |
+ |
+void ExternalExtensionLoader::LoadFinished() { |
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
+ running_ = false; |
+ if (owner_) { |
+ AutoLock auto_(lock_); |
+ owner_->SetPrefs(prefs_.release()); |
+ } |
+} |