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

Side by Side Diff: net/url_request/url_fetcher_core.cc

Issue 398903002: Plumb redirect info out of net, through content, and into child processes. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: darin comments Created 6 years, 4 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/url_request/url_fetcher_core.h ('k') | net/url_request/url_request.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/url_request/url_fetcher_core.h" 5 #include "net/url_request/url_fetcher_core.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/metrics/histogram.h" 9 #include "base/metrics/histogram.h"
10 #include "base/sequenced_task_runner.h" 10 #include "base/sequenced_task_runner.h"
11 #include "base/single_thread_task_runner.h" 11 #include "base/single_thread_task_runner.h"
12 #include "base/stl_util.h" 12 #include "base/stl_util.h"
13 #include "base/thread_task_runner_handle.h" 13 #include "base/thread_task_runner_handle.h"
14 #include "base/tracked_objects.h" 14 #include "base/tracked_objects.h"
15 #include "net/base/io_buffer.h" 15 #include "net/base/io_buffer.h"
16 #include "net/base/load_flags.h" 16 #include "net/base/load_flags.h"
17 #include "net/base/net_errors.h" 17 #include "net/base/net_errors.h"
18 #include "net/base/request_priority.h" 18 #include "net/base/request_priority.h"
19 #include "net/base/upload_bytes_element_reader.h" 19 #include "net/base/upload_bytes_element_reader.h"
20 #include "net/base/upload_data_stream.h" 20 #include "net/base/upload_data_stream.h"
21 #include "net/base/upload_file_element_reader.h" 21 #include "net/base/upload_file_element_reader.h"
22 #include "net/http/http_response_headers.h" 22 #include "net/http/http_response_headers.h"
23 #include "net/url_request/redirect_info.h"
23 #include "net/url_request/url_fetcher_delegate.h" 24 #include "net/url_request/url_fetcher_delegate.h"
24 #include "net/url_request/url_fetcher_response_writer.h" 25 #include "net/url_request/url_fetcher_response_writer.h"
25 #include "net/url_request/url_request_context.h" 26 #include "net/url_request/url_request_context.h"
26 #include "net/url_request/url_request_context_getter.h" 27 #include "net/url_request/url_request_context_getter.h"
27 #include "net/url_request/url_request_throttler_manager.h" 28 #include "net/url_request/url_request_throttler_manager.h"
28 29
29 namespace { 30 namespace {
30 31
31 const int kBufferSize = 4096; 32 const int kBufferSize = 4096;
32 const int kUploadProgressTimerInterval = 100; 33 const int kUploadProgressTimerInterval = 100;
(...skipping 331 matching lines...) Expand 10 before | Expand all | Expand 10 after
364 // DisownFile takes effect before Stop deletes file_writer_. 365 // DisownFile takes effect before Stop deletes file_writer_.
365 // 366 //
366 // This direct call should be thread-safe, since DisownFile itself does no 367 // This direct call should be thread-safe, since DisownFile itself does no
367 // file operation. It just flips the state to be referred in destruction. 368 // file operation. It just flips the state to be referred in destruction.
368 file_writer->DisownFile(); 369 file_writer->DisownFile();
369 } 370 }
370 return true; 371 return true;
371 } 372 }
372 373
373 void URLFetcherCore::OnReceivedRedirect(URLRequest* request, 374 void URLFetcherCore::OnReceivedRedirect(URLRequest* request,
374 const GURL& new_url, 375 const RedirectInfo& redirect_info,
375 bool* defer_redirect) { 376 bool* defer_redirect) {
376 DCHECK_EQ(request, request_.get()); 377 DCHECK_EQ(request, request_.get());
377 DCHECK(network_task_runner_->BelongsToCurrentThread()); 378 DCHECK(network_task_runner_->BelongsToCurrentThread());
378 if (stop_on_redirect_) { 379 if (stop_on_redirect_) {
379 stopped_on_redirect_ = true; 380 stopped_on_redirect_ = true;
380 url_ = new_url; 381 url_ = redirect_info.new_url;
381 response_code_ = request_->GetResponseCode(); 382 response_code_ = request_->GetResponseCode();
382 was_fetched_via_proxy_ = request_->was_fetched_via_proxy(); 383 was_fetched_via_proxy_ = request_->was_fetched_via_proxy();
383 request->Cancel(); 384 request->Cancel();
384 OnReadCompleted(request, 0); 385 OnReadCompleted(request, 0);
385 } 386 }
386 } 387 }
387 388
388 void URLFetcherCore::OnResponseStarted(URLRequest* request) { 389 void URLFetcherCore::OnResponseStarted(URLRequest* request) {
389 DCHECK_EQ(request, request_.get()); 390 DCHECK_EQ(request, request_.get());
390 DCHECK(network_task_runner_->BelongsToCurrentThread()); 391 DCHECK(network_task_runner_->BelongsToCurrentThread());
(...skipping 499 matching lines...) Expand 10 before | Expand all | Expand 10 after
890 } 891 }
891 892
892 void URLFetcherCore::InformDelegateDownloadProgressInDelegateThread( 893 void URLFetcherCore::InformDelegateDownloadProgressInDelegateThread(
893 int64 current, int64 total) { 894 int64 current, int64 total) {
894 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); 895 DCHECK(delegate_task_runner_->BelongsToCurrentThread());
895 if (delegate_) 896 if (delegate_)
896 delegate_->OnURLFetchDownloadProgress(fetcher_, current, total); 897 delegate_->OnURLFetchDownloadProgress(fetcher_, current, total);
897 } 898 }
898 899
899 } // namespace net 900 } // namespace net
OLDNEW
« no previous file with comments | « net/url_request/url_fetcher_core.h ('k') | net/url_request/url_request.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698