1. Changelog
2. Revision 0 - April 12th, 2022
- 
     🎉 Initial (and hopefully, only) release! 
3. Introduction & Motivation
After a series of papers by Aaron Ballman and Jens Gustedt to provide what are now known as * potentially reserved names* in the C Standard, we enabled strictly-conforming and pedantic implementations of the C Standard to avoid warning on names that were not officially taken by the implementation or standard. This removed a bunch of warnings on potentially non-conforming code that included certain headers and had aggregates with members such as:
struct streptobacillus ; /* previously reserved and UB, now potentially-reserved and not UB unless implementation or standard takes the name. */ 
This solves one problem, but leaves another: the actual introduction of names.
3.1. Handling New Names
As of right now, if the C standard or an implementation decides to take the name 
- 
     _Thread_local 
- 
     _Static_assert 
- 
     _Atomic 
- 
     _Bool 
- 
     _BitInt ( …) 
- 
     and more… 
However, we still do not have a similar consistent practice for the C Standard Library’s functions. Much of these are sourced from C implementations, which means we generally have to follow the behavior and practice of existing C libraries to-the-letter. This can be problematic when we want to make changes to such interfaces, such as Annex K’s 
One way to avoid these problems is by providing for a prefix for use with the standard library. This has been proposed before in Nick Stoughton’s [N1345], but Mr. Stoughton’s proposal contained a fatal flaw: it was also for the use of new keywords of the language as well. Therefore, it would not be 
Some discussion on the reflector 13 years later, more functions were being added to the standard and new areas of interest that already had widely existing practice were being tackled. There were too many builtins and user-named functions which had taken popular library names, like 
4. Design
The choice of name will have to be up to Committee Consensus, if it is deemed that a prefix for the standard library would be desirable to aid in prevention of name collisions with the existing ecosystem. Some popular selections for prefixes for the C standard library include the below choices. Note the C Standard now requires up to 32 characters of significant names for external identifiers, so there is some breathing room as opposed to the old limit of 8 characters.
- 
     stdc_ __STDC_ …__ std std :: stdc_ 
- 
     std_ stdc_ std std :: std_ 
- 
     iso_ std_ 
- 
     isoc_ stdc_ 
- 
     c_ std std :: c_foo ( …) 
- 
     sc_ c_ 
Whatever the Committee chooses for a name, it will be substituted into the wording below for the token 
5. Specification
The following specification is related to the latest C Standard Draft at the time of publication (N2731).
5.1. Add a new bullet point at the top for globally-reserved macro and library names to §7.1.3 "Reserved Identifiers, paragraph ¶1.
— All identifiers starting with
are reserved for future use.STANDARD - C - PREFIX 
5.2. Add a new item to the C Charter
Additionally, on top of this wording, the specification changes should also include a change to the C Charter Document to recommend:
New library functionality (not Core Language functionality) should use the prefix
where it is desirable to avoid collision with existing code or widely-established practice that may have divergent APIs and ABIs for the purposes of unification. It is important to leave old code without undue modification.STANDARD - C - PREFIX