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

Unified Diff: components/filesystem/directory_impl.cc

Issue 2326913003: Privatize StrongBinding lifetime management (Closed)
Patch Set: rebase Created 4 years, 3 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
« no previous file with comments | « components/filesystem/directory_impl.h ('k') | components/filesystem/file_impl.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/filesystem/directory_impl.cc
diff --git a/components/filesystem/directory_impl.cc b/components/filesystem/directory_impl.cc
index 835a0f22029fcdf7bf8ae0a6ec4903ee4901372a..7fd998142b66542a56dae4a87d322e3ec9247e73 100644
--- a/components/filesystem/directory_impl.cc
+++ b/components/filesystem/directory_impl.cc
@@ -16,16 +16,15 @@
#include "components/filesystem/lock_table.h"
#include "components/filesystem/util.h"
#include "mojo/common/common_type_converters.h"
+#include "mojo/public/cpp/bindings/strong_binding.h"
#include "mojo/public/cpp/system/platform_handle.h"
namespace filesystem {
-DirectoryImpl::DirectoryImpl(mojo::InterfaceRequest<mojom::Directory> request,
- base::FilePath directory_path,
+DirectoryImpl::DirectoryImpl(base::FilePath directory_path,
scoped_refptr<SharedTempDir> temp_dir,
scoped_refptr<LockTable> lock_table)
- : binding_(this, std::move(request)),
- directory_path_(directory_path),
+ : directory_path_(directory_path),
temp_dir_(std::move(temp_dir)),
lock_table_(std::move(lock_table)) {}
@@ -55,7 +54,7 @@ void DirectoryImpl::Read(const ReadCallback& callback) {
// TODO(vtl): Move the implementation to a thread pool.
void DirectoryImpl::OpenFile(const mojo::String& raw_path,
- mojo::InterfaceRequest<mojom::File> file,
+ mojom::FileRequest file,
uint32_t open_flags,
const OpenFileCallback& callback) {
base::FilePath path;
@@ -80,8 +79,10 @@ void DirectoryImpl::OpenFile(const mojo::String& raw_path,
}
if (file.is_pending()) {
- new FileImpl(std::move(file), path, std::move(base_file), temp_dir_,
- lock_table_);
+ mojo::MakeStrongBinding(
+ base::MakeUnique<FileImpl>(path, std::move(base_file), temp_dir_,
+ lock_table_),
+ std::move(file));
}
callback.Run(mojom::FileError::OK);
}
@@ -110,11 +111,10 @@ void DirectoryImpl::OpenFileHandles(
callback.Run(std::move(results));
}
-void DirectoryImpl::OpenDirectory(
- const mojo::String& raw_path,
- mojo::InterfaceRequest<mojom::Directory> directory,
- uint32_t open_flags,
- const OpenDirectoryCallback& callback) {
+void DirectoryImpl::OpenDirectory(const mojo::String& raw_path,
+ mojom::DirectoryRequest directory,
+ uint32_t open_flags,
+ const OpenDirectoryCallback& callback) {
base::FilePath path;
mojom::FileError error = ValidatePath(raw_path, directory_path_, &path);
if (error != mojom::FileError::OK) {
@@ -143,8 +143,12 @@ void DirectoryImpl::OpenDirectory(
}
}
- if (directory.is_pending())
- new DirectoryImpl(std::move(directory), path, temp_dir_, lock_table_);
+ if (directory.is_pending()) {
+ mojo::MakeStrongBinding(
+ base::MakeUnique<DirectoryImpl>(path, temp_dir_, lock_table_),
+ std::move(directory));
+ }
+
callback.Run(mojom::FileError::OK);
}
@@ -257,10 +261,11 @@ void DirectoryImpl::StatFile(const mojo::String& raw_path,
callback.Run(mojom::FileError::OK, MakeFileInformation(info));
}
-void DirectoryImpl::Clone(mojo::InterfaceRequest<mojom::Directory> directory) {
+void DirectoryImpl::Clone(mojom::DirectoryRequest directory) {
if (directory.is_pending()) {
- new DirectoryImpl(std::move(directory), directory_path_,
- temp_dir_, lock_table_);
+ mojo::MakeStrongBinding(base::MakeUnique<DirectoryImpl>(
+ directory_path_, temp_dir_, lock_table_),
+ std::move(directory));
}
}
« no previous file with comments | « components/filesystem/directory_impl.h ('k') | components/filesystem/file_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698