Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(579)

Unified Diff: webkit/plugins/ppapi/ppb_url_loader_impl.cc

Issue 6254003: Revert 71334 - Fix Pepper URL Loader callbacks.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webkit/plugins/ppapi/ppb_url_loader_impl.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webkit/plugins/ppapi/ppb_url_loader_impl.cc
===================================================================
--- webkit/plugins/ppapi/ppb_url_loader_impl.cc (revision 71399)
+++ webkit/plugins/ppapi/ppb_url_loader_impl.cc (working copy)
@@ -1,4 +1,4 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Copyright (c) 2010 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.
@@ -21,7 +21,6 @@
#include "third_party/WebKit/WebKit/chromium/public/WebURLResponse.h"
#include "webkit/appcache/web_application_cache_host_impl.h"
#include "webkit/plugins/ppapi/common.h"
-#include "webkit/plugins/ppapi/plugin_module.h"
#include "webkit/plugins/ppapi/ppapi_plugin_instance.h"
#include "webkit/plugins/ppapi/ppb_url_request_info_impl.h"
#include "webkit/plugins/ppapi/ppb_url_response_info_impl.h"
@@ -233,19 +232,19 @@
int32_t PPB_URLLoader_Impl::Open(PPB_URLRequestInfo_Impl* request,
PP_CompletionCallback callback) {
- int32_t rv = ValidateCallback(callback);
- if (rv != PP_OK)
- return rv;
-
if (loader_.get())
return PP_ERROR_INPROGRESS;
+ // We only support non-blocking calls.
+ if (!callback.func)
+ return PP_ERROR_BADARGUMENT;
+
WebFrame* frame = GetFrame(instance_);
if (!frame)
return PP_ERROR_FAILED;
WebURLRequest web_request(request->ToWebURLRequest(frame));
- rv = CanRequest(frame, web_request.url());
+ int32_t rv = CanRequest(frame, web_request.url());
if (rv != PP_OK)
return rv;
@@ -264,25 +263,28 @@
loader_->loadAsynchronously(web_request, this);
request_info_ = scoped_refptr<PPB_URLRequestInfo_Impl>(request);
+ pending_callback_ = callback;
// Notify completion when we receive a redirect or response headers.
- RegisterCallback(callback);
return PP_ERROR_WOULDBLOCK;
}
int32_t PPB_URLLoader_Impl::FollowRedirect(PP_CompletionCallback callback) {
- int32_t rv = ValidateCallback(callback);
- if (rv != PP_OK)
- return rv;
+ if (pending_callback_.func)
+ return PP_ERROR_INPROGRESS;
+ // We only support non-blocking calls.
+ if (!callback.func)
+ return PP_ERROR_BADARGUMENT;
+
WebURL redirect_url = GURL(response_info_->redirect_url());
- rv = CanRequest(GetFrame(instance_), redirect_url);
+ int32_t rv = CanRequest(GetFrame(instance_), redirect_url);
if (rv != PP_OK)
return rv;
+ pending_callback_ = callback;
loader_->setDefersLoading(false); // Allow the redirect to continue.
- RegisterCallback(callback);
return PP_ERROR_WOULDBLOCK;
}
@@ -314,14 +316,17 @@
int32_t PPB_URLLoader_Impl::ReadResponseBody(char* buffer,
int32_t bytes_to_read,
PP_CompletionCallback callback) {
- int32_t rv = ValidateCallback(callback);
- if (rv != PP_OK)
- return rv;
if (!response_info_ || response_info_->body())
return PP_ERROR_FAILED;
if (bytes_to_read <= 0 || !buffer)
return PP_ERROR_BADARGUMENT;
+ if (pending_callback_.func)
+ return PP_ERROR_INPROGRESS;
+ // We only support non-blocking calls.
+ if (!callback.func)
+ return PP_ERROR_BADARGUMENT;
+
user_buffer_ = buffer;
user_buffer_size_ = bytes_to_read;
@@ -335,24 +340,23 @@
return done_status_;
}
- RegisterCallback(callback);
+ pending_callback_ = callback;
return PP_ERROR_WOULDBLOCK;
}
int32_t PPB_URLLoader_Impl::FinishStreamingToFile(
PP_CompletionCallback callback) {
- int32_t rv = ValidateCallback(callback);
- if (rv != PP_OK)
- return rv;
if (!response_info_ || !response_info_->body())
return PP_ERROR_FAILED;
+ if (pending_callback_.func)
+ return PP_ERROR_INPROGRESS;
// We may have already reached EOF.
if (done_status_ != PP_ERROR_WOULDBLOCK)
return done_status_;
// Wait for didFinishLoading / didFail.
- RegisterCallback(callback);
+ pending_callback_ = callback;
return PP_ERROR_WOULDBLOCK;
}
@@ -363,8 +367,6 @@
WebFrame* frame = instance_->container()->element().document().frame();
frame->stopLoading();
}
- // TODO(viettrungluu): Check what happens to the callback (probably the
- // wrong thing). May need to post abort here. crbug.com/69457
}
void PPB_URLLoader_Impl::GrantUniversalAccess() {
@@ -429,7 +431,7 @@
if (user_buffer_) {
RunCallback(FillUserBuffer());
} else {
- DCHECK(!pending_callback_.get() || pending_callback_->completed());
+ DCHECK(!pending_callback_.func);
}
}
@@ -480,33 +482,15 @@
// goes out of scope.
}
-int32_t PPB_URLLoader_Impl::ValidateCallback(PP_CompletionCallback callback) {
- // We only support non-blocking calls.
- if (!callback.func)
- return PP_ERROR_BADARGUMENT;
+void PPB_URLLoader_Impl::RunCallback(int32_t result) {
+ if (!pending_callback_.func)
+ return;
- if (pending_callback_.get() && !pending_callback_->completed())
- return PP_ERROR_INPROGRESS;
-
- return PP_OK;
+ PP_CompletionCallback callback = {0};
+ std::swap(callback, pending_callback_);
+ PP_RunCompletionCallback(&callback, result);
}
-void PPB_URLLoader_Impl::RegisterCallback(PP_CompletionCallback callback) {
- DCHECK(callback.func);
- DCHECK(!pending_callback_.get() || pending_callback_->completed());
-
- PP_Resource resource_id = GetReferenceNoAddRef();
- CHECK(resource_id);
- pending_callback_ = new TrackedCompletionCallback(
- module()->GetCallbackTracker(), resource_id, callback);
-}
-
-void PPB_URLLoader_Impl::RunCallback(int32_t result) {
- scoped_refptr<TrackedCompletionCallback> callback;
- callback.swap(pending_callback_);
- callback->Run(result); // Will complete abortively if necessary.
-}
-
size_t PPB_URLLoader_Impl::FillUserBuffer() {
DCHECK(user_buffer_);
DCHECK(user_buffer_size_);
« no previous file with comments | « webkit/plugins/ppapi/ppb_url_loader_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698