Index: chrome/browser/local_discovery/storage/privet_filesystem_backend.h |
diff --git a/chrome/browser/local_discovery/storage/privet_filesystem_backend.h b/chrome/browser/local_discovery/storage/privet_filesystem_backend.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3e9368465d1a5856c5e2addc5f398379c5b7b82a |
--- /dev/null |
+++ b/chrome/browser/local_discovery/storage/privet_filesystem_backend.h |
@@ -0,0 +1,69 @@ |
+// Copyright 2014 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_LOCAL_DISCOVERY_STORAGE_PRIVET_FILESYSTEM_BACKEND_H_ |
+#define CHROME_BROWSER_LOCAL_DISCOVERY_STORAGE_PRIVET_FILESYSTEM_BACKEND_H_ |
+ |
+#include <string> |
+#include <vector> |
+ |
+#include "base/memory/ref_counted.h" |
+#include "webkit/browser/blob/file_stream_reader.h" |
+#include "webkit/browser/fileapi/external_mount_points.h" |
+#include "webkit/browser/fileapi/file_stream_writer.h" |
+#include "webkit/browser/fileapi/file_system_backend.h" |
+ |
+namespace local_discovery { |
+ |
+class PrivetFileSystemAsyncUtil; |
+ |
+class PrivetFileSystemBackend : public fileapi::FileSystemBackend { |
+ public: |
+ explicit PrivetFileSystemBackend(fileapi::ExternalMountPoints* mount_points); |
+ virtual ~PrivetFileSystemBackend(); |
+ |
+ // FileSystemBackend implementation. |
+ virtual bool CanHandleType(fileapi::FileSystemType type) const OVERRIDE; |
+ virtual void Initialize(fileapi::FileSystemContext* context) OVERRIDE; |
+ |
+ virtual void OpenFileSystem( |
+ const GURL& origin_url, |
+ fileapi::FileSystemType type, |
+ fileapi::OpenFileSystemMode mode, |
+ const OpenFileSystemCallback& callback) OVERRIDE; |
+ |
+ virtual fileapi::AsyncFileUtil* GetAsyncFileUtil( |
+ fileapi::FileSystemType type) OVERRIDE; |
+ virtual fileapi::CopyOrMoveFileValidatorFactory* |
+ GetCopyOrMoveFileValidatorFactory( |
+ fileapi::FileSystemType type, |
+ base::PlatformFileError* error_code) OVERRIDE; |
+ |
+ virtual fileapi::FileSystemOperation* CreateFileSystemOperation( |
+ const fileapi::FileSystemURL& url, |
+ fileapi::FileSystemContext* context, |
+ base::PlatformFileError* error_code) const OVERRIDE; |
+ |
+ virtual scoped_ptr<webkit_blob::FileStreamReader> CreateFileStreamReader( |
+ const fileapi::FileSystemURL& url, |
+ int64 offset, |
+ const base::Time& expected_modification_time, |
+ fileapi::FileSystemContext* context) const OVERRIDE; |
+ |
+ virtual scoped_ptr<fileapi::FileStreamWriter> CreateFileStreamWriter( |
+ const fileapi::FileSystemURL& url, |
+ int64 offset, |
+ fileapi::FileSystemContext* context) const OVERRIDE; |
+ |
+ virtual fileapi::FileSystemQuotaUtil* GetQuotaUtil() OVERRIDE; |
+ |
+ private: |
+ // User mount points. |
+ scoped_refptr<fileapi::ExternalMountPoints> mount_points_; |
+ scoped_ptr<PrivetFileSystemAsyncUtil> async_util_; |
+}; |
+ |
+} // namespace local_discovery |
+ |
+#endif // CHROME_BROWSER_LOCAL_DISCOVERY_STORAGE_PRIVET_FILESYSTEM_BACKEND_H_ |