OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ | 5 #ifndef CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ |
6 #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ | 6 #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/file_path.h" | 11 #include "base/file_path.h" |
12 #include "base/memory/linked_ptr.h" | 12 #include "base/memory/linked_ptr.h" |
13 #include "base/synchronization/lock.h" | 13 #include "base/synchronization/lock.h" |
14 #include "content/common/content_export.h" | 14 #include "content/common/content_export.h" |
15 #include "net/base/file_stream.h" | 15 #include "net/base/file_stream.h" |
16 | 16 |
17 namespace net { | 17 namespace net { |
18 class IOBuffer; | 18 class IOBuffer; |
19 } | 19 } |
20 | 20 |
21 // DownloadBuffer is created and populated on the IO thread, and passed to the | 21 // DownloadBuffer is created and populated on the IO thread, and passed to the |
22 // file thread for writing. In order to avoid flooding the file thread with too | 22 // file thread for writing. In order to avoid flooding the file thread with too |
23 // many small write messages, each write is appended to the DownloadBuffer while | 23 // many small write messages, each write is appended to the DownloadBuffer while |
24 // waiting for the task to run on the file thread. Access to the write buffers | 24 // waiting for the task to run on the file thread. Access to the write buffers |
25 // is synchronized via the lock. Each entry in 'contents' represents one data | 25 // is synchronized via the lock. Each entry in 'contents' represents one data |
26 // buffer and its size in bytes. | 26 // buffer and its size in bytes. |
27 struct DownloadBuffer { | 27 struct CONTENT_EXPORT DownloadBuffer { |
28 DownloadBuffer(); | 28 DownloadBuffer(); |
29 ~DownloadBuffer(); | 29 ~DownloadBuffer(); |
30 | 30 |
31 base::Lock lock; | 31 base::Lock lock; |
32 typedef std::pair<net::IOBuffer*, int> Contents; | 32 typedef std::pair<net::IOBuffer*, int> Contents; |
33 std::vector<Contents> contents; | 33 std::vector<Contents> contents; |
34 }; | 34 }; |
35 | 35 |
36 // Holds the information about how to save a download file. | 36 // Holds the information about how to save a download file. |
37 struct CONTENT_EXPORT DownloadSaveInfo { | 37 struct CONTENT_EXPORT DownloadSaveInfo { |
38 DownloadSaveInfo(); | 38 DownloadSaveInfo(); |
39 DownloadSaveInfo(const DownloadSaveInfo& info); | 39 DownloadSaveInfo(const DownloadSaveInfo& info); |
40 ~DownloadSaveInfo(); | 40 ~DownloadSaveInfo(); |
41 DownloadSaveInfo& operator=(const DownloadSaveInfo& info); | 41 DownloadSaveInfo& operator=(const DownloadSaveInfo& info); |
42 | 42 |
43 FilePath file_path; | 43 FilePath file_path; |
44 linked_ptr<net::FileStream> file_stream; | 44 linked_ptr<net::FileStream> file_stream; |
45 string16 suggested_name; | 45 string16 suggested_name; |
46 }; | 46 }; |
47 | 47 |
48 #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ | 48 #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_TYPES_H_ |
OLD | NEW |