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_FILE_H_ | 5 #ifndef CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_H_ |
6 #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_H_ | 6 #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
13 #include "content/browser/download/base_file.h" | 13 #include "content/browser/download/base_file.h" |
| 14 #include "content/browser/download/download_id.h" |
14 #include "content/browser/download/download_request_handle.h" | 15 #include "content/browser/download/download_request_handle.h" |
15 #include "content/browser/download/download_types.h" | 16 #include "content/browser/download/download_types.h" |
16 #include "content/common/content_export.h" | 17 #include "content/common/content_export.h" |
17 | 18 |
18 struct DownloadCreateInfo; | 19 struct DownloadCreateInfo; |
19 class DownloadManager; | 20 class DownloadManager; |
20 class ResourceDispatcherHost; | 21 class ResourceDispatcherHost; |
21 | 22 |
22 // These objects live exclusively on the download thread and handle the writing | 23 // These objects live exclusively on the download thread and handle the writing |
23 // operations for one download. These objects live only for the duration that | 24 // operations for one download. These objects live only for the duration that |
24 // the download is 'in progress': once the download has been completed or | 25 // the download is 'in progress': once the download has been completed or |
25 // cancelled, the DownloadFile is destroyed. | 26 // cancelled, the DownloadFile is destroyed. |
26 class CONTENT_EXPORT DownloadFile : public BaseFile { | 27 class CONTENT_EXPORT DownloadFile : public BaseFile { |
27 public: | 28 public: |
28 DownloadFile(const DownloadCreateInfo* info, | 29 DownloadFile(const DownloadCreateInfo* info, |
29 const DownloadRequestHandle& request_handle, | 30 const DownloadRequestHandle& request_handle, |
30 DownloadManager* download_manager); | 31 DownloadManager* download_manager); |
31 virtual ~DownloadFile(); | 32 virtual ~DownloadFile(); |
32 | 33 |
33 // Cancels the download request associated with this file. | 34 // Cancels the download request associated with this file. |
34 void CancelDownloadRequest(); | 35 void CancelDownloadRequest(); |
35 | 36 |
36 int id() const { return id_; } | 37 int id() const { return id_.local(); } |
37 DownloadManager* GetDownloadManager(); | 38 DownloadManager* GetDownloadManager(); |
| 39 const DownloadId& global_id() const { return id_; } |
38 | 40 |
39 virtual std::string DebugString() const; | 41 virtual std::string DebugString() const; |
40 | 42 |
41 // Appends the passed the number between parenthesis the path before the | 43 // Appends the passed the number between parenthesis the path before the |
42 // extension. | 44 // extension. |
43 static void AppendNumberToPath(FilePath* path, int number); | 45 static void AppendNumberToPath(FilePath* path, int number); |
44 | 46 |
45 // Attempts to find a number that can be appended to that path to make it | 47 // Attempts to find a number that can be appended to that path to make it |
46 // unique. If |path| does not exist, 0 is returned. If it fails to find such | 48 // unique. If |path| does not exist, 0 is returned. If it fails to find such |
47 // a number, -1 is returned. | 49 // a number, -1 is returned. |
48 static int GetUniquePathNumber(const FilePath& path); | 50 static int GetUniquePathNumber(const FilePath& path); |
49 | 51 |
50 static FilePath AppendSuffixToPath(const FilePath& path, | 52 static FilePath AppendSuffixToPath(const FilePath& path, |
51 const FilePath::StringType& suffix); | 53 const FilePath::StringType& suffix); |
52 | 54 |
53 // Same as GetUniquePathNumber, except that it also checks the existence | 55 // Same as GetUniquePathNumber, except that it also checks the existence |
54 // of it with the given suffix. | 56 // of it with the given suffix. |
55 // If |path| does not exist, 0 is returned. If it fails to find such | 57 // If |path| does not exist, 0 is returned. If it fails to find such |
56 // a number, -1 is returned. | 58 // a number, -1 is returned. |
57 static int GetUniquePathNumberWithSuffix( | 59 static int GetUniquePathNumberWithSuffix( |
58 const FilePath& path, | 60 const FilePath& path, |
59 const FilePath::StringType& suffix); | 61 const FilePath::StringType& suffix); |
60 | 62 |
61 private: | 63 private: |
62 // The unique identifier for this download, assigned at creation by | 64 // The unique identifier for this download, assigned at creation by |
63 // the DownloadFileManager for its internal record keeping. | 65 // the DownloadFileManager for its internal record keeping. |
64 int id_; | 66 DownloadId id_; |
65 | 67 |
66 // The handle to the request information. Used for operations outside the | 68 // The handle to the request information. Used for operations outside the |
67 // download system, specifically canceling a download. | 69 // download system, specifically canceling a download. |
68 DownloadRequestHandle request_handle_; | 70 DownloadRequestHandle request_handle_; |
69 | 71 |
70 // DownloadManager this download belongs to. | 72 // DownloadManager this download belongs to. |
71 scoped_refptr<DownloadManager> download_manager_; | 73 scoped_refptr<DownloadManager> download_manager_; |
72 | 74 |
73 DISALLOW_COPY_AND_ASSIGN(DownloadFile); | 75 DISALLOW_COPY_AND_ASSIGN(DownloadFile); |
74 }; | 76 }; |
75 | 77 |
76 #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_H_ | 78 #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_H_ |
OLD | NEW |