| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #ifndef BASE_MESSAGE_LOOP_H_ | 5 #ifndef BASE_MESSAGE_LOOP_H_ |
| 6 #define BASE_MESSAGE_LOOP_H_ | 6 #define BASE_MESSAGE_LOOP_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include <queue> | 9 #include <queue> |
| 10 #include <string> | 10 #include <string> |
| (...skipping 26 matching lines...) Expand all Loading... |
| 37 #include "base/message_pump_gtk.h" | 37 #include "base/message_pump_gtk.h" |
| 38 #endif | 38 #endif |
| 39 | 39 |
| 40 #endif | 40 #endif |
| 41 #endif | 41 #endif |
| 42 | 42 |
| 43 namespace base { | 43 namespace base { |
| 44 class Histogram; | 44 class Histogram; |
| 45 } | 45 } |
| 46 | 46 |
| 47 #if defined(TRACK_ALL_TASK_OBJECTS) | |
| 48 namespace tracked_objects { | 47 namespace tracked_objects { |
| 49 class Births; | 48 class Births; |
| 50 } | 49 } |
| 51 #endif // defined(TRACK_ALL_TASK_OBJECTS) | |
| 52 | 50 |
| 53 // A MessageLoop is used to process events for a particular thread. There is | 51 // A MessageLoop is used to process events for a particular thread. There is |
| 54 // at most one MessageLoop instance per thread. | 52 // at most one MessageLoop instance per thread. |
| 55 // | 53 // |
| 56 // Events include at a minimum Task instances submitted to PostTask or those | 54 // Events include at a minimum Task instances submitted to PostTask or those |
| 57 // managed by TimerManager. Depending on the type of message pump used by the | 55 // managed by TimerManager. Depending on the type of message pump used by the |
| 58 // MessageLoop other events such as UI messages may be processed. On Windows | 56 // MessageLoop other events such as UI messages may be processed. On Windows |
| 59 // APC calls (as time permits) and signals sent to a registered set of HANDLEs | 57 // APC calls (as time permits) and signals sent to a registered set of HANDLEs |
| 60 // may also be processed. | 58 // may also be processed. |
| 61 // | 59 // |
| (...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 370 #if defined(OS_WIN) | 368 #if defined(OS_WIN) |
| 371 void set_os_modal_loop(bool os_modal_loop) { | 369 void set_os_modal_loop(bool os_modal_loop) { |
| 372 os_modal_loop_ = os_modal_loop; | 370 os_modal_loop_ = os_modal_loop; |
| 373 } | 371 } |
| 374 | 372 |
| 375 bool os_modal_loop() const { | 373 bool os_modal_loop() const { |
| 376 return os_modal_loop_; | 374 return os_modal_loop_; |
| 377 } | 375 } |
| 378 #endif // OS_WIN | 376 #endif // OS_WIN |
| 379 | 377 |
| 378 // This structure is copied around by value. |
| 379 struct TrackingInfo { |
| 380 TrackingInfo(const tracked_objects::Location& posted_from, |
| 381 base::TimeTicks delayed_run_time); |
| 382 ~TrackingInfo(); |
| 383 |
| 384 // Counter for location where the Closure was posted from. |
| 385 tracked_objects::Births* birth_tally; |
| 386 |
| 387 // Time this PendingTask was posted. |
| 388 base::TimeTicks time_posted; |
| 389 |
| 390 // The time when the task should be run. |
| 391 base::TimeTicks delayed_run_time; |
| 392 }; |
| 393 |
| 380 //---------------------------------------------------------------------------- | 394 //---------------------------------------------------------------------------- |
| 381 protected: | 395 protected: |
| 382 struct RunState { | 396 struct RunState { |
| 383 // Used to count how many Run() invocations are on the stack. | 397 // Used to count how many Run() invocations are on the stack. |
| 384 int run_depth; | 398 int run_depth; |
| 385 | 399 |
| 386 // Used to record that Quit() was called, or that we should quit the pump | 400 // Used to record that Quit() was called, or that we should quit the pump |
| 387 // once it becomes idle. | 401 // once it becomes idle. |
| 388 bool quit_received; | 402 bool quit_received; |
| 389 | 403 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 403 ~AutoRunState(); | 417 ~AutoRunState(); |
| 404 private: | 418 private: |
| 405 MessageLoop* loop_; | 419 MessageLoop* loop_; |
| 406 RunState* previous_state_; | 420 RunState* previous_state_; |
| 407 }; | 421 }; |
| 408 #if defined(OS_ANDROID) | 422 #if defined(OS_ANDROID) |
| 409 protected: | 423 protected: |
| 410 #endif | 424 #endif |
| 411 | 425 |
| 412 // This structure is copied around by value. | 426 // This structure is copied around by value. |
| 413 struct PendingTask { | 427 struct PendingTask : public TrackingInfo { |
| 414 PendingTask(const base::Closure& task, | 428 PendingTask(const base::Closure& task, |
| 415 const tracked_objects::Location& posted_from, | 429 const tracked_objects::Location& posted_from, |
| 416 base::TimeTicks delayed_run_time, | 430 base::TimeTicks delayed_run_time, |
| 417 bool nestable); | 431 bool nestable); |
| 418 ~PendingTask(); | 432 ~PendingTask(); |
| 419 | 433 |
| 420 // Used to support sorting. | 434 // Used to support sorting. |
| 421 bool operator<(const PendingTask& other) const; | 435 bool operator<(const PendingTask& other) const; |
| 422 | 436 |
| 423 // The task to run. | 437 // The task to run. |
| 424 base::Closure task; | 438 base::Closure task; |
| 425 | 439 |
| 426 #if defined(TRACK_ALL_TASK_OBJECTS) | |
| 427 // Counter for location where the Closure was posted from. | |
| 428 tracked_objects::Births* post_births; | |
| 429 #endif // defined(TRACK_ALL_TASK_OBJECTS) | |
| 430 | |
| 431 // Time this PendingTask was posted. | |
| 432 base::TimeTicks time_posted; | |
| 433 | |
| 434 // The time when the task should be run. | |
| 435 base::TimeTicks delayed_run_time; | |
| 436 | |
| 437 // The site this PendingTask was posted from. | 440 // The site this PendingTask was posted from. |
| 438 tracked_objects::Location posted_from; | 441 tracked_objects::Location posted_from; |
| 439 | 442 |
| 440 // Secondary sort key for run time. | 443 // Secondary sort key for run time. |
| 441 int sequence_num; | 444 int sequence_num; |
| 442 | 445 |
| 443 // OK to dispatch from a nested loop. | 446 // OK to dispatch from a nested loop. |
| 444 bool nestable; | 447 bool nestable; |
| 445 }; | 448 }; |
| 446 | 449 |
| (...skipping 264 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 711 #endif // defined(OS_POSIX) | 714 #endif // defined(OS_POSIX) |
| 712 }; | 715 }; |
| 713 | 716 |
| 714 // Do not add any member variables to MessageLoopForIO! This is important b/c | 717 // Do not add any member variables to MessageLoopForIO! This is important b/c |
| 715 // MessageLoopForIO is often allocated via MessageLoop(TYPE_IO). Any extra | 718 // MessageLoopForIO is often allocated via MessageLoop(TYPE_IO). Any extra |
| 716 // data that you need should be stored on the MessageLoop's pump_ instance. | 719 // data that you need should be stored on the MessageLoop's pump_ instance. |
| 717 COMPILE_ASSERT(sizeof(MessageLoop) == sizeof(MessageLoopForIO), | 720 COMPILE_ASSERT(sizeof(MessageLoop) == sizeof(MessageLoopForIO), |
| 718 MessageLoopForIO_should_not_have_extra_member_variables); | 721 MessageLoopForIO_should_not_have_extra_member_variables); |
| 719 | 722 |
| 720 #endif // BASE_MESSAGE_LOOP_H_ | 723 #endif // BASE_MESSAGE_LOOP_H_ |
| OLD | NEW |