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

Side by Side Diff: media/base/serial_runner.cc

Issue 193303002: WeakPtr destruction order cleanup: media edition. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 9 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
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 "media/base/serial_runner.h" 5 #include "media/base/serial_runner.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/callback_helpers.h" 8 #include "base/callback_helpers.h"
9 #include "base/location.h" 9 #include "base/location.h"
10 #include "base/message_loop/message_loop_proxy.h" 10 #include "base/message_loop/message_loop_proxy.h"
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
47 SerialRunner::BoundPipelineStatusCB SerialRunner::Queue::Pop() { 47 SerialRunner::BoundPipelineStatusCB SerialRunner::Queue::Pop() {
48 BoundPipelineStatusCB bound_fn = bound_fns_.front(); 48 BoundPipelineStatusCB bound_fn = bound_fns_.front();
49 bound_fns_.pop(); 49 bound_fns_.pop();
50 return bound_fn; 50 return bound_fn;
51 } 51 }
52 52
53 bool SerialRunner::Queue::empty() { 53 bool SerialRunner::Queue::empty() {
54 return bound_fns_.empty(); 54 return bound_fns_.empty();
55 } 55 }
56 56
57 SerialRunner::SerialRunner( 57 SerialRunner::SerialRunner(const Queue& bound_fns,
58 const Queue& bound_fns, const PipelineStatusCB& done_cb) 58 const PipelineStatusCB& done_cb)
59 : weak_this_(this), 59 : task_runner_(base::MessageLoopProxy::current()),
60 task_runner_(base::MessageLoopProxy::current()),
61 bound_fns_(bound_fns), 60 bound_fns_(bound_fns),
62 done_cb_(done_cb) { 61 done_cb_(done_cb),
62 weak_factory_(this) {
63 // Respect both cancellation and calling stack guarantees for |done_cb| 63 // Respect both cancellation and calling stack guarantees for |done_cb|
64 // when empty. 64 // when empty.
65 if (bound_fns_.empty()) { 65 if (bound_fns_.empty()) {
66 task_runner_->PostTask(FROM_HERE, base::Bind( 66 task_runner_->PostTask(FROM_HERE,
67 &SerialRunner::RunNextInSeries, weak_this_.GetWeakPtr(), PIPELINE_OK)); 67 base::Bind(&SerialRunner::RunNextInSeries,
68 weak_factory_.GetWeakPtr(),
69 PIPELINE_OK));
68 return; 70 return;
69 } 71 }
70 72
71 RunNextInSeries(PIPELINE_OK); 73 RunNextInSeries(PIPELINE_OK);
72 } 74 }
73 75
74 SerialRunner::~SerialRunner() {} 76 SerialRunner::~SerialRunner() {}
75 77
76 scoped_ptr<SerialRunner> SerialRunner::Run( 78 scoped_ptr<SerialRunner> SerialRunner::Run(
77 const Queue& bound_fns, const PipelineStatusCB& done_cb) { 79 const Queue& bound_fns, const PipelineStatusCB& done_cb) {
78 scoped_ptr<SerialRunner> callback_series( 80 scoped_ptr<SerialRunner> callback_series(
79 new SerialRunner(bound_fns, done_cb)); 81 new SerialRunner(bound_fns, done_cb));
80 return callback_series.Pass(); 82 return callback_series.Pass();
81 } 83 }
82 84
83 void SerialRunner::RunNextInSeries(PipelineStatus last_status) { 85 void SerialRunner::RunNextInSeries(PipelineStatus last_status) {
84 DCHECK(task_runner_->BelongsToCurrentThread()); 86 DCHECK(task_runner_->BelongsToCurrentThread());
85 DCHECK(!done_cb_.is_null()); 87 DCHECK(!done_cb_.is_null());
86 88
87 if (bound_fns_.empty() || last_status != PIPELINE_OK) { 89 if (bound_fns_.empty() || last_status != PIPELINE_OK) {
88 base::ResetAndReturn(&done_cb_).Run(last_status); 90 base::ResetAndReturn(&done_cb_).Run(last_status);
89 return; 91 return;
90 } 92 }
91 93
92 BoundPipelineStatusCB bound_fn = bound_fns_.Pop(); 94 BoundPipelineStatusCB bound_fn = bound_fns_.Pop();
93 bound_fn.Run(base::Bind(&RunOnTaskRunner, task_runner_, base::Bind( 95 bound_fn.Run(base::Bind(
94 &SerialRunner::RunNextInSeries, weak_this_.GetWeakPtr()))); 96 &RunOnTaskRunner,
97 task_runner_,
98 base::Bind(&SerialRunner::RunNextInSeries, weak_factory_.GetWeakPtr())));
95 } 99 }
96 100
97 } // namespace media 101 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698