Index: chrome/browser/chromeos/arc/fileapi/arc_documents_provider_backend_delegate.h |
diff --git a/chrome/browser/chromeos/arc/fileapi/arc_documents_provider_backend_delegate.h b/chrome/browser/chromeos/arc/fileapi/arc_documents_provider_backend_delegate.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..637b82ba0faaeaa20c64e6caa571c8a9d7f6abbf |
--- /dev/null |
+++ b/chrome/browser/chromeos/arc/fileapi/arc_documents_provider_backend_delegate.h |
@@ -0,0 +1,59 @@ |
+// 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. |
+ |
+#ifndef CHROME_BROWSER_CHROMEOS_ARC_FILEAPI_ARC_DOCUMENTS_PROVIDER_BACKEND_DELEGATE_H_ |
+#define CHROME_BROWSER_CHROMEOS_ARC_FILEAPI_ARC_DOCUMENTS_PROVIDER_BACKEND_DELEGATE_H_ |
+ |
+#include <memory> |
+ |
+#include "base/macros.h" |
+#include "base/memory/weak_ptr.h" |
+#include "chrome/browser/chromeos/arc/fileapi/arc_documents_provider_async_file_util.h" |
+#include "chrome/browser/chromeos/fileapi/file_system_backend_delegate.h" |
+ |
+namespace storage { |
+class AsyncFileUtil; |
+class FileSystemContext; |
+class FileStreamReader; |
+class FileStreamWriter; |
+class FileSystemURL; |
+} // namespace storage |
+ |
+namespace arc { |
+ |
+// Implements ARC documents provider filesystem. |
+class ArcDocumentsProviderBackendDelegate |
+ : public chromeos::FileSystemBackendDelegate { |
+ public: |
+ ArcDocumentsProviderBackendDelegate(); |
+ ~ArcDocumentsProviderBackendDelegate() override; |
+ |
+ // FileSystemBackend::Delegate overrides. |
+ storage::AsyncFileUtil* GetAsyncFileUtil( |
+ storage::FileSystemType type) override; |
+ std::unique_ptr<storage::FileStreamReader> CreateFileStreamReader( |
+ const storage::FileSystemURL& url, |
+ int64_t offset, |
+ int64_t max_bytes_to_read, |
+ const base::Time& expected_modification_time, |
+ storage::FileSystemContext* context) override; |
+ std::unique_ptr<storage::FileStreamWriter> CreateFileStreamWriter( |
+ const storage::FileSystemURL& url, |
+ int64_t offset, |
+ storage::FileSystemContext* context) override; |
+ storage::WatcherManager* GetWatcherManager( |
+ storage::FileSystemType type) override; |
+ void GetRedirectURLForContents(const storage::FileSystemURL& url, |
+ const storage::URLCallback& callback) override; |
+ |
+ private: |
+ ArcDocumentsProviderAsyncFileUtil async_file_util_; |
hashimoto
2016/12/13 07:52:29
How about adding this when it's actually needed?
Shuhei Takahashi
2016/12/13 10:27:47
Done. I assume you meant a line below :)
|
+ base::WeakPtrFactory<ArcDocumentsProviderBackendDelegate> weak_ptr_factory_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ArcDocumentsProviderBackendDelegate); |
+}; |
+ |
+} // namespace arc |
+ |
+#endif // CHROME_BROWSER_CHROMEOS_ARC_FILEAPI_ARC_DOCUMENTS_PROVIDER_BACKEND_DELEGATE_H_ |