1. Revision History
1.1. Revision 3 - November 26th, 2018
Strengthened rationale for the current set of suffixes in §3.1 But what about using t for ptrdiff_t and zu for size_t instead?.
1.2. Revision 2 - October 1st, 2018
Published as P0330R2; change reply-to and point of contact from Rein Halbersma to JeanHeyd Meneide, who revitalized paper according to feedback from Rein Halbersma, and all of LWG. Overwhelming consensus for it to be a Language Feature instead, proposal rewritten as Language proposal with wording against [n4762].
1.3. Revision 1 - October 12th, 2017
Published as P0330R1; expanded the survey of existing literals. Synced the proposed wording with the Working Draft WG21/N4687. Moved the reference implementation from BitBucket to GitHub.
1.4. Revision 0 - November 21st, 2014
Initial release; published as N4254.
Published as P0330R0; summarized LEWG’s view re N4254; dropped the proposed suffix for ptrdiff_t; changed the proposed suffix for size_t to zu; added survey of existing literal suffixes.
2. Motivation
| Currently | With Proposal | 
|---|---|
| ⚠️ - Compiles on 32-bit, truncates (maybe with warnings) on 64-bit ❌ - Compilation error | ✔️ - Compiles with no warnings on 32-bit or 64-bit | 
Consider this very simple code to print an index and its value:
std :: vector < int > v { 0 , 1 , 2 , 3 }; for ( auto i = 0 ; i < v . size (); ++ i ) { std :: cout << i << ": " << v [ i ] << '\n' ; } 
This code can lead to the following warnings:
main . cpp : In function 'int main () ': main . cpp : warning : comparison of integer expressions of different signedness : 'int 'and 'long unsigned int '[ - Wsign - compare ] for ( auto i = 0 ; i < v . size (); ++ i ) { ~~^~~~~~~~~~ 
It grows worse if a user wants to cache the size rather than query it per-iteration:
std :: vector < int > v { 0 , 1 , 2 , 3 }; for ( auto i = 0 , s = v . size (); i < s ; ++ i ) { /* use both i and v[i] */ } 
Resulting in a hard compiler error:
main . cpp : In function 'int main () ': main . cpp : 8 : 10 : error : inconsistent deduction for 'auto ': 'int 'and then 'long unsigned int 'for ( auto i = 0 , s = v . size (); i < s ; ++ i ) { ^~~~ 
This paper proposes adding a zu literal suffix that deduces literals to size_t, making the following warning-free:
for ( auto i = 0 zu ; i < v . size (); ++ i ) { std :: cout << i << ": " << v [ i ] << '\n' ; } 
More generally:
- 
     int is the default type deduced from integer literals without suffix; 
- 
     comparisons, signs or conversion ranks with integers can lead to surprising results; 
- 
     size_t ptrdiff_t . size () 
- 
     programmer intent and stability is hard to communicate portably with the current set of literals; 
- 
     surprises range from (pedantic) compiler errors to undefined behavior; 
- 
     existing integer suffixes (such as ul 
- 
     and, C-style casts and static_casts are verbose. 
3. Design
Following the feedback from §7 Feedback on Revisions, we have dropped the 
As a language feature, the design of the suffixes becomes much simpler. The core language only has one format for its integer literal suffixes: the letter(s), with an optional 
The literal suffixes 
3.1. But what about using t ptrdiff_t zu size_t 
   Consider the following snippet:
int main () { signed decltype ( sizeof ( 0 )) x = 0 ; unsigned decltype (( char * ) nullptr - ( char * ) nullptr ) y = 0 ; return x - y ; } 
When compiled, these warnings appear:
main . cpp : 2 : 32 : warning : long , short , signed or unsigned used invalidly for 'x' [ - Wpedantic ] main . cpp : 3 : 56 : warning : long , short , signed or unsigned used invalidly for 'y' [ - Wpedantic ] 
These warnings are, in fact, correct: 
This paper is not attempting to make such a definition.
3.2. What about the fixed/least/max (unsigned) int types?
This paper does not propose suffixes for the fixed size, at-least size, and max size integral types in the standard library or the language. This paper is focusing exclusively on 
4. Impact on the Standard
This feature is purely an extension of the language and has, to the best of our knowledge, no conflict with existing or currently proposed features. 
5. Proposed wording and Feature Test Macros
The following wording is relative to [n4762].
5.1. Proposed feature Test Macro
The recommended feature test macro is 
5.2. Intent
The intent of this paper is to propose 2 language suffixes for integral literals of specific types. One is for 
5.3. Proposed Wording
Modify §5.13.2 Integer Literals [lex.icon] with additional suffixes:
- integer-suffix:
- unsigned-suffix long-suffixopt
- unsigned-suffix long-long-suffixopt
- unsigned-suffix ptrdiff-suffixopt
- long-suffix unsigned-suffixopt
- long-long-suffix unsigned-suffixopt
- ptrdiff-suffix unsigned-suffixopt
unsigned-suffix: one of
u Ulong-suffix: one of
l Llong-long-suffix: one of
ll LLptrdiff-suffix: one of
z Z
Append to §5.13.2 Integer Literals [lex.icon]'s Table 7 two additional entries:
Suffix Decimal literal Binary, octal, or hexadecimal literal z or Z ptrdiff_t ptrdiff_t Both u or U 
and z or Zsize_t size_t 
Append to §14.8.1 Predefined macro names [cpp.predefined]'s Table 16 with one additional entry:
Macro name Value __cpp_ptrdiff_t_suffix 201811L 
6. Acknowledgements
Thank you to Rein Halbersma, who started this paper and put in the necessary work for r0 and r1. Thank you to Walter E. Brown, who acted as locum on this paper before the Committee twice and gave us valuable feedback on wording. Thank you to Lounge<C++>'s Cicada for encouraging us to write this paper. Thank you to Hubert Tong for giving us a few pointers on where in the Core Language to modify things for such a paper. Thank you to Tim Song for wording advice.
We appreciate your guidance as we learn to be a better Committee member and represent the C++ community’s needs more more efficiently and effectively in the coming months.
7. Feedback on Revisions
Polls are in the form Strongly in Favor | Favor | Neutral | Against | Strongly Against. The polls on Revision 1 were as follows, from LWG at the WG21 Albuquerque meeting.
Proposal as presented, i.e., are we OK with the library solution going forward?
0 | 6 | 5 | 7 | 4
We translated this as strong discouragement to pursue this feature as a set of user-defined literals. A second poll was taken.
Do we want to solve this problem with a language feature?
2 | 15 | 0 | 2 | 2
We considered this overwhelming consensus for it to be a language feature instead, culminating in this paper after much feedback.