Chromium Code Reviews| Index: chrome/browser/sync_file_system/remote_change_processor.h |
| diff --git a/chrome/browser/sync_file_system/remote_change_processor.h b/chrome/browser/sync_file_system/remote_change_processor.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..25ea9c1731d58d25dad0d6f62288e210342986a1 |
| --- /dev/null |
| +++ b/chrome/browser/sync_file_system/remote_change_processor.h |
| @@ -0,0 +1,63 @@ |
| +// Copyright (c) 2012 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_SYNC_FILE_SYSTEM_REMOTE_CHANGE_PROCESSOR_H_ |
| +#define CHROME_BROWSER_SYNC_FILE_SYSTEM_REMOTE_CHANGE_PROCESSOR_H_ |
| + |
| +#include "base/basictypes.h" |
| +#include "base/callback_forward.h" |
| +#include "webkit/fileapi/syncable/sync_status_code.h" |
| + |
| +class FilePath; |
| + |
| +namespace fileapi { |
| +class FileChange; |
| +class FileChangeList; |
| +class FileSystemURL; |
| +} |
| + |
| +namespace sync_file_system { |
| + |
| +// Represents an interface to process one remote change and applies |
| +// it to the local file system. |
| +// This interface is to be implemented/backed by LocalSyncFileService. |
| +class RemoteChangeProcessor { |
| + public: |
| + typedef base::Callback<void( |
| + fileapi::SyncStatusCode status, |
| + fileapi::FileChangeList& change)> PrepareChangeCallback; |
| + typedef base::Callback<void(fileapi::SyncStatusCode status)> StatusCallback; |
| + |
| + RemoteChangeProcessor() {} |
| + virtual ~RemoteChangeProcessor() {} |
| + |
| + // This must be called before processing the change for the |url|. |
| + // This tries to lock the target |url| and returns the local changes |
| + // if any. (The change returned by the callback is to make a decision |
| + // on conflict resolution, but NOT for applying local changes to the remote, |
| + // which is supposed to be done by LocalChangeProcessor) |
|
tzik
2012/10/22 12:28:19
Should we invoke the callback soon, when we fail t
kinuko
2012/10/22 12:38:03
I'm thinking about let it fail with an error like
|
| + virtual void PrepareForProcessRemoteChange( |
| + const fileapi::FileSystemURL& url, |
| + const PrepareChangeCallback& callback) = 0; |
| + |
| + // This is called to apply the remote |change|. If the change type is |
| + // ADD_OR_UPDATE for a file, |local_path| needs to point to a |
| + // local file path that contains the latest file image (e.g. a path |
| + // to a temporary file which has the data downloaded from the server). |
| + // This may fail with an error but should NOT result in a conflict |
| + // (as we must have checked the change status in PrepareRemoteSync and |
| + // have disabled any further writing). |
| + virtual void ApplyRemoteChange( |
| + const fileapi::FileChange& change, |
| + const FilePath& local_path, |
| + const fileapi::FileSystemURL& url, |
| + const StatusCallback& callback) = 0; |
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(RemoteChangeProcessor); |
| +}; |
| + |
| +} // namespace sync_file_system |
| + |
| +#endif // CHROME_BROWSER_SYNC_FILE_SYSTEM_REMOTE_CHANGE_PROCESSOR_H_ |