Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

P2988 R9 std::optional<T&> #1661

Open
wg21bot opened this issue Oct 16, 2023 · 12 comments
Open

P2988 R9 std::optional<T&> #1661

wg21bot opened this issue Oct 16, 2023 · 12 comments
Labels
B3 - addition Bucket 3 as described by P0592: material that is not mentioned in P0592 C++26 Targeted at C++26 IS Ship vehicle: IS LEWG Library Evolution ready-for-library-evolution-meeting-review This paper needs to be discussed at a Library Evolution meeting scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review size - medium paper size estimate
Milestone

Comments

@wg21bot
Copy link
Collaborator

wg21bot commented Oct 16, 2023

P2988R0 std::optional<T&> (Steve Downey)

@wg21bot wg21bot added the LEWG Library Evolution label Oct 16, 2023
@wg21bot wg21bot added this to the 2023-telecon milestone Oct 16, 2023
@cor3ntin cor3ntin changed the title P2988 R0 std::optional&lt;T&amp;&gt; P2988 R0 std::optional<T&> Oct 16, 2023
@inbal2l inbal2l added IS Ship vehicle: IS C++26 Targeted at C++26 B3 - addition Bucket 3 as described by P0592: material that is not mentioned in P0592 ready-for-library-evolution-meeting-review This paper needs to be discussed at a Library Evolution meeting size - medium paper size estimate labels Oct 16, 2023
@inbal2l inbal2l changed the title P2988 R0 std::optional<T&> P2988 R0 std::optional<T&> (A) Oct 18, 2023
@inbal2l inbal2l added the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Oct 19, 2023
@inbal2l inbal2l changed the title P2988 R0 std::optional<T&> (A) P2988 R0 std::optional<T&> Oct 19, 2023
@inbal2l inbal2l removed the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Nov 20, 2023
@inbal2l inbal2l modified the milestones: 2023-telecon, 2024-telecon Jan 5, 2024
@inbal2l inbal2l added needs-revision Paper needs changes before it can proceed and removed ready-for-library-evolution-meeting-review This paper needs to be discussed at a Library Evolution meeting labels Jan 5, 2024
@inbal2l
Copy link
Collaborator

inbal2l commented Jan 6, 2024

2024-01-02 Library Evolution Telecon

P2988R0: std::optional<T&>

2024-01-02 Library Evolution Telecon Minutes

Champion: Steve Downey

Chair: Billy Baker

Minute Taker: Ben Craig

Summary

References mentioned during the discussion:
references mentioned above:

  1. https://thephd.dev/to-bind-and-loose-a-reference-optional
  2. https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2020/p2070r0.pdf
  3. https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2018/p1175r0.html

The author will explore and add information on:

  1. Explore compiler failure vs. compiler error for assignment op
  2. Add references to analysis of the discussion of “Assign-through” optional direction, and the “Rebind” optional direction (https://wg21.link/p1683r0)
  3. Consider a separate name then std::optional to the "ref" version?
  4. Explore named function for separating between the cases above.
  5. Add a feature test macro.
  6. Explore and add examples for "const" behaviour.

No polls were taken.

Next Steps

The room was generally supportive of the proposal but would like the author to come back with more rationale for the (already settled) design decisions and further exploration of the open topics mentioned above.
Ville and Barry volunteered to help the author.
We will see the paper again in LEWG.

@wg21bot
Copy link
Collaborator Author

wg21bot commented Jan 17, 2024

P2988R1 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot removed the needs-revision Paper needs changes before it can proceed label Jan 17, 2024
@wg21bot wg21bot changed the title P2988 R0 std::optional<T&> P2988 R1 std::optional Jan 17, 2024
@wg21bot wg21bot changed the title P2988 R1 std::optional P2988 R1 std::optional&lt;T&&gt; Jan 17, 2024
@inbal2l inbal2l added the ready-for-library-evolution-meeting-review This paper needs to be discussed at a Library Evolution meeting label Jan 17, 2024
@inbal2l inbal2l changed the title P2988 R1 std::optional&lt;T&&gt; P2988 R1 std::optional<&T> Jan 17, 2024
@inbal2l inbal2l changed the title P2988 R1 std::optional<&T> P2988 R1 std::optional<T&> Jan 17, 2024
@inbal2l inbal2l added the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Jan 18, 2024
@wg21bot
Copy link
Collaborator Author

wg21bot commented Feb 16, 2024

P2988R3 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R1 std::optional<T&> P2988 R3 std::optional&lt;T&amp;&gt; Feb 16, 2024
@cor3ntin cor3ntin changed the title P2988 R3 std::optional&lt;T&amp;&gt; P2988 R3 std::optional<T&> Feb 16, 2024
@wg21bot wg21bot removed the needs-revision Paper needs changes before it can proceed label Apr 17, 2024
@wg21bot wg21bot changed the title P2988 R3 std::optional<T&> P2988 R4 std::optional&lt;T&amp;&gt; Apr 17, 2024
@cor3ntin cor3ntin changed the title P2988 R4 std::optional&lt;T&amp;&gt; P2988 R4 std::optional<T&> Apr 17, 2024
@wg21bot
Copy link
Collaborator Author

wg21bot commented May 22, 2024

P2988R5 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R4 std::optional<T&> P2988 R5 std::optional&lt;T&amp;&gt; May 22, 2024
@inbal2l inbal2l changed the title P2988 R5 std::optional&lt;T&amp;&gt; P2988 R5 std::optional May 23, 2024
@inbal2l inbal2l added the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Jul 30, 2024
@wg21bot
Copy link
Collaborator Author

wg21bot commented Aug 15, 2024

P2988R6 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R5 std::optional P2988 R6 std::optional&lt;T&amp;&gt; Aug 15, 2024
@jensmaurer jensmaurer changed the title P2988 R6 std::optional&lt;T&amp;&gt; P2988 R6 std::optional<T&> Aug 15, 2024
@inbal2l
Copy link
Collaborator

inbal2l commented Sep 3, 2024

2024-09-03 Library Evolution Telecon

P2988R6 std::optional<T&>

2024-09-03 Library Evolution Telecon Minutes

Champion: Steve Downey
Chair: Inbal Levi
Minute Taker: Eddie Nolan

Summary

POLL: We’re happy with the behaviour “P2988R6: std::optional <T&>” which leave the behaviour of make_optional<T&> as currently is in the standard (return optional<T> or in some cases it being ill-formed)

Attendance: 20
Outcome: No objection to unanimous consent

Next Steps

We will continue the review of R6 of the paper during the next telecon.

@FabioFracassi
Copy link
Collaborator

FabioFracassi commented Sep 10, 2024

2024-09-10 Library Evolution Telecon

P2988R6: std::optional<T&>

2024-09-10 Library Evolution Telecon Minutes

Champion: Steve Downey
Chair: Fabio Fracassi
Minute Taker: Mark Hoemmen

Summary

Paper Forwarding Checklist

Checklist
Why should this utility go into the standard library? extention of standard type
Examples? yes
Discussion of prior art? yes, extensive
Implementation experience? yes
Usage experience? yes, e.g. through boost
Deployment experience? no
Performance considerations? yes
Changes Library Evolution previously requested? yes
Support in "std::format" and "hash" (if required)? n/a
Feature test macro? yes
Freestanding? yes
Constexpr? yes
Wording? yes

ACTION: Strike =T from ctor and assignment:
template <class U = T> constexpr explicit(see below) optional(U&& u) noexcept;

POLL: Add optional& constructor and assigment
(allowing to to construct opt<int&> from opt<int>
(opt<int const&> from opt<int> already works)).

SF F N A SA
4 4 0 0 0

Attendance: 15
# of Authors: 1
Author's Position: SF
Outcome: Consensus in favour

POLL: We approve of the design in P2988R7 with the added optional& constructor and assignment operator.

SF F N A SA
5 4 0 0 0

Attendance: 15
# of Authors: 1
Author Position: SF
Outcome: Consensus in favour

Next Steps

Design is approved. We will look at the updated wording in a future meeting, with the goal to forward to LWG.

@wg21bot
Copy link
Collaborator Author

wg21bot commented Sep 21, 2024

P2988R7 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R6 std::optional<T&> P2988 R7 std::optional&lt;T&amp;&gt; Sep 21, 2024
@inbal2l inbal2l removed the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Sep 21, 2024
@inbal2l inbal2l changed the title P2988 R7 std::optional&lt;T&amp;&gt; P2988 R7 std::optional<T&> Sep 21, 2024
@wg21bot
Copy link
Collaborator Author

wg21bot commented Oct 17, 2024

P2988R8 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R7 std::optional<T&> P2988 R8 std::optional&lt;T&amp;&gt; Oct 17, 2024
@jwakely jwakely changed the title P2988 R8 std::optional&lt;T&amp;&gt; P2988 R8 std::optional<T&> Oct 17, 2024
@inbal2l inbal2l added the scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review label Nov 29, 2024
@jensmaurer jensmaurer modified the milestones: 2024-telecon, 2025-telecon Dec 18, 2024
@wg21bot
Copy link
Collaborator Author

wg21bot commented Jan 14, 2025

P2988R9 std::optional<T&> (Steve Downey, Peter Sommerlad)

@wg21bot wg21bot changed the title P2988 R8 std::optional<T&> P2988 R9 std::optional&lt;T&amp;&gt; Jan 14, 2025
@jwakely jwakely changed the title P2988 R9 std::optional&lt;T&amp;&gt; P2988 R9 std::optional<T&> Jan 14, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
B3 - addition Bucket 3 as described by P0592: material that is not mentioned in P0592 C++26 Targeted at C++26 IS Ship vehicle: IS LEWG Library Evolution ready-for-library-evolution-meeting-review This paper needs to be discussed at a Library Evolution meeting scheduled-for-library-evolution This paper has been scheduled for one of the groups: LEWG, LEWG Incubator, or a Mailing List review size - medium paper size estimate
Development

No branches or pull requests

5 participants