1. Revision History
1.1. Revision 4 - November 1st, 2018
- 
     Change primary author and point of contact. 
- 
     Prepare paper for LWG with wording for parts approved by LEWG. 
- 
     Separated out the idea of a std :: exact_overload 
- 
     Select implementation to move forward with: forwarding calls for not-quite-derivable types while accepting that overload resolution might not work exactly as planned due to the greediness of perfectly forwarding types. Other overload strategies can be used for other types. 
1.2. Revision 3
- 
     Signal a limitation on the design: final structs, reference_wrapper/perfect forwarders, and other not-quite-derivable types. 
- 
     Remove the wording waiting for a decision on how deal with these limitations. 
1.3. Revision 2
- 
     Add constexpr noexcept 
- 
     Confirmed the use of universal references as parameters of std :: overload 
- 
     Ensure that cv-qualifiers and reference-qualifiers are forwarded correctly. 
- 
     Note that the use case for final 
- 
     Check the working with an expert from LWG before sending a new revision to LEWG and LWG. 
1.4. Revision 1
This paper has been splintered into 3 or more proposals, following discussion in the Kona meeting for the original [p0051r0]:
- 
     std :: overload 
- 
     Separate out std :: first_overload 
- 
     Separate out providing access to the stored function objects when they are stateful (not this paper). 
1.5. Revision 0
- 
     Initial release. 
2. Motivation
This paper proposes a 
Lambda expressions, library-defined functions objects, and other callables/
| Shared Code | |
|---|---|
| 
 | |
| Currently | With Proposal | 
| 
 | 
 | 
3. Design
The interface is a simple variadic function which returns an instance of an unspecified type. It is unspecified because its implementation techniques and internals are not to be relied upon by the user. As such, there is no way to retrieve a function out of the result of a 
The resulting call operation will be marked 
3.1. Perfect Argument Match vs. Forwarding?
This touches at the heart of some implementation problems. Types which introduce this problem include anything the implementation cannot derive from directly, as well as types which wrap other types and introduce forwarding argument calls:
- 
     member function pointers 
- 
     member object pointers 
- 
     function pointers 
- 
     instances of types marked final 
There are 2 known ways to implement this in the face of such: one is to perfectly mimic the function call’s arguments in the case where it cannot be easily inherited into the 
This was seen as a problem in previous revisions and by people who read the paper, and it was agreed that the calls should forward arguments whenever possible.
This led to the second, preferred implementation. By using a perfectly forwarding wrapper, 
This revision decides that it is better to make a choice and let other proposals provide more fine-grained methods of overloading. In particular, this revision chooses efficiency over overload resolution issues: by using the perfectly-forwarding, 
3.2. INVOKE 
   The handling of all of these will be with 
3.3. Shipping
This paper has been in limbo since pre-2015, based on not getting perfectly-right implementation. There are some corners of this that do not behave exactly as expected due to forwarding call wrappers, as discussed above. However, working with 
It is a shame that 
4. Future
4.1. Library
When creating this paper, it was clear that other forms of overload matching might be ideal to have. For example, a 
This is not proposed in this paper, albeit it is strongly encouraged for others to contribute such ideas in another paper. In particular, the authors here think that a 
4.2. Language
Given the various problems with defining overload sets, it seems like this feature might be better fit as a language feature. Thankfully, a language solution to this problem can be developed in-parallel or even after this paper and does not need to impede the progress of this paper. A language feature addressing this problem would be to create an overloaded set out of a number of 
5. Proposed Wording
Note: The following changes are relative to the post-Rapperswil 2018 working draft of ISO/IEC 14882, ([N4762]).
Note: The � character is used to denote a placeholder number which shall be selected by the editor.
5.1. Proposed Feature Testing Macro
The proposed feature testing macro is 
5.2. Intent
The intent of this wording is to produce an unspecified object that:
- 
     is constexpr constexpr 
- 
     is noexcept 
- 
     is noexcept noexcept 
- 
     implements a (potentially overloaded) call operator usable in the form, obj ( args ...) 
- 
     works with any INVOKE std :: invoke 
- 
     and, forwards all arguments to its underlying function call, if the implementation needs to. 
The implementation may not need to explicitly forward the arguments,but the specification will be written as if all arguments are perfectly forwarded from the the call on an 
5.3. Proposed Wording
Append to §16.3.1 General [support.limits.general]'s Table 35 one additional entry:
Macro name Value __cpp_lib_overload 201811L 
Insert a new entry into §19.1 [utilities.general]'s Table 38:
Subclause Header(s) 19.� Overload function objects <overload> 
Insert a new sub-section §19.� Overload function objects [overload.obj] in §19 [utilities] as follows:
19.� Overload function objects [overload.obj]19.�.1 Header
synopsis [overload.obj.syn]< overload > // 19.�, Overload template constexpr /* see below */ overload ( Args && ... args ) noexcept ( /*see below*/ ) 19.�.2
[overload.obj.overload]overload template < class ... Args > ; constexpr /* see below */ overload ( Args && ... args ) noexcept ( /*see below*/ ); Returns: An instance of an unspecified type of function object that behaves as if all the passed-in callables were overloaded (11.3 [over.match]) when calling it. The overloads shall preserve,constexpr , cv-qualifiers and reference qualifiers.noexcept The effect of calling an instance of this type with parameters will select the best overload. Given arguments
,a1 , ...a2 with typesaN ,T1 , ...,T2 for any numberTN >= 0, a call on the resulting object will behave as if byN . If there is no such a best overload, either because there is no candidate or that there are ambiguous candidates, the invocation expression will be ill-formed.INVOKE ( DECAY_COPY ( arg ), forward < T1 > ( a1 ) ..., forward < TN > ( aN ) Throws: Any exception thrown during the construction of the resulting function object. If all of the constructors satisfy, then the function isis_nothrow_constructible .noexcept Remarks: This function as well as the overloadedfor each ofoperator () on the resulting type shall be aArgs functions. The overloadedconstexpr for eachoperator () inarg on the resulting type shall beargs ... or equivalent.noexcept ( is_nothrow_invocable_v < Arg , T1 , T2 , ..., TN > ) 
6. Acknowledgements
Thanks to Daniel Krügler who helped me improve the wording and pointed out to me the use case for a final Callable. Thanks to Scott Pager who suggested to add overloads for non-member and member functions (which we eventually migrated over to simply use all of 
Thanks to Paul Fultz II and Bjørn Ali, authors of the Fit library and the FTL library, who yielded the ideas of 
Thanks to Matt Calabrese for his useful improvement suggestions on the library usability. Thanks to Tony Van Eerd for championing the original proposal at Kona and for insightful comments.
Thanks to Stephan T. Lavavej for pointing to CWG-1581 - "When are constexpr member functions defined?". Thanks to Peter Remmers that reported issue 16.
Thanks to Tomasz Kaminski helping me to refine the implementation for final function object and to the private discussion about the possibility to have the combination of unique_overload and first_overload as a much safer solution.
Special thanks and recognition goes to Technical Center of Nokia: Lannion for supporting in part the production of this proposal.
Special thanks to Bryce Adelstein Lelbach for his notifying the new primary author of this proposal so it could be cleaned up for C++20.