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

Unified Diff: chrome/browser/ui/app_list/profile_loader.cc

Issue 16766003: Move ProfileLoader to chrome/browser/profiles. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: gyp-def out profile_loader* on android Created 7 years, 6 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/app_list/profile_loader.cc
diff --git a/chrome/browser/ui/app_list/profile_loader.cc b/chrome/browser/ui/app_list/profile_loader.cc
deleted file mode 100644
index 4654cf2c4611f76fab6711e2aa28abad5fbd0ba1..0000000000000000000000000000000000000000
--- a/chrome/browser/ui/app_list/profile_loader.cc
+++ /dev/null
@@ -1,83 +0,0 @@
-// Copyright 2013 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/ui/app_list/profile_loader.h"
-
-#include "base/bind.h"
-#include "base/files/file_path.h"
-#include "base/memory/weak_ptr.h"
-#include "chrome/browser/lifetime/application_lifetime.h"
-#include "chrome/browser/profiles/profile_manager.h"
-
-ProfileLoader::ProfileLoader(ProfileManager* profile_manager)
- : profile_manager_(profile_manager),
- profile_load_sequence_id_(0),
- pending_profile_loads_(0),
- weak_factory_(this) {
-}
-
-ProfileLoader::~ProfileLoader() {
-}
-
-bool ProfileLoader::AnyProfilesLoading() const {
- return pending_profile_loads_ > 0;
-}
-
-void ProfileLoader::InvalidatePendingProfileLoads() {
- profile_load_sequence_id_++;
-}
-
-void ProfileLoader::LoadProfileInvalidatingOtherLoads(
- const base::FilePath& profile_file_path,
- base::Callback<void(Profile*)> callback) {
- Profile* profile = profile_manager_->GetProfileByPath(profile_file_path);
- if (profile) {
- callback.Run(profile);
- return;
- }
-
- IncrementPendingProfileLoads();
- profile_manager_->CreateProfileAsync(
- profile_file_path,
- base::Bind(&ProfileLoader::OnProfileLoaded,
- weak_factory_.GetWeakPtr(),
- profile_load_sequence_id_,
- callback),
- string16(), string16(), false);
-}
-
-void ProfileLoader::OnProfileLoaded(int profile_load_sequence_id,
- base::Callback<void(Profile*)> callback,
- Profile* profile,
- Profile::CreateStatus status) {
- switch (status) {
- case Profile::CREATE_STATUS_CREATED:
- break;
- case Profile::CREATE_STATUS_INITIALIZED:
- if (profile_load_sequence_id == profile_load_sequence_id_)
- callback.Run(profile);
- DecrementPendingProfileLoads();
- break;
- case Profile::CREATE_STATUS_LOCAL_FAIL:
- case Profile::CREATE_STATUS_REMOTE_FAIL:
- case Profile::CREATE_STATUS_CANCELED:
- DecrementPendingProfileLoads();
- break;
- case Profile::MAX_CREATE_STATUS:
- NOTREACHED();
- break;
- }
-}
-
-void ProfileLoader::IncrementPendingProfileLoads() {
- pending_profile_loads_++;
- if (pending_profile_loads_ == 1)
- chrome::StartKeepAlive();
-}
-
-void ProfileLoader::DecrementPendingProfileLoads() {
- pending_profile_loads_--;
- if (pending_profile_loads_ == 0)
- chrome::EndKeepAlive();
-}
« no previous file with comments | « chrome/browser/ui/app_list/profile_loader.h ('k') | chrome/browser/ui/views/app_list/app_list_controller_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698