OLD | NEW |
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 "content/browser/browser_main_loop.h" | 5 #include "content/browser/browser_main_loop.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/debug/trace_event.h" | 9 #include "base/debug/trace_event.h" |
10 #include "base/hi_res_timer_manager.h" | 10 #include "base/hi_res_timer_manager.h" |
11 #include "base/logging.h" | 11 #include "base/logging.h" |
12 #include "base/message_loop.h" | 12 #include "base/message_loop.h" |
13 #include "base/metrics/field_trial.h" | 13 #include "base/metrics/field_trial.h" |
14 #include "base/metrics/histogram.h" | 14 #include "base/metrics/histogram.h" |
15 #include "base/run_loop.h" | 15 #include "base/run_loop.h" |
16 #include "base/string_number_conversions.h" | 16 #include "base/string_number_conversions.h" |
17 #include "base/threading/thread_restrictions.h" | 17 #include "base/threading/thread_restrictions.h" |
18 #include "content/browser/browser_thread_impl.h" | 18 #include "content/browser/browser_thread_impl.h" |
| 19 #include "content/browser/download/download_file_manager.h" |
19 #include "content/browser/download/save_file_manager.h" | 20 #include "content/browser/download/save_file_manager.h" |
20 #include "content/browser/gamepad/gamepad_service.h" | 21 #include "content/browser/gamepad/gamepad_service.h" |
21 #include "content/browser/gpu/browser_gpu_channel_host_factory.h" | 22 #include "content/browser/gpu/browser_gpu_channel_host_factory.h" |
22 #include "content/browser/gpu/gpu_process_host.h" | 23 #include "content/browser/gpu/gpu_process_host.h" |
23 #include "content/browser/gpu/gpu_process_host_ui_shim.h" | 24 #include "content/browser/gpu/gpu_process_host_ui_shim.h" |
24 #include "content/browser/histogram_synchronizer.h" | 25 #include "content/browser/histogram_synchronizer.h" |
25 #include "content/browser/in_process_webkit/webkit_thread.h" | 26 #include "content/browser/in_process_webkit/webkit_thread.h" |
26 #include "content/browser/net/browser_online_state_observer.h" | 27 #include "content/browser/net/browser_online_state_observer.h" |
27 #include "content/browser/plugin_service_impl.h" | 28 #include "content/browser/plugin_service_impl.h" |
28 #include "content/browser/renderer_host/media/audio_input_device_manager.h" | 29 #include "content/browser/renderer_host/media/audio_input_device_manager.h" |
(...skipping 529 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
558 resource_dispatcher_host_.reset(); | 559 resource_dispatcher_host_.reset(); |
559 break; | 560 break; |
560 case BrowserThread::FILE_USER_BLOCKING: | 561 case BrowserThread::FILE_USER_BLOCKING: |
561 thread_to_stop = &file_user_blocking_thread_; | 562 thread_to_stop = &file_user_blocking_thread_; |
562 break; | 563 break; |
563 case BrowserThread::FILE: | 564 case BrowserThread::FILE: |
564 thread_to_stop = &file_thread_; | 565 thread_to_stop = &file_thread_; |
565 | 566 |
566 // Clean up state that lives on or uses the file_thread_ before | 567 // Clean up state that lives on or uses the file_thread_ before |
567 // it goes away. | 568 // it goes away. |
568 if (resource_dispatcher_host_.get()) | 569 if (resource_dispatcher_host_.get()) { |
| 570 resource_dispatcher_host_.get()->download_file_manager()->Shutdown(); |
569 resource_dispatcher_host_.get()->save_file_manager()->Shutdown(); | 571 resource_dispatcher_host_.get()->save_file_manager()->Shutdown(); |
| 572 } |
570 break; | 573 break; |
571 case BrowserThread::PROCESS_LAUNCHER: | 574 case BrowserThread::PROCESS_LAUNCHER: |
572 thread_to_stop = &process_launcher_thread_; | 575 thread_to_stop = &process_launcher_thread_; |
573 break; | 576 break; |
574 case BrowserThread::CACHE: | 577 case BrowserThread::CACHE: |
575 thread_to_stop = &cache_thread_; | 578 thread_to_stop = &cache_thread_; |
576 break; | 579 break; |
577 case BrowserThread::IO: | 580 case BrowserThread::IO: |
578 thread_to_stop = &io_thread_; | 581 thread_to_stop = &io_thread_; |
579 break; | 582 break; |
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
693 DCHECK_EQ(MessageLoop::TYPE_UI, MessageLoop::current()->type()); | 696 DCHECK_EQ(MessageLoop::TYPE_UI, MessageLoop::current()->type()); |
694 if (parameters_.ui_task) | 697 if (parameters_.ui_task) |
695 MessageLoopForUI::current()->PostTask(FROM_HERE, *parameters_.ui_task); | 698 MessageLoopForUI::current()->PostTask(FROM_HERE, *parameters_.ui_task); |
696 | 699 |
697 base::RunLoop run_loop; | 700 base::RunLoop run_loop; |
698 run_loop.Run(); | 701 run_loop.Run(); |
699 #endif | 702 #endif |
700 } | 703 } |
701 | 704 |
702 } // namespace content | 705 } // namespace content |
OLD | NEW |