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