diff options
author | raymes@chromium.org <raymes@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-13 07:14:45 +0000 |
---|---|---|
committer | raymes@chromium.org <raymes@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-13 07:14:45 +0000 |
commit | 993c38816404ba88b532bbaef4aaf232cdcf1dea (patch) | |
tree | cd900262eadebf5fab3734d6a1bd3870d1d0678a | |
parent | 244722b1cbc6adbc2d662fbb9ff06c92d350241c (diff) | |
download | chromium_src-993c38816404ba88b532bbaef4aaf232cdcf1dea.zip chromium_src-993c38816404ba88b532bbaef4aaf232cdcf1dea.tar.gz chromium_src-993c38816404ba88b532bbaef4aaf232cdcf1dea.tar.bz2 |
Merge DidStartLoading/DidStopLoading imbalance patch to OOP PDF
This merges this CL https://chromereviews.googleplex.com/32997013/ to OOP PDF
and also corrects some minor differences that had arisen in document loading.
BUG=303491
Review URL: https://codereview.chromium.org/333553003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@276954 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | pdf/out_of_process_instance.cc | 37 | ||||
-rw-r--r-- | pdf/out_of_process_instance.h | 5 |
2 files changed, 28 insertions, 14 deletions
diff --git a/pdf/out_of_process_instance.cc b/pdf/out_of_process_instance.cc index 49b14ee..8a692c9 100644 --- a/pdf/out_of_process_instance.cc +++ b/pdf/out_of_process_instance.cc @@ -243,7 +243,8 @@ OutOfProcessInstance::OutOfProcessInstance(PP_Instance instance) print_preview_page_count_(0), last_progress_sent_(0), recently_sent_find_update_(false), - received_viewport_message_(false) { + received_viewport_message_(false), + did_call_start_loading_(false) { loader_factory_.Initialize(this); timer_factory_.Initialize(this); form_factory_.Initialize(this); @@ -1002,6 +1003,19 @@ std::string OutOfProcessInstance::ShowFileSelectionDialog() { } pp::URLLoader OutOfProcessInstance::CreateURLLoader() { + if (full_) { + if (!did_call_start_loading_) { + did_call_start_loading_ = true; + pp::PDF::DidStartLoading(this); + } + + // Disable save and print until the document is fully loaded, since they + // would generate an incomplete document. Need to do this each time we + // call DidStartLoading since that resets the content restrictions. + pp::PDF::SetContentRestriction(this, CONTENT_RESTRICTION_SAVE | + CONTENT_RESTRICTION_PRINT); + } + return CreateURLLoaderInternal(); } @@ -1065,7 +1079,10 @@ void OutOfProcessInstance::DocumentLoadComplete(int page_count) { if (!full_) return; - pp::PDF::DidStopLoading(this); + if (did_call_start_loading_) { + pp::PDF::DidStopLoading(this); + did_call_start_loading_ = false; + } int content_restrictions = CONTENT_RESTRICTION_CUT | CONTENT_RESTRICTION_PASTE; @@ -1119,10 +1136,12 @@ void OutOfProcessInstance::DocumentLoadFailed() { DCHECK(document_load_state_ == LOAD_STATE_LOADING); UserMetricsRecordAction("PDF.LoadFailure"); - if (full_) + if (did_call_start_loading_) { pp::PDF::DidStopLoading(this); - document_load_state_ = LOAD_STATE_FAILED; + did_call_start_loading_ = false; + } + document_load_state_ = LOAD_STATE_FAILED; paint_manager_.InvalidateRect(pp::Rect(pp::Point(), plugin_size_)); // Send a progress value of -1 to indicate a failure. @@ -1263,16 +1282,6 @@ void OutOfProcessInstance::LoadUrlInternal( } pp::URLLoader OutOfProcessInstance::CreateURLLoaderInternal() { - if (full_) { - pp::PDF::DidStartLoading(this); - - // Disable save and print until the document is fully loaded, since they - // would generate an incomplete document. Need to do this each time we - // call DidStartLoading since that resets the content restrictions. - pp::PDF::SetContentRestriction(this, CONTENT_RESTRICTION_SAVE | - CONTENT_RESTRICTION_PRINT); - } - pp::URLLoader loader(this); const PPB_URLLoaderTrusted* trusted_interface = diff --git a/pdf/out_of_process_instance.h b/pdf/out_of_process_instance.h index ada259f..bd70be2 100644 --- a/pdf/out_of_process_instance.h +++ b/pdf/out_of_process_instance.h @@ -328,6 +328,11 @@ class OutOfProcessInstance : public pp::Instance, // be painted until this is received. bool received_viewport_message_; + // If true, this means we told the RenderView that we're starting a network + // request so that it can start the throbber. We will tell it again once the + // document finishes loading. + bool did_call_start_loading_; + // The callback for receiving the password from the page. scoped_ptr<pp::CompletionCallbackWithOutput<pp::Var> > password_callback_; }; |