Created on 2020-02-13.00:00:00 last changed 45 months ago
Proposed resolution:
This wording is relative to N4849.
Modify [support.srcloc.cons] as indicated:
static consteval source_location current() noexcept;-1- […]
-2- Remarks:When a default member initializer is used to initialize a non-static data member, any calls to currentAny call to current that appears as a default member initializer ([class.mem]), or as a subexpression thereof, should correspond to the location of the constructor definition or aggregate initialization thatinitializes the memberuses the default member initializer. Any call to current that appears as a default argument ([dcl.fct.default]), or as a subexpression thereof, should correspond to the location of the invocation of the function that uses the default argument ([expr.call]).-3- [Note: When used as a default argument ([dcl.fct.default]), the value of the source_location will be the location of the call to current at the call site. — end note]
[ 2020-02 Moved to Immediate on Thursday afternoon in Prague. ]
Addresses DE 169
The expectation of the note that a default argument expression involving current() causes a source_location to be constructed that refers to the site of a function call where that default argument is needed has no basis in normative text. In particular, 9.2.3.6 paragraph 5 seems to imply that the name "current" and its semantics are bound where it appears lexically in the function declaration.
Proposed change: Add normative text to express the desired semantics.History | |||
---|---|---|---|
Date | User | Action | Args |
2021-02-25 10:48:01 | admin | set | status: wp -> c++20 |
2020-02-24 16:02:59 | admin | set | status: immediate -> wp |
2020-02-14 06:55:06 | admin | set | messages: + msg11094 |
2020-02-14 06:55:06 | admin | set | status: new -> immediate |
2020-02-13 10:21:24 | admin | set | messages: + msg11050 |
2020-02-13 00:00:00 | admin | create |