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

Unified Diff: services/files/files_impl.cc

Issue 875643004: Prototype of Files service. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Remove much of DirectoryImpl implementation until I write tests. Created 5 years, 10 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: services/files/files_impl.cc
diff --git a/services/files/files_impl.cc b/services/files/files_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e43d5770af731411c9d4bc78d6262cde123a9827
--- /dev/null
+++ b/services/files/files_impl.cc
@@ -0,0 +1,98 @@
+// Copyright 2015 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 "services/files/files_impl.h"
+
+#include <fcntl.h>
+#include <stdlib.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+#include "base/files/file_path.h"
+#include "base/files/file_util.h"
+#include "base/files/scoped_file.h"
+#include "base/logging.h"
+#include "base/posix/eintr_wrapper.h"
+#include "services/files/directory_impl.h"
+
+namespace mojo {
+namespace files {
+
+namespace {
+
+base::ScopedFD CreateAndOpenTemporaryDirectory(base::FilePath* temp_dir_name) {
+ DCHECK(temp_dir_name);
+ CHECK(base::CreateNewTempDirectory(base::FilePath::StringType(),
+ temp_dir_name));
+ base::ScopedFD temp_dir_fd(HANDLE_EINTR(
+ open(temp_dir_name->value().c_str(), O_RDONLY | O_DIRECTORY, 0)));
+ PCHECK(temp_dir_fd.is_valid());
+ DVLOG(1) << "Made a temporary directory: " << temp_dir_name->value();
+ return temp_dir_fd.Pass();
+}
+
+#ifndef NDEBUG
+base::ScopedFD OpenMojoDebugDirectory() {
+ const char* home_dir_name = getenv("HOME");
+ if (!home_dir_name || !home_dir_name[0]) {
+ LOG(ERROR) << "HOME not set";
+ return base::ScopedFD();
+ }
+ base::FilePath mojo_debug_dir_name =
+ base::FilePath(home_dir_name).Append("MojoDebug");
+ return base::ScopedFD(HANDLE_EINTR(
+ open(mojo_debug_dir_name.value().c_str(), O_RDONLY | O_DIRECTORY, 0)));
+}
+#endif
+
+} // namespace
+
+FilesImpl::FilesImpl(ApplicationConnection* connection,
+ InterfaceRequest<Files> request)
+ : binding_(this, request.Pass()) {
+ // TODO(vtl): record other app's URL
+}
+
+FilesImpl::~FilesImpl() {
+}
+
+void FilesImpl::OpenFileSystem(FileSystem file_system,
+ InterfaceRequest<Directory> directory,
+ const Callback<void(Error)>& callback) {
+ base::ScopedFD dir_fd;
+ // Set only if the |DirectoryImpl| will own this directory (and should delete
+ // it on destruction).
+ base::FilePath owned_dir_name;
+ switch (file_system) {
+ case FILE_SYSTEM_TEMPORARY:
+ // TODO(vtl): ScopedGeneric (hence ScopedFD) doesn't have an operator=!
+ dir_fd.reset(CreateAndOpenTemporaryDirectory(&owned_dir_name).release());
+ DCHECK(!owned_dir_name.empty());
+ break;
+ case FILE_SYSTEM_DEBUG:
+#ifdef NDEBUG
+ LOG(WARNING) << "~/MojoDebug only available in Debug builds";
qsr 2015/03/02 12:46:40 You should call the callback, otherwise client wil
qsr 2015/03/03 11:56:44 You didn't change this -> I really think this shou
viettrungluu 2015/03/03 18:50:35 Oops, missed your previous comment. Sorry. I had
+#else
+ // TODO(vtl): ScopedGeneric (hence ScopedFD) doesn't have an operator=!
+ dir_fd.reset(OpenMojoDebugDirectory().release());
+ if (!dir_fd.is_valid()) {
+ LOG(ERROR) << "~/MojoDebug unavailable";
+ callback.Run(ERROR_UNAVAILABLE);
+ return;
+ }
+#endif
+ break;
+ default:
+ LOG(ERROR) << "Unknown file system type: " << file_system;
+ callback.Run(ERROR_UNIMPLEMENTED);
+ return;
+ }
+
+ new DirectoryImpl(directory.Pass(), dir_fd.Pass(), owned_dir_name);
+ callback.Run(ERROR_OK);
+}
+
+} // namespace files
+} // namespace mojo

Powered by Google App Engine
This is Rietveld 408576698