You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
51 lines
1.1 KiB
51 lines
1.1 KiB
/*
|
|
* Copyright (c) 2016-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under both the BSD-style license (found in the
|
|
* LICENSE file in the root directory of this source tree) and the GPLv2 (found
|
|
* in the COPYING file in the root directory of this source tree).
|
|
*/
|
|
#pragma once
|
|
|
|
#include <utility>
|
|
|
|
namespace pzstd {
|
|
|
|
/**
|
|
* Dismissable scope guard.
|
|
* `Function` must be callable and take no parameters.
|
|
* Unless `dissmiss()` is called, the callable is executed upon destruction of
|
|
* `ScopeGuard`.
|
|
*
|
|
* Example:
|
|
*
|
|
* auto guard = makeScopeGuard([&] { cleanup(); });
|
|
*/
|
|
template <typename Function>
|
|
class ScopeGuard {
|
|
Function function;
|
|
bool dismissed;
|
|
|
|
public:
|
|
explicit ScopeGuard(Function&& function)
|
|
: function(std::move(function)), dismissed(false) {}
|
|
|
|
void dismiss() {
|
|
dismissed = true;
|
|
}
|
|
|
|
~ScopeGuard() noexcept {
|
|
if (!dismissed) {
|
|
function();
|
|
}
|
|
}
|
|
};
|
|
|
|
/// Creates a scope guard from `function`.
|
|
template <typename Function>
|
|
ScopeGuard<Function> makeScopeGuard(Function&& function) {
|
|
return ScopeGuard<Function>(std::forward<Function>(function));
|
|
}
|
|
}
|