Index: content/browser/download/download_file_impl.h |
diff --git a/content/browser/download/download_file_impl.h b/content/browser/download/download_file_impl.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..da406ee3a6752ab0a8de910c9143eea09b21092d |
--- /dev/null |
+++ b/content/browser/download/download_file_impl.h |
@@ -0,0 +1,71 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_IMPL_H_ |
+#define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_IMPL_H_ |
+#pragma once |
+ |
+#include "content/browser/download/download_file.h" |
+ |
+#include <string> |
+ |
+#include "base/basictypes.h" |
+#include "base/memory/ref_counted.h" |
+#include "content/browser/download/download_request_handle.h" |
+#include "content/common/content_export.h" |
+ |
+struct DownloadCreateInfo; |
+class DownloadManager; |
+ |
+// These objects live exclusively on the download thread and handle the writing |
Randy Smith (Not in Mondays)
2011/11/10 21:58:43
nit: Could you change "download thread" to "file
ahendrickson
2011/11/13 00:50:21
Done.
|
+// operations for one download. These objects live only for the duration that |
+// the download is 'in progress': once the download has been completed or |
+// cancelled, the DownloadFile is destroyed. |
Randy Smith (Not in Mondays)
2011/11/10 21:58:43
I'm ambivalent (so if you have a strong feeling, l
ahendrickson
2011/11/13 00:50:21
Done.
|
+class CONTENT_EXPORT DownloadFileImpl : virtual public DownloadFile { |
+ public: |
+ // Takes ownership of the object pointed to by |request_handle|. |
+ DownloadFileImpl(const DownloadCreateInfo* info, |
+ DownloadRequestHandleInterface* request_handle, |
+ DownloadManager* download_manager); |
+ virtual ~DownloadFileImpl(); |
+ |
+ // BaseFile delegated functions. |
Randy Smith (Not in Mondays)
2011/11/10 21:58:43
nit: The fact that these are delegated to the Base
ahendrickson
2011/11/13 00:50:21
Done.
|
+ virtual net::Error Initialize(bool calculate_hash); |
+ virtual net::Error AppendDataToFile(const char* data, size_t data_len); |
+ virtual net::Error Rename(const FilePath& full_path); |
+ virtual void Detach(); |
+ virtual void Cancel(); |
+ virtual void Finish(); |
+ virtual void AnnotateWithSourceInformation(); |
+ virtual FilePath FullPath() const; |
+ virtual bool InProgress() const; |
+ virtual int64 BytesSoFar() const; |
+ virtual bool GetSha256Hash(std::string* hash); |
+ |
+ // DownloadFile implementation. |
Randy Smith (Not in Mondays)
2011/11/10 21:58:43
The above is part of the DownloadFile implementati
Randy Smith (Not in Mondays)
2011/11/10 21:58:43
Shouldn't all functions that inherit from the Down
ahendrickson
2011/11/13 00:50:21
Yes
ahendrickson
2011/11/13 00:50:21
Done.
|
+ virtual void CancelDownloadRequest(); |
+ virtual int Id() const; |
+ virtual DownloadManager* GetDownloadManager(); |
+ virtual const DownloadId& GlobalId() const; |
+ virtual std::string DebugString() const; |
+ |
+ private: |
+ // The base file instance. |
+ BaseFile file_; |
+ |
+ // The unique identifier for this download, assigned at creation by |
+ // the DownloadFileManager for its internal record keeping. |
+ DownloadId id_; |
+ |
+ // The handle to the request information. Used for operations outside the |
+ // download system, specifically canceling a download. |
+ scoped_ptr<DownloadRequestHandleInterface> request_handle_; |
+ |
+ // DownloadManager this download belongs to. |
+ scoped_refptr<DownloadManager> download_manager_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(DownloadFileImpl); |
+}; |
+ |
+#endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_FILE_IMPL_H_ |