summaryrefslogtreecommitdiffstats
path: root/chrome/service
diff options
context:
space:
mode:
authorsanjeevr@chromium.org <sanjeevr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-13 01:19:54 +0000
committersanjeevr@chromium.org <sanjeevr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-13 01:19:54 +0000
commit505d8e85e2f2383703d1932e0e4bc722a531c47f (patch)
tree1d6f1f41c7aba2f05986d2890cd2e67eebb0b231 /chrome/service
parent2bce5e17baa53ab9547a0dd8bb4c5eb005277264 (diff)
downloadchromium_src-505d8e85e2f2383703d1932e0e4bc722a531c47f.zip
chromium_src-505d8e85e2f2383703d1932e0e4bc722a531c47f.tar.gz
chromium_src-505d8e85e2f2383703d1932e0e4bc722a531c47f.tar.bz2
Created and deleted URLFetcher on the IO thread in the ServiceGaiaAuthenticator implementation.
BUG=None. TEST=None. Review URL: http://codereview.chromium.org/1992016 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@47105 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/service')
-rw-r--r--chrome/service/gaia/service_gaia_authenticator.cc11
-rw-r--r--chrome/service/gaia/service_gaia_authenticator.h1
2 files changed, 7 insertions, 5 deletions
diff --git a/chrome/service/gaia/service_gaia_authenticator.cc b/chrome/service/gaia/service_gaia_authenticator.cc
index 55dfff2..d6a1948 100644
--- a/chrome/service/gaia/service_gaia_authenticator.cc
+++ b/chrome/service/gaia/service_gaia_authenticator.cc
@@ -31,6 +31,8 @@ bool ServiceGaiaAuthenticator::Post(const GURL& url,
FROM_HERE,
NewRunnableMethod(this, &ServiceGaiaAuthenticator::DoPost, url,
post_body));
+ // TODO(sanjeevr): Waiting here until the network request completes is not
+ // desirable. We need to change Post to be asynchronous.
if (!http_post_completed_.Wait()) // Block until network request completes.
NOTREACHED(); // See OnURLFetchComplete.
@@ -60,12 +62,12 @@ int ServiceGaiaAuthenticator::GetBackoffDelaySeconds(
void ServiceGaiaAuthenticator::DoPost(const GURL& post_url,
const std::string& post_body) {
DCHECK(io_message_loop_proxy_->BelongsToCurrentThread());
- request_.reset(new URLFetcher(post_url, URLFetcher::POST, this));
+ URLFetcher* request = new URLFetcher(post_url, URLFetcher::POST, this);
ServiceURLRequestContextGetter* context_getter =
new ServiceURLRequestContextGetter();
- request_->set_request_context(context_getter);
- request_->set_upload_data("application/x-www-form-urlencoded", post_body);
- request_->Start();
+ request->set_request_context(context_getter);
+ request->set_upload_data("application/x-www-form-urlencoded", post_body);
+ request->Start();
}
// URLFetcher::Delegate implementation
@@ -76,6 +78,7 @@ void ServiceGaiaAuthenticator::OnURLFetchComplete(
DCHECK(io_message_loop_proxy_->BelongsToCurrentThread());
http_response_code_ = response_code;
response_data_ = data;
+ delete source;
// Add an extra reference because we want http_post_completed_ to remain
// valid until after Signal() returns.
scoped_refptr<ServiceGaiaAuthenticator> keep_alive(this);
diff --git a/chrome/service/gaia/service_gaia_authenticator.h b/chrome/service/gaia/service_gaia_authenticator.h
index aedc302..acb05ad 100644
--- a/chrome/service/gaia/service_gaia_authenticator.h
+++ b/chrome/service/gaia/service_gaia_authenticator.h
@@ -48,7 +48,6 @@ class ServiceGaiaAuthenticator
scoped_refptr<base::MessageLoopProxy> io_message_loop_proxy_;
int http_response_code_;
std::string response_data_;
- scoped_ptr<URLFetcher> request_;
DISALLOW_COPY_AND_ASSIGN(ServiceGaiaAuthenticator);
};