| Index: extensions/browser/api/file_handlers/directory_util.cc
|
| diff --git a/extensions/browser/api/file_handlers/directory_util.cc b/extensions/browser/api/file_handlers/directory_util.cc
|
| deleted file mode 100644
|
| index 516be8f872be520002cb7a3ed3678644bfceda2d..0000000000000000000000000000000000000000
|
| --- a/extensions/browser/api/file_handlers/directory_util.cc
|
| +++ /dev/null
|
| @@ -1,110 +0,0 @@
|
| -// Copyright 2016 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 "extensions/browser/api/file_handlers/directory_util.h"
|
| -
|
| -#include "base/files/file_path.h"
|
| -#include "base/files/file_util.h"
|
| -#include "base/threading/thread_task_runner_handle.h"
|
| -#include "content/public/browser/browser_context.h"
|
| -#include "content/public/browser/browser_thread.h"
|
| -#include "net/base/filename_util.h"
|
| -#include "storage/browser/fileapi/file_system_url.h"
|
| -
|
| -#if defined(OS_CHROMEOS)
|
| -#include "extensions/browser/api/extensions_api_client.h"
|
| -#include "extensions/browser/api/file_handlers/non_native_file_system_delegate.h"
|
| -#endif
|
| -
|
| -namespace extensions {
|
| -namespace app_file_handler_util {
|
| -
|
| -namespace {
|
| -
|
| -void GetIsDirectoryFromFileInfo(const base::FilePath& path,
|
| - bool* is_directory) {
|
| - base::File::Info file_info;
|
| - *is_directory = GetFileInfo(path, &file_info) && file_info.is_directory;
|
| -}
|
| -
|
| -void OnGetIsDirectoryFromFileInfoCompleted(
|
| - std::unique_ptr<bool> is_directory,
|
| - const base::Callback<void(bool)>& callback) {
|
| - callback.Run(*is_directory);
|
| -}
|
| -
|
| -// The callback parameter contains the result and is required to support
|
| -// both native local directories to avoid UI thread and non native local
|
| -// path directories for the IsNonNativeLocalPathDirectory API.
|
| -void EntryIsDirectory(content::BrowserContext* context,
|
| - const base::FilePath& path,
|
| - const base::Callback<void(bool)>& callback) {
|
| -#if defined(OS_CHROMEOS)
|
| - NonNativeFileSystemDelegate* delegate =
|
| - ExtensionsAPIClient::Get()->GetNonNativeFileSystemDelegate();
|
| - if (delegate && delegate->IsUnderNonNativeLocalPath(context, path)) {
|
| - delegate->IsNonNativeLocalPathDirectory(context, path, callback);
|
| - return;
|
| - }
|
| -#endif
|
| -
|
| - std::unique_ptr<bool> is_directory(new bool);
|
| - bool* const is_directory_ptr = is_directory.get();
|
| -
|
| - content::BrowserThread::PostBlockingPoolTaskAndReply(
|
| - FROM_HERE,
|
| - base::Bind(&GetIsDirectoryFromFileInfo, path, is_directory_ptr),
|
| - base::Bind(&OnGetIsDirectoryFromFileInfoCompleted,
|
| - base::Passed(&is_directory), callback));
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -IsDirectoryCollector::IsDirectoryCollector(content::BrowserContext* context)
|
| - : context_(context), left_(0), weak_ptr_factory_(this) {}
|
| -
|
| -IsDirectoryCollector::~IsDirectoryCollector() {}
|
| -
|
| -void IsDirectoryCollector::CollectForEntriesPaths(
|
| - const std::vector<base::FilePath>& paths,
|
| - const CompletionCallback& callback) {
|
| - DCHECK(!callback.is_null());
|
| - paths_ = paths;
|
| - callback_ = callback;
|
| -
|
| - DCHECK(!result_.get());
|
| - result_.reset(new std::set<base::FilePath>());
|
| - left_ = paths.size();
|
| -
|
| - if (!left_) {
|
| - // Nothing to process.
|
| - base::ThreadTaskRunnerHandle::Get()->PostTask(
|
| - FROM_HERE, base::Bind(callback_, base::Passed(&result_)));
|
| - callback_ = CompletionCallback();
|
| - return;
|
| - }
|
| -
|
| - for (size_t i = 0; i < paths.size(); ++i) {
|
| - EntryIsDirectory(context_, paths[i],
|
| - base::Bind(&IsDirectoryCollector::OnIsDirectoryCollected,
|
| - weak_ptr_factory_.GetWeakPtr(), i));
|
| - }
|
| -}
|
| -
|
| -void IsDirectoryCollector::OnIsDirectoryCollected(size_t index,
|
| - bool is_directory) {
|
| - if (is_directory)
|
| - result_->insert(paths_[index]);
|
| - if (!--left_) {
|
| - base::ThreadTaskRunnerHandle::Get()->PostTask(
|
| - FROM_HERE, base::Bind(callback_, base::Passed(&result_)));
|
| - // Release the callback to avoid a circullar reference in case an instance
|
| - // of this class is a member of a ref counted class, which instance is bound
|
| - // to this callback.
|
| - callback_ = CompletionCallback();
|
| - }
|
| -}
|
| -
|
| -} // namespace app_file_handler_util
|
| -} // namespace extensions
|
|
|