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

Unified Diff: chrome/utility/profile_import_handler.cc

Issue 2470283002: Convert profile import IPCs to Mojo (Closed)
Patch Set: Fix incorrect merge Created 4 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 side-by-side diff with in-line comments
Download patch
Index: chrome/utility/profile_import_handler.cc
diff --git a/chrome/utility/profile_import_handler.cc b/chrome/utility/profile_import_handler.cc
index ba2d45b3cb537879ebac240a77c7b098ba1ad92a..c4dc6f0933daedb08534d6bc8b5396b0735fcb5d 100644
--- a/chrome/utility/profile_import_handler.cc
+++ b/chrome/utility/profile_import_handler.cc
@@ -11,49 +11,32 @@
#include "base/threading/thread.h"
#include "base/threading/thread_task_runner_handle.h"
#include "build/build_config.h"
-#include "chrome/common/importer/profile_import_process_messages.h"
#include "chrome/utility/importer/external_process_importer_bridge.h"
#include "chrome/utility/importer/importer.h"
#include "chrome/utility/importer/importer_creator.h"
#include "content/public/utility/utility_thread.h"
+#include "mojo/public/cpp/bindings/strong_binding.h"
-namespace {
-
-bool Send(IPC::Message* message) {
- return content::UtilityThread::Get()->Send(message);
+// static
sky 2016/11/29 23:56:28 Declaration and definition order should match (see
tibell 2016/11/30 03:36:47 Done.
sky 2016/11/30 16:19:07 Did you miss this one? This function should be aft
tibell 2016/11/30 23:56:26 Done.
+void ProfileImportHandler::Create(
+ mojo::InterfaceRequest<chrome::mojom::ProfileImport> request) {
+ mojo::MakeStrongBinding(base::MakeUnique<ProfileImportHandler>(),
+ std::move(request));
}
-} // namespace
-
ProfileImportHandler::ProfileImportHandler() : items_to_import_(0) {}
ProfileImportHandler::~ProfileImportHandler() {}
-bool ProfileImportHandler::OnMessageReceived(const IPC::Message& message) {
- bool handled = true;
- IPC_BEGIN_MESSAGE_MAP(ProfileImportHandler, message)
- IPC_MESSAGE_HANDLER(ProfileImportProcessMsg_StartImport, OnImportStart)
- IPC_MESSAGE_HANDLER(ProfileImportProcessMsg_CancelImport, OnImportCancel)
- IPC_MESSAGE_HANDLER(ProfileImportProcessMsg_ReportImportItemFinished,
- OnImportItemFinished)
- IPC_MESSAGE_UNHANDLED(handled = false)
- IPC_END_MESSAGE_MAP()
- return handled;
-}
-
-void ProfileImportHandler::OnImportStart(
+void ProfileImportHandler::StartImport(
const importer::SourceProfile& source_profile,
uint16_t items,
- const base::DictionaryValue& localized_strings) {
+ const base::DictionaryValue& localized_strings,
+ chrome::mojom::ProfileImportObserverPtr observer) {
content::UtilityThread::Get()->EnsureBlinkInitialized();
- bridge_ = new ExternalProcessImporterBridge(
- localized_strings,
- content::UtilityThread::Get(),
- base::ThreadTaskRunnerHandle::Get().get());
importer_ = importer::CreateImporterByType(source_profile.importer_type);
if (!importer_.get()) {
- Send(new ProfileImportProcessHostMsg_Import_Finished(
- false, "Importer could not be created."));
+ observer->OnImportFinished(false, "Importer could not be created.");
return;
}
@@ -68,20 +51,23 @@ void ProfileImportHandler::OnImportStart(
NOTREACHED();
ImporterCleanup();
}
+ // Move the InterfacePtr to the import thread, as remaining messages will be
+ // sent from there:
+ observer.Bind(observer.PassInterface(), import_thread_->task_runner());
sky 2016/11/29 23:56:28 The description of Bind indicates the runner "must
tibell 2016/11/30 03:36:47 Talked this through with sammc@ and we decided tha
yzshen1 2016/12/01 18:15:48 Sorry for late reply. Just realized that I missed
+ bridge_ =
+ new ExternalProcessImporterBridge(localized_strings, std::move(observer));
import_thread_->task_runner()->PostTask(
FROM_HERE, base::Bind(&Importer::StartImport, importer_,
source_profile, items, base::RetainedRef(bridge_)));
}
-void ProfileImportHandler::OnImportCancel() {
+void ProfileImportHandler::CancelImport() {
ImporterCleanup();
}
-void ProfileImportHandler::OnImportItemFinished(uint16_t item) {
+void ProfileImportHandler::ReportImportItemFinished(importer::ImportItem item) {
items_to_import_ ^= item; // Remove finished item from mask.
- // If we've finished with all items, notify the browser process.
if (items_to_import_ == 0) {
- Send(new ProfileImportProcessHostMsg_Import_Finished(true, std::string()));
ImporterCleanup();
}
}

Powered by Google App Engine
This is Rietveld 408576698