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

Side by Side Diff: sync/api/attachments/attachment.h

Issue 2130453004: [Sync] Move //sync to //components/sync. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase. Created 4 years, 4 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 unified diff | Download patch
« no previous file with comments | « sync/api/attachments/README ('k') | sync/api/attachments/attachment.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef SYNC_API_ATTACHMENTS_ATTACHMENT_H_
6 #define SYNC_API_ATTACHMENTS_ATTACHMENT_H_
7
8 #include <stdint.h>
9
10 #include <map>
11 #include <memory>
12 #include <vector>
13
14 #include "base/memory/ref_counted.h"
15 #include "base/memory/ref_counted_memory.h"
16 #include "sync/api/attachments/attachment_id.h"
17 #include "sync/base/sync_export.h"
18
19 namespace syncer {
20
21 // A blob of in-memory data attached to a sync item.
22 //
23 // While Attachment objects themselves aren't immutable (they are assignable)
24 // the data they wrap is immutable.
25 //
26 // It is cheap to copy Attachments. Feel free to store and return by value.
27 class SYNC_EXPORT Attachment {
28 public:
29 Attachment(const Attachment& other);
30 ~Attachment();
31
32 // Default copy and assignment are welcome.
33
34 // Creates an attachment with a unique id and the supplied data.
35 //
36 // Used when creating a brand new attachment.
37 static Attachment Create(const scoped_refptr<base::RefCountedMemory>& data);
38
39 // Creates an attachment with the supplied id and data.
40 //
41 // Used when you want to recreate a specific attachment. E.g. creating a local
42 // copy of an attachment that already exists on the sync server.
43 static Attachment CreateFromParts(
44 const AttachmentId& id,
45 const scoped_refptr<base::RefCountedMemory>& data);
46
47 // Returns this attachment's id.
48 const AttachmentId& GetId() const;
49
50 // Returns this attachment's data.
51 const scoped_refptr<base::RefCountedMemory>& GetData() const;
52
53 // Returns precomputed crc32c hash of data. In ideal case this hash is
54 // computed when attachment is first created. It is then passed around through
55 // local attachment store and attachment server. Crc is verified when
56 // attachment is downloaded from server or loaded from local storage.
57 uint32_t GetCrc32c() const;
58
59 private:
60 AttachmentId id_;
61 scoped_refptr<base::RefCountedMemory> data_;
62
63 Attachment(const AttachmentId& id,
64 const scoped_refptr<base::RefCountedMemory>& data);
65 };
66
67 typedef std::vector<syncer::Attachment> AttachmentList;
68 typedef std::map<AttachmentId, Attachment> AttachmentMap;
69
70 } // namespace syncer
71
72 #endif // SYNC_API_ATTACHMENTS_ATTACHMENT_H_
OLDNEW
« no previous file with comments | « sync/api/attachments/README ('k') | sync/api/attachments/attachment.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698