1. Changelog
1.1. Revision 1 - February 3rd, 2025
- 
     Switch to using a keyword-style specification rather than a predefined identifier specification (allows for directly referencing the function rather than making a function pointer object). 
- 
     Add examples and explain (future) application, in anticipation of the Nested Functions and Lambda TS. 
1.2. Revision 0 - December 23rd, 2024
- 
     Initial Release! 🎉 
2. Introduction and Motivation
C99 introduced 
Recently, 
This paper is the lift out, implementing 
3. Design
The design for this is, thankfully, very simple and easy: 
In general, this allows someone to
3.1. Separate from the function itself
One of the key benefits of 
However, C++ still has a vast deficiency here in that even with their new Deducing This feature (see: Gasper Azman’s P0847) which allows you to get the "this" of the function (even a "callable function" like a Lambda), it
- 
     does not work as a substitute for the function itself, just the "object" the function is tied to (if it has one); 
- 
     and, does not allow someone to get the signature of the function they are within without explicitly modifying the function itself to pass that object to something like what is attempted in va_start 
This means that C++ still can’t viably implement 
- 
     typeof ( foo ) 
- 
     _Generic 
- 
     and, some way to access the name of the function or function object without needing to modify the function signature as it stands (currently unavailable). 
This means that the implementation of 
This proposal enables standalone, independent retrieval of the function designator of the function in use, which gives access to both the function itself and, importantly for a pure, ABI-based, assembly-hacking, library-hacking implementation, the function’s type signature.
3.2. Future: Lambdas
This is important when lambdas (e.g. Jens Gustedt’s Basic Lambdas for C: N2892) need this as they are, effectively, anonymous complete function objects. They don’t necessary have a name. This also applies to Apple’s C extension, Blocks; right now, there’s no way to get the name of a Lambda or the start of an unnamed Block. 
3.3. Keyword Name
We do not care what this is called. This has 3 popular names:
- 
     self 
- 
     this * this this 
- 
     recur 
Another popular name is 
As stated earlier, we do not care what it is called, so long as it exists. Suggestions are welcome and any name will do just fine.
4. Wording
This wording is relative to C’s latest working draft.
📝 Editor’s Note: The ✨ characters are intentional. They represent stand-ins to be replaced by the editor.
4.1. OPTIONAL: Modify "Predefined identifiers" (6.4.3.2)
- 
     change the mention of "execution encoding" in this section to instead be "literal encoding (6.2.9)"; 
- 
     and, add constexpr static const char __func__ [] = "function-name" 
4.2. Add the new keyword __self_func 
   Syntax
1 postfix-expression:
primary-expression
postfix-expression
*expression[ ] 
postfix-expression
argument-expression-listopt( ) 
postfix-expression
identifier. 
postfix-expression
identifier-> 
postfix-expression
++ 
postfix-expression
-- 
compound-literal
__self_func 
4.3. Add a new section §6.5.3.✨ "__self_func 
   6.5.3.✨__self_func Constraintsshall appear in a function body.__self_func Semantics
is the function designator (6.3.3.1) of the function it is used in.__self_func EXAMPLE A program refers to the enclosing function even when the name is not directly known.
#include <stdlib.h>#include <stddef.h>#include <stdio.h>bool f ( int tries , char * fn ) { #define MAX_TRIES 30 #define RE_DO(TRIES, ...) if (TRIES >= MAX_TRIES) goto TOO_MANY_TRIES;\ return __self_func(TRIES + 1 __VA_OPT__(,) __VA_ARGS__); if ( fn == nullptr ) return false; size_t fnlen = strlen ( fn ); if ( fnlen < 1 ) return false; FILE * f = fopen ( fn ); if ( ! f ) { fn [ fnlen - 1 ] = '0' + tries ; RE_DO ( tries , fn ); } // found the first proper f, // use it fclose ( f ); return true; TOO_MANY_TRIES : if ( f ) fclose ( f ); return false; }