[optional.assign] (original) (raw)

22 General utilities library [utilities]

22.5 Optional objects [optional]

22.5.3 Class template optional [optional.optional]

22.5.3.4 Assignment [optional.assign]

constexpr optional<T>& operator=(nullopt_t) noexcept;

Effects: If *this contains a value, calls val->T​::​~T() to destroy the contained value; otherwise no effect.

Postconditions: *this does not contain a value.

constexpr optional<T>& operator=(const optional& rhs);

Table 65 — optional​::​operator=(const optional&) effects [tab:optional.assign.copy]

🔗 *this contains a value *this does not contain a value
🔗rhs contains a value assigns *rhs to the contained value direct-non-list-initializes the contained value with *rhs
🔗rhs does not contain a value destroys the contained value by calling val->T​::​~T() no effect

Postconditions: rhs.has_value() == this->has_value().

Remarks: If any exception is thrown, the result of the expression this->has_value() remains unchanged.

If an exception is thrown during the call to T's copy constructor, no effect.

If an exception is thrown during the call to T's copy assignment, the state of its contained value is as defined by the exception safety guarantee of T's copy assignment.

This operator is defined as deleted unlessis_copy_constructible_v<T> is true andis_copy_assignable_v<T> is true.

If is_trivially_copy_constructible_v<T> && is_trivially_copy_assignable_v<T> && is_trivially_destructible_v<T> is true, this assignment operator is trivial.

constexpr optional& operator=(optional&& rhs) noexcept(_see below_);

Constraints: is_move_constructible_v<T> is true andis_move_assignable_v<T> is true.

Effects: See Table 66.

The result of the expression rhs.has_value() remains unchanged.

Table 66 — optional​::​operator=(optional&&) effects [tab:optional.assign.move]

🔗 *this contains a value *this does not contain a value
🔗rhs contains a value assigns std​::​move(*rhs) to the contained value direct-non-list-initializes the contained value with std​::​move(*rhs)
🔗rhs does not contain a value destroys the contained value by calling val->T​::​~T() no effect

Postconditions: rhs.has_value() == this->has_value().

Remarks: The exception specification is equivalent to:is_nothrow_move_assignable_v<T> && is_nothrow_move_constructible_v<T>

If any exception is thrown, the result of the expression this->has_value() remains unchanged.

If an exception is thrown during the call to T's move constructor, the state of *rhs.val is determined by the exception safety guarantee of T's move constructor.

If an exception is thrown during the call to T's move assignment, the state of *val and *rhs.val is determined by the exception safety guarantee of T's move assignment.

If is_trivially_move_constructible_v<T> && is_trivially_move_assignable_v<T> && is_trivially_destructible_v<T> is true, this assignment operator is trivial.

template<class U = remove_cv_t<T>> constexpr optional& operator=(U&& v);

Constraints:

Effects: If *this contains a value, assigns std​::​forward<U>(v) to the contained value; otherwise direct-non-list-initializes the contained value with std​::​forward<U>(v).

Postconditions: *this contains a value.

Remarks: If any exception is thrown, the result of the expression this->has_value() remains unchanged.

If an exception is thrown during the call to T's constructor, the state of v is determined by the exception safety guarantee of T's constructor.

If an exception is thrown during the call to T's assignment, the state of *val and v is determined by the exception safety guarantee of T's assignment.

template<class U> constexpr optional<T>& operator=(const optional<U>& rhs);

Constraints:

Table 67 — optional​::​operator=(const optional<U>&) effects [tab:optional.assign.copy.templ]

🔗 *this contains a value *this does not contain a value
🔗rhs contains a value assigns *rhs to the contained value direct-non-list-initializes the contained value with *rhs
🔗rhs does not contain a value destroys the contained value by calling val->T​::​~T() no effect

Postconditions: rhs.has_value() == this->has_value().

Remarks: If any exception is thrown, the result of the expression this->has_value() remains unchanged.

If an exception is thrown during the call to T's constructor, the state of *rhs.val is determined by the exception safety guarantee of T's constructor.

If an exception is thrown during the call to T's assignment, the state of *val and *rhs.val is determined by the exception safety guarantee of T's assignment.

template<class U> constexpr optional<T>& operator=(optional<U>&& rhs);

Constraints:

Effects: See Table 68.

The result of the expression rhs.has_value() remains unchanged.

Table 68 — optional​::​operator=(optional<U>&&) effects [tab:optional.assign.move.templ]

🔗 *this contains a value *this does not contain a value
🔗rhs contains a value assigns std​::​move(*rhs) to the contained value direct-non-list-initializes the contained value with std​::​move(*rhs)
🔗rhs does not contain a value destroys the contained value by calling val->T​::​~T() no effect

Postconditions: rhs.has_value() == this->has_value().

Remarks: If any exception is thrown, the result of the expression this->has_value() remains unchanged.

If an exception is thrown during the call to T's constructor, the state of *rhs.val is determined by the exception safety guarantee of T's constructor.

If an exception is thrown during the call to T's assignment, the state of *val and *rhs.val is determined by the exception safety guarantee of T's assignment.

template<class... Args> constexpr T& emplace(Args&&... args);

Mandates: is_constructible_v<T, Args...> is true.

Effects: Calls *this = nullopt.

Then direct-non-list-initializes the contained value with std​::​forward​<Args>(args)....

Postconditions: *this contains a value.

Returns: A reference to the new contained value.

Throws: Any exception thrown by the selected constructor of T.

Remarks: If an exception is thrown during the call to T's constructor, *this does not contain a value, and the previous *val (if any) has been destroyed.

template<class U, class... Args> constexpr T& emplace(initializer_list<U> il, Args&&... args);

Constraints: is_constructible_v<T, initializer_list<U>&, Args...> is true.

Effects: Calls *this = nullopt.

Then direct-non-list-initializes the contained value withil, std​::​​forward<Args>(args)....

Postconditions: *this contains a value.

Returns: A reference to the new contained value.

Throws: Any exception thrown by the selected constructor of T.

Remarks: If an exception is thrown during the call to T's constructor, *this does not contain a value, and the previous *val (if any) has been destroyed.