diff options
| author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2025-03-16 12:48:45 +0100 | 
|---|---|---|
| committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2025-03-16 12:48:45 +0100 | 
| commit | cec79a3f5578da4a9f9085282389482edf45c81b (patch) | |
| tree | 5c45f5efee77f9f8d84c3a1c7e02b12b6725a2e3 /doc/scope.rst | |
| parent | 677e5b0b948fe62d8017c198c57049275f6fe61a (diff) | |
New upstream version 4.26upstream/4.26
Diffstat (limited to 'doc/scope.rst')
| -rw-r--r-- | doc/scope.rst | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/doc/scope.rst b/doc/scope.rst new file mode 100644 index 0000000..84ad69b --- /dev/null +++ b/doc/scope.rst @@ -0,0 +1,22 @@ +============ +Scope guards +============ + +``scope_exit`` +============== + +scope_exit creates an object that runs a predefined function when a scope ends. +This is useful for augmenting C APIs with something of a destructor without +wrapping the stuff in an explicit class of its own. For instance, + +.. code-block:: c++ + +	#include <libHX/option.h> +	#include <libHX/scope.hpp> +	int main() { +		auto fa = HXformat_init(); +		if (fa == nullptr) +			return 0; +		auto cleanup_fa = HX::make_scope_exit([&]() { HXformat_free(fa); }); +		HXformat_add(fa, "foo", "bar", HXTYPE_STRING); +	} | 
