From df16ed24d3cdb487fa37b7b8cb5d6c74926a95dd Mon Sep 17 00:00:00 2001 From: "willchan@chromium.org" Date: Tue, 7 Dec 2010 05:15:44 +0000 Subject: Fix webkit URLRequestJob subtypes to handle Kill() correctly. Kill() should prevent calling back into the delegate. So we cancel pending callbacks. BUG=63692 TEST=existing Review URL: http://codereview.chromium.org/5545003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@68445 0039d316-1c4b-4281-b951-d872f2087c98 --- webkit/appcache/appcache_request_handler.h | 1 - webkit/appcache/appcache_url_request_job.cc | 12 ++++++--- webkit/appcache/appcache_url_request_job.h | 6 ++--- webkit/blob/blob_url_request_job.cc | 39 ++++++++++++++++------------- webkit/blob/blob_url_request_job.h | 2 ++ webkit/blob/view_blob_internals_job.cc | 14 ++++++++--- webkit/blob/view_blob_internals_job.h | 3 +++ 7 files changed, 48 insertions(+), 29 deletions(-) (limited to 'webkit') diff --git a/webkit/appcache/appcache_request_handler.h b/webkit/appcache/appcache_request_handler.h index e07a77c..b1cb331 100644 --- a/webkit/appcache/appcache_request_handler.h +++ b/webkit/appcache/appcache_request_handler.h @@ -124,4 +124,3 @@ class AppCacheRequestHandler : public net::URLRequest::UserData, } // namespace appcache #endif // WEBKIT_APPCACHE_APPCACHE_REQUEST_HANDLER_H_ - diff --git a/webkit/appcache/appcache_url_request_job.cc b/webkit/appcache/appcache_url_request_job.cc index c70cd7a..6a61674 100644 --- a/webkit/appcache/appcache_url_request_job.cc +++ b/webkit/appcache/appcache_url_request_job.cc @@ -6,6 +6,7 @@ #include "webkit/appcache/appcache_url_request_job.h" +#include "base/compiler_specific.h" #include "base/message_loop.h" #include "base/string_util.h" #include "base/stringprintf.h" @@ -27,7 +28,8 @@ AppCacheURLRequestJob::AppCacheURLRequestJob( cache_id_(kNoCacheId), is_fallback_(false), cache_entry_not_found_(false), ALLOW_THIS_IN_INITIALIZER_LIST(read_callback_( - this, &AppCacheURLRequestJob::OnReadComplete)) { + this, &AppCacheURLRequestJob::OnReadComplete)), + ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) { DCHECK(storage_); } @@ -67,8 +69,10 @@ void AppCacheURLRequestJob::MaybeBeginDelivery() { if (has_been_started() && has_delivery_orders()) { // Start asynchronously so that all error reporting and data // callbacks happen as they would for network requests. - MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( - this, &AppCacheURLRequestJob::BeginDelivery)); + MessageLoop::current()->PostTask( + FROM_HERE, + method_factory_.NewRunnableMethod( + &AppCacheURLRequestJob::BeginDelivery)); } } @@ -210,6 +214,7 @@ void AppCacheURLRequestJob::Kill() { storage_ = NULL; } URLRequestJob::Kill(); + method_factory_.RevokeAll(); } } @@ -278,4 +283,3 @@ void AppCacheURLRequestJob::SetExtraRequestHeaders( } } // namespace appcache - diff --git a/webkit/appcache/appcache_url_request_job.h b/webkit/appcache/appcache_url_request_job.h index 8630815..7491e71 100644 --- a/webkit/appcache/appcache_url_request_job.h +++ b/webkit/appcache/appcache_url_request_job.h @@ -7,6 +7,7 @@ #include +#include "base/task.h" #include "net/http/http_byte_range.h" #include "net/url_request/url_request_job.h" #include "webkit/appcache/appcache_entry.h" @@ -20,8 +21,7 @@ namespace appcache { class AppCacheURLRequestJob : public net::URLRequestJob, public AppCacheStorage::Delegate { public: - explicit AppCacheURLRequestJob(net::URLRequest* request, - AppCacheStorage* storage); + AppCacheURLRequestJob(net::URLRequest* request, AppCacheStorage* storage); virtual ~AppCacheURLRequestJob(); // Informs the job of what response it should deliver. Only one of these @@ -143,9 +143,9 @@ class AppCacheURLRequestJob : public net::URLRequestJob, scoped_ptr range_response_info_; scoped_ptr reader_; net::CompletionCallbackImpl read_callback_; + ScopedRunnableMethodFactory method_factory_; }; } // namespace appcache #endif // WEBKIT_APPCACHE_APPCACHE_REQUEST_HANDLER_H_ - diff --git a/webkit/blob/blob_url_request_job.cc b/webkit/blob/blob_url_request_job.cc index 6b62605..bbe26be 100644 --- a/webkit/blob/blob_url_request_job.cc +++ b/webkit/blob/blob_url_request_job.cc @@ -4,6 +4,7 @@ #include "webkit/blob/blob_url_request_job.h" +#include "base/compiler_specific.h" #include "base/file_path.h" #include "base/file_util.h" #include "base/file_util_proxy.h" @@ -30,14 +31,14 @@ static const int kHTTPMethodNotAllow = 405; static const int kHTTPRequestedRangeNotSatisfiable = 416; static const int kHTTPInternalError = 500; -static const char* kHTTPOKText = "OK"; -static const char* kHTTPPartialContentText = "Partial Content"; -static const char* kHTTPNotAllowedText = "Not Allowed"; -static const char* kHTTPNotFoundText = "Not Found"; -static const char* kHTTPMethodNotAllowText = "Method Not Allowed"; -static const char* kHTTPRequestedRangeNotSatisfiableText = +static const char kHTTPOKText[] = "OK"; +static const char kHTTPPartialContentText[] = "Partial Content"; +static const char kHTTPNotAllowedText[] = "Not Allowed"; +static const char kHTTPNotFoundText[] = "Not Found"; +static const char kHTTPMethodNotAllowText[] = "Method Not Allowed"; +static const char kHTTPRequestedRangeNotSatisfiableText[] = "Requested Range Not Satisfiable"; -static const char* kHTTPInternalErrorText = "Internal Server Error"; +static const char kHTTPInternalErrorText[] = "Internal Server Error"; BlobURLRequestJob::BlobURLRequestJob( net::URLRequest* request, @@ -58,7 +59,8 @@ BlobURLRequestJob::BlobURLRequestJob( read_buf_remaining_bytes_(0), error_(false), headers_set_(false), - byte_range_set_(false) { + byte_range_set_(false), + ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) { } BlobURLRequestJob::~BlobURLRequestJob() { @@ -66,8 +68,9 @@ BlobURLRequestJob::~BlobURLRequestJob() { void BlobURLRequestJob::Start() { // Continue asynchronously. - MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( - this, &BlobURLRequestJob::DidStart)); + MessageLoop::current()->PostTask( + FROM_HERE, + method_factory_.NewRunnableMethod(&BlobURLRequestJob::DidStart)); } void BlobURLRequestJob::DidStart() { @@ -90,6 +93,8 @@ void BlobURLRequestJob::Kill() { stream_.Close(); URLRequestJob::Kill(); + callback_factory_.RevokeAll(); + method_factory_.RevokeAll(); } void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { @@ -109,18 +114,16 @@ void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { bool exists = file_util::GetFileInfo(file_path, &file_info); // Continue asynchronously. - MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( - this, &BlobURLRequestJob::DidResolve, - (exists ? base::PLATFORM_FILE_OK : base::PLATFORM_FILE_ERROR_NOT_FOUND), - file_info)); + MessageLoop::current()->PostTask( + FROM_HERE, + method_factory_.NewRunnableMethod( + &BlobURLRequestJob::DidResolve, + exists ? base::PLATFORM_FILE_OK : base::PLATFORM_FILE_ERROR_NOT_FOUND, + file_info)); } void BlobURLRequestJob::DidResolve(base::PlatformFileError rv, const base::PlatformFileInfo& file_info) { - // We may have been orphaned... - if (!request_) - return; - // If an error occured, bail out. if (rv == base::PLATFORM_FILE_ERROR_NOT_FOUND) { NotifyFailure(net::ERR_FILE_NOT_FOUND); diff --git a/webkit/blob/blob_url_request_job.h b/webkit/blob/blob_url_request_job.h index 53414cd..c82ebfc 100644 --- a/webkit/blob/blob_url_request_job.h +++ b/webkit/blob/blob_url_request_job.h @@ -9,6 +9,7 @@ #include "base/ref_counted.h" #include "base/scoped_callback_factory.h" #include "base/scoped_ptr.h" +#include "base/task.h" #include "net/base/completion_callback.h" #include "net/base/file_stream.h" #include "net/http/http_byte_range.h" @@ -78,6 +79,7 @@ class BlobURLRequestJob : public net::URLRequestJob { bool byte_range_set_; net::HttpByteRange byte_range_; scoped_ptr response_info_; + ScopedRunnableMethodFactory method_factory_; DISALLOW_COPY_AND_ASSIGN(BlobURLRequestJob); }; diff --git a/webkit/blob/view_blob_internals_job.cc b/webkit/blob/view_blob_internals_job.cc index 6d6955b..49798b4 100644 --- a/webkit/blob/view_blob_internals_job.cc +++ b/webkit/blob/view_blob_internals_job.cc @@ -4,6 +4,7 @@ #include "webkit/blob/view_blob_internals_job.h" +#include "base/compiler_specific.h" #include "base/logging.h" #include "base/format_macros.h" #include "base/i18n/number_formatting.h" @@ -102,15 +103,17 @@ namespace webkit_blob { ViewBlobInternalsJob::ViewBlobInternalsJob( net::URLRequest* request, BlobStorageController* blob_storage_controller) : URLRequestSimpleJob(request), - blob_storage_controller_(blob_storage_controller) { + blob_storage_controller_(blob_storage_controller), + ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) { } ViewBlobInternalsJob::~ViewBlobInternalsJob() { } void ViewBlobInternalsJob::Start() { - MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( - this, &ViewBlobInternalsJob::DoWorkAsync)); + MessageLoop::current()->PostTask( + FROM_HERE, + method_factory_.NewRunnableMethod(&ViewBlobInternalsJob::DoWorkAsync)); } bool ViewBlobInternalsJob::IsRedirectResponse(GURL* location, @@ -126,6 +129,11 @@ bool ViewBlobInternalsJob::IsRedirectResponse(GURL* location, return false; } +void ViewBlobInternalsJob::Kill() { + URLRequestSimpleJob::Kill(); + method_factory_.RevokeAll(); +} + void ViewBlobInternalsJob::DoWorkAsync() { if (request_->url().has_query() && StartsWithASCII(request_->url().query(), "remove=", true)) { diff --git a/webkit/blob/view_blob_internals_job.h b/webkit/blob/view_blob_internals_job.h index 913531c..2f557ae 100644 --- a/webkit/blob/view_blob_internals_job.h +++ b/webkit/blob/view_blob_internals_job.h @@ -7,6 +7,7 @@ #include +#include "base/task.h" #include "net/url_request/url_request_simple_job.h" namespace net { @@ -30,6 +31,7 @@ class ViewBlobInternalsJob : public URLRequestSimpleJob { std::string* charset, std::string* data) const; virtual bool IsRedirectResponse(GURL* location, int* http_status_code); + virtual void Kill(); private: ~ViewBlobInternalsJob(); @@ -40,6 +42,7 @@ class ViewBlobInternalsJob : public URLRequestSimpleJob { std::string* out); BlobStorageController* blob_storage_controller_; + ScopedRunnableMethodFactory method_factory_; DISALLOW_COPY_AND_ASSIGN(ViewBlobInternalsJob); }; -- cgit v1.1