
* Explicit deletion of copy constructors not necessary when move constructors are given. * No way to check if the runner had a closure inside. * RunAndReset() crashed if called with no closure inside. * operator=() failed to run the outgoing closure. Bug: none Change-Id: I8c92dfaca95619fe6661af10c018a75dae7e25ff Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2537787 Commit-Queue: Peter Kasting <pkasting@chromium.org> Reviewed-by: Avi Drissman <avi@chromium.org> Reviewed-by: danakj <danakj@chromium.org> Auto-Submit: Peter Kasting <pkasting@chromium.org> Cr-Commit-Position: refs/heads/master@{#827526}
44 lines
1.0 KiB
C++
44 lines
1.0 KiB
C++
// Copyright 2013 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "base/callback_helpers.h"
|
|
|
|
namespace base {
|
|
|
|
ScopedClosureRunner::ScopedClosureRunner() = default;
|
|
|
|
ScopedClosureRunner::ScopedClosureRunner(OnceClosure closure)
|
|
: closure_(std::move(closure)) {}
|
|
|
|
ScopedClosureRunner::ScopedClosureRunner(ScopedClosureRunner&& other)
|
|
: closure_(other.Release()) {}
|
|
|
|
ScopedClosureRunner& ScopedClosureRunner::operator=(
|
|
ScopedClosureRunner&& other) {
|
|
if (this != &other) {
|
|
RunAndReset();
|
|
ReplaceClosure(other.Release());
|
|
}
|
|
return *this;
|
|
}
|
|
|
|
ScopedClosureRunner::~ScopedClosureRunner() {
|
|
RunAndReset();
|
|
}
|
|
|
|
void ScopedClosureRunner::RunAndReset() {
|
|
if (closure_)
|
|
std::move(closure_).Run();
|
|
}
|
|
|
|
void ScopedClosureRunner::ReplaceClosure(OnceClosure closure) {
|
|
closure_ = std::move(closure);
|
|
}
|
|
|
|
OnceClosure ScopedClosureRunner::Release() {
|
|
return std::move(closure_);
|
|
}
|
|
|
|
} // namespace base
|