2020-04-18 22:53:04 -07:00
|
|
|
/**
|
|
|
|
* @file expected.h
|
|
|
|
* @brief This utility class provides a way for a function to accept or return a value that may be invalid.
|
|
|
|
*
|
|
|
|
* For example, suppose there needs to be a solution for prevention of divide by zero. One could write this function:
|
|
|
|
*
|
|
|
|
* expected<int> my_divide(int num, int denom) {
|
|
|
|
* if (denom == 0) return unexpected;
|
|
|
|
* return num / denom;
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* @date April 18, 2020
|
|
|
|
* @author Matthew Kennedy, (c) 2020
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-04-19 05:37:43 -07:00
|
|
|
struct unexpected_t {};
|
|
|
|
|
2020-04-18 22:53:04 -07:00
|
|
|
template <class TValue>
|
|
|
|
struct expected {
|
|
|
|
const bool Valid;
|
|
|
|
const TValue Value;
|
|
|
|
|
2020-04-19 05:37:43 -07:00
|
|
|
// Implicit constructor to construct in the invalid state
|
|
|
|
constexpr expected(const unexpected_t&) : Valid(false), Value{} {}
|
2020-04-18 22:53:04 -07:00
|
|
|
|
|
|
|
// Implicit constructor to convert from TValue (for valid values, so an expected<T> behaves like a T)
|
|
|
|
constexpr expected(TValue validValue)
|
|
|
|
: Valid(true)
|
|
|
|
, Value(validValue)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// Implicit conversion operator to bool, so you can do things like if (myResult) { ... }
|
|
|
|
constexpr explicit operator bool() const {
|
|
|
|
return Valid;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Easy default value handling
|
2020-09-03 11:56:55 -07:00
|
|
|
constexpr TValue value_or(TValue valueIfInvalid) const {
|
2020-04-18 22:53:04 -07:00
|
|
|
return Valid ? Value : valueIfInvalid;
|
|
|
|
}
|
2020-04-19 14:18:47 -07:00
|
|
|
|
|
|
|
bool operator ==(const expected<TValue>& other) const {
|
|
|
|
// If validity mismatch, not equal
|
|
|
|
if (Valid != other.Valid) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If both are invalid, they are equal
|
|
|
|
if (!Valid && !other.Valid) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Both are guaranteed valid - simply compare values
|
|
|
|
return Value == other.Value;
|
|
|
|
}
|
2020-04-18 22:53:04 -07:00
|
|
|
};
|
|
|
|
|
2020-04-19 05:37:43 -07:00
|
|
|
constexpr unexpected_t unexpected{};
|