From bc7e723f8da648915fd6975963e77868940645f3 Mon Sep 17 00:00:00 2001 From: Sebastien Ponce Date: Wed, 11 Oct 2023 14:06:32 +0200 Subject: [PATCH] Added on slide on std::expected --- talk/morelanguage/morestl.tex | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/talk/morelanguage/morestl.tex b/talk/morelanguage/morestl.tex index e8ee92f5..ea882a6b 100644 --- a/talk/morelanguage/morestl.tex +++ b/talk/morelanguage/morestl.tex @@ -147,6 +147,35 @@ \end{exerciseWithShortcut} \end{frame} +\begin{frame}[fragile] + \frametitlecpp[23]{std::expected \cpprefLink{https://en.cppreference.com/w/cpp/utility/expected}} + \begin{block}{Manages either of 2 values (expected or not)} + \begin{itemize} + \item templated by the 2 value types + \item Useful for the return value of a function that may fail + \begin{itemize} + \item and would then return another type (error type) + \end{itemize} + \end{itemize} + \end{block} + \begin{exampleblock}{} + \small + \begin{cppcode*}{} + enum class Error {...}; + std::expected parse(std::string_view in) { + if (is_valid(in)) return convert_to_int(in); + return std::unexpected(Error::...); + } + auto v = parse(...); + if (v.has_value()) { + std::cout << *v; // (unchecked) + foo(v.value()); // may throw bad_expected_access + } else + log(v.error()); + \end{cppcode*} + \end{exampleblock} +\end{frame} + \begin{frame}[fragile] \frametitlecpp[17]{std::variant \cpprefLink{https://en.cppreference.com/w/cpp/utility/variant}} \begin{block}{A type-safe union}