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

Side by Side Diff: content/common/resource_request_body.h

Issue 367653002: Add a FrameHostMsg_BeginNavigation IPC (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Added unit test + fixed bug in parent_is_render_frame_computation Created 6 years, 5 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_ 5 #ifndef CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_
6 #define CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_ 6 #define CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_
7 7
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
11 #include "base/memory/ref_counted.h" 11 #include "base/memory/ref_counted.h"
12 #include "base/supports_user_data.h" 12 #include "base/supports_user_data.h"
13 #include "content/common/content_export.h" 13 #include "content/common/content_export.h"
14 #include "url/gurl.h" 14 #include "url/gurl.h"
15 #include "webkit/common/data_element.h" 15 #include "webkit/common/data_element.h"
16 16
17 namespace base { 17 namespace base {
18 class FilePath; 18 class FilePath;
19 } 19 }
20 20
21 namespace content { 21 namespace content {
22 22
23 // A struct used to represent upload data. The data field is populated by 23 // A struct used to represent upload data. The data field is populated by
24 // WebURLLoader from the data given as WebHTTPBody. 24 // WebURLLoader from the data given as WebHTTPBody.
25 class CONTENT_EXPORT ResourceRequestBody 25 class CONTENT_EXPORT ResourceRequestBody
26 : public base::RefCounted<ResourceRequestBody>, 26 : public base::RefCountedThreadSafe<ResourceRequestBody>,
nasko 2014/07/07 11:35:09 Is there a different pattern we might use for send
clamy 2014/07/07 13:36:23 I'm afraid I don't see a better one :).
27 public base::SupportsUserData { 27 public base::SupportsUserData {
28 public: 28 public:
29 typedef webkit_common::DataElement Element; 29 typedef webkit_common::DataElement Element;
30 30
31 ResourceRequestBody(); 31 ResourceRequestBody();
32 virtual ~ResourceRequestBody();
nasko 2014/07/07 11:35:09 Why is the destructor now public?
clamy 2014/07/07 13:36:23 Since I forgot to change the friend class, it woul
32 33
33 void AppendBytes(const char* bytes, int bytes_len); 34 void AppendBytes(const char* bytes, int bytes_len);
34 void AppendFileRange(const base::FilePath& file_path, 35 void AppendFileRange(const base::FilePath& file_path,
35 uint64 offset, uint64 length, 36 uint64 offset, uint64 length,
36 const base::Time& expected_modification_time); 37 const base::Time& expected_modification_time);
37 void AppendBlob(const std::string& uuid); 38 void AppendBlob(const std::string& uuid);
38 void AppendFileSystemFileRange(const GURL& url, uint64 offset, uint64 length, 39 void AppendFileSystemFileRange(const GURL& url, uint64 offset, uint64 length,
39 const base::Time& expected_modification_time); 40 const base::Time& expected_modification_time);
40 41
41 const std::vector<Element>* elements() const { return &elements_; } 42 const std::vector<Element>* elements() const { return &elements_; }
42 std::vector<Element>* elements_mutable() { return &elements_; } 43 std::vector<Element>* elements_mutable() { return &elements_; }
43 void swap_elements(std::vector<Element>* elements) { 44 void swap_elements(std::vector<Element>* elements) {
44 elements_.swap(*elements); 45 elements_.swap(*elements);
45 } 46 }
46 47
47 // Identifies a particular upload instance, which is used by the cache to 48 // Identifies a particular upload instance, which is used by the cache to
48 // formulate a cache key. This value should be unique across browser 49 // formulate a cache key. This value should be unique across browser
49 // sessions. A value of 0 is used to indicate an unspecified identifier. 50 // sessions. A value of 0 is used to indicate an unspecified identifier.
50 void set_identifier(int64 id) { identifier_ = id; } 51 void set_identifier(int64 id) { identifier_ = id; }
51 int64 identifier() const { return identifier_; } 52 int64 identifier() const { return identifier_; }
52 53
53 private: 54 private:
54 friend class base::RefCounted<ResourceRequestBody>; 55 friend class base::RefCounted<ResourceRequestBody>;
nasko 2014/07/07 11:35:09 Shouldn't this be RefCountedThreadSafe?
clamy 2014/07/07 13:36:23 Done.
55 virtual ~ResourceRequestBody();
56 56
57 std::vector<Element> elements_; 57 std::vector<Element> elements_;
58 int64 identifier_; 58 int64 identifier_;
59 59
60 DISALLOW_COPY_AND_ASSIGN(ResourceRequestBody); 60 DISALLOW_COPY_AND_ASSIGN(ResourceRequestBody);
61 }; 61 };
62 62
63 } // namespace content 63 } // namespace content
64 64
65 #endif // CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_ 65 #endif // CONTENT_COMMON_RESOURCE_REQUEST_BODY_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698