Scroll to navigation

std::experimental::make_unique_resource_checked(3) C++ Standard Libary std::experimental::make_unique_resource_checked(3)

NAME

std::experimental::make_unique_resource_checked - std::experimental::make_unique_resource_checked

Synopsis


Defined in header <experimental/scope>
template< class R, class D, class S = std::decay_t<R> >


std::experimental::unique_resource<std::decay_t<R>,
std::decay_t<D>> (library
make_unique_resource_checked( R&& r, const S& invalid, D&& fundamentals TS v3)
d )


noexcept(/*see below*/);


Creates a unique_resource, initializes its stored resource handle is initialized
with std::forward<R>(r) and its deleter with std::forward<D>(d). The created
unique_resource owns the resource if and only if bool(r == invalid) is false.


The program is ill-formed if the expression r == invalid cannot be contextually
converted to bool, and the behavior is undefined if the conversion results in
undefined behavior or throws an exception.

Exceptions


Any exception thrown in initialization of the stored resource handle and the
deleter.


noexcept specification:
noexcept(


std::is_nothrow_constructible_v<std::decay_t<R>, R> &&
std::is_nothrow_constructible_v<std::decay_t<D>, D>


)

Notes


make_unique_resource_checked exists to avoid calling a deleter function with an
invalid argument.


Resource handle r is either copied or moved into the return value, and the created
unique_resource always holds an underlying resource handle with object type.

Example

// Run this code


#include <cstdio>
#include <experimental/scope>


int main()
{
// avoid calling fclose when fopen fails
auto file = std::experimental::make_unique_resource_checked(
std::fopen("potentially_nonexistent_file.txt", "r"),
nullptr,
[](std::FILE *fptr) { std::fclose(fptr); }
);
if (file.get())
std::puts("The file exits.");
else
std::puts("The file does not exist.");
}

Possible output:


The file does not exist.

See also

Category:


* conditionally noexcept

2024.06.10 http://cppreference.com