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

Side by Side Diff: base/message_loop/message_loop.cc

Issue 1206893003: base: Make it possible to replace the MessageLoop's task runner (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Change in media/blink/webmediaplayer_impl.cc is not needed Created 5 years, 5 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
« no previous file with comments | « base/message_loop/message_loop.h ('k') | base/message_loop/message_loop_task_runner.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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "base/message_loop/message_loop.h" 5 #include "base/message_loop/message_loop.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
(...skipping 349 matching lines...) Expand 10 before | Expand all | Expand 10 after
360 } 360 }
361 361
362 bool MessageLoop::IsIdleForTesting() { 362 bool MessageLoop::IsIdleForTesting() {
363 // We only check the imcoming queue|, since we don't want to lock the work 363 // We only check the imcoming queue|, since we don't want to lock the work
364 // queue. 364 // queue.
365 return incoming_task_queue_->IsIdleForTesting(); 365 return incoming_task_queue_->IsIdleForTesting();
366 } 366 }
367 367
368 //------------------------------------------------------------------------------ 368 //------------------------------------------------------------------------------
369 369
370 // static
370 scoped_ptr<MessageLoop> MessageLoop::CreateUnbound( 371 scoped_ptr<MessageLoop> MessageLoop::CreateUnbound(
371 Type type, MessagePumpFactoryCallback pump_factory) { 372 Type type, MessagePumpFactoryCallback pump_factory) {
372 return make_scoped_ptr(new MessageLoop(type, pump_factory)); 373 return make_scoped_ptr(new MessageLoop(type, pump_factory));
373 } 374 }
374 375
375 MessageLoop::MessageLoop(Type type, MessagePumpFactoryCallback pump_factory) 376 MessageLoop::MessageLoop(Type type, MessagePumpFactoryCallback pump_factory)
376 : type_(type), 377 : type_(type),
377 #if defined(OS_WIN) 378 #if defined(OS_WIN)
378 pending_high_res_tasks_(0), 379 pending_high_res_tasks_(0),
379 in_high_res_mode_(false), 380 in_high_res_mode_(false),
(...skipping 16 matching lines...) Expand all
396 if (!pump_factory_.is_null()) 397 if (!pump_factory_.is_null())
397 pump_ = pump_factory_.Run(); 398 pump_ = pump_factory_.Run();
398 else 399 else
399 pump_ = CreateMessagePumpForType(type_); 400 pump_ = CreateMessagePumpForType(type_);
400 401
401 DCHECK(!current()) << "should only have one message loop per thread"; 402 DCHECK(!current()) << "should only have one message loop per thread";
402 lazy_tls_ptr.Pointer()->Set(this); 403 lazy_tls_ptr.Pointer()->Set(this);
403 404
404 incoming_task_queue_->StartScheduling(); 405 incoming_task_queue_->StartScheduling();
405 task_runner_->BindToCurrentThread(); 406 task_runner_->BindToCurrentThread();
406 thread_task_runner_handle_.reset(new ThreadTaskRunnerHandle(task_runner_)); 407 scoped_refptr<BindableSingleThreadTaskRunner> previous_task_runner =
408 SwapTaskRunner(task_runner_.Pass());
409 DCHECK(previous_task_runner == NULL);
410 }
411
412 scoped_refptr<BindableSingleThreadTaskRunner> MessageLoop::SwapTaskRunner(
413 scoped_refptr<BindableSingleThreadTaskRunner> task_runner) {
414 // If this message loop was already bound to a thread, ensure the task runner
415 // belongs to the same thread and update the thread task runner handle.
416 // Otherwise the task runner will be bound later in BindToCurrentThread().
417 if (pump_) {
418 DCHECK_EQ(this, current());
419 DCHECK(task_runner->BelongsToCurrentThread());
420 // This reset() is needed or ThreadTaskRunnerHandle::Get() will crash.
421 thread_task_runner_handle_.reset();
422 thread_task_runner_handle_.reset(new ThreadTaskRunnerHandle(task_runner));
423 }
424 task_runner_.swap(task_runner);
425 return task_runner;
407 } 426 }
408 427
409 void MessageLoop::RunHandler() { 428 void MessageLoop::RunHandler() {
410 DCHECK_EQ(this, current()); 429 DCHECK_EQ(this, current());
411 430
412 StartHistogrammer(); 431 StartHistogrammer();
413 432
414 #if defined(OS_WIN) 433 #if defined(OS_WIN)
415 if (run_loop_->dispatcher_ && type() == TYPE_UI) { 434 if (run_loop_->dispatcher_ && type() == TYPE_UI) {
416 static_cast<MessagePumpForUI*>(pump_.get())-> 435 static_cast<MessagePumpForUI*>(pump_.get())->
(...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after
727 persistent, 746 persistent,
728 mode, 747 mode,
729 controller, 748 controller,
730 delegate); 749 delegate);
731 } 750 }
732 #endif 751 #endif
733 752
734 #endif // !defined(OS_NACL_SFI) 753 #endif // !defined(OS_NACL_SFI)
735 754
736 } // namespace base 755 } // namespace base
OLDNEW
« no previous file with comments | « base/message_loop/message_loop.h ('k') | base/message_loop/message_loop_task_runner.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698