47#define MAX_RECURSION_DEPTH 32
51 size_t * out_num_args,
52 size_t * out_num_fixed_args);
72 while (isspace((
unsigned char)*state->
p))
75 while (*state->
p !=
'\n' && *state->
p !=
'\0')
89 const char *
start = state->
p;
92 unsigned long long val = strtoull(
start, &
end, 10);
95 if (
end ==
start || errno == ERANGE) {
102 if (val > SIZE_MAX) {
106 *out_val = (size_t)val;
120 const char *
start = state->
p;
121 if (!isalpha((
unsigned char)*
start) && *
start !=
'_')
123 while (isalnum((
unsigned char)*state->
p) || *state->
p ==
'_' || *state->
p ==
':') {
124 if (*state->
p ==
':' && state->
p[1] !=
':')
126 if (*state->
p ==
':')
130 size_t len = state->
p -
start;
154 size_t len = strlen(keyword);
155 if (strncmp(state->
p, keyword, len) == 0) {
157 if (isalnum((
unsigned char)state->
p[len]) || state->
p[len] ==
'_')
177 const char * p_before = state->
p;
181 if (*state->
p ==
':') {
205 const char *
p = state->
p;
211 while (*
p !=
'\0' && depth > 0) {
221 while (isspace((
unsigned char)*
p) || *
p ==
'#') {
223 while (*
p !=
'\n' && *
p !=
'\0')
229 return (
p[0] ==
'-' &&
p[1] ==
'>');
245 typedef struct member_node {
247 struct member_node * next;
249 member_node *head =
nullptr, *tail =
nullptr;
250 size_t num_members = 0;
252 if (*state->
p != end_char) {
254 const char * p_before_member = state->
p;
257 if (name && (*state->
p ==
',' || *state->
p == end_char)) {
258 state->
p = p_before_member + strlen(name);
272 uint8_t bit_width = 0;
273 bool is_bitfield =
false;
274 const char * p_before_colon = state->
p;
276 if (*state->
p ==
':') {
279 if (!isdigit((
unsigned char)*state->
p)) {
281 state->
p = p_before_colon;
284 size_t width_val = 0;
287 if (width_val > 255) {
291 bit_width = (uint8_t)width_val;
309 node->next =
nullptr;
320 if (*state->
p ==
',') {
324 if (*state->
p == end_char) {
329 else if (*state->
p == end_char)
332 if (*state->
p ==
'\0') {
341 *out_num_members = num_members;
342 if (num_members == 0)
351 member_node * current = head;
352 for (
size_t i = 0; i < num_members; i++) {
354 current = current->next;
372 if (*state->
p != start_char) {
378 size_t num_members = 0;
385 if (*state->
p != end_char) {
408 size_t alignment = 1;
409 if (*state->
p ==
'!') {
411 if (isdigit((
unsigned char)*state->
p)) {
415 if (*state->
p !=
':') {
423 if (*state->
p !=
'{') {
428 size_t num_members = 0;
432 if (*state->
p !=
'}') {
443 size_t total_size = 0;
444 for (
size_t i = 0; i < num_members; ++i)
445 total_size +=
members[i].type->size;
600 size_t current_offset = state->
p - state->
start;
602 const char * p_before_type = state->
p;
603 if (*state->
p ==
'@') {
613 result_type =
nullptr;
615 else if (*state->
p ==
'*') {
624 result_type =
nullptr;
626 else if (*state->
p ==
'(') {
630 size_t num_args = 0, num_fixed = 0;
644 func_type->
size =
sizeof(
void *);
652 result_type = func_type;
663 if (*state->
p !=
')') {
665 result_type =
nullptr;
671 else if (*state->
p ==
'[') {
674 size_t num_elements = 0;
675 bool is_flexible =
false;
677 if (*state->
p ==
'?') {
688 if (*state->
p !=
':') {
706 if (*state->
p !=
']') {
715 result_type =
nullptr;
719 result_type =
nullptr;
722 else if (*state->
p ==
'!')
724 else if (*state->
p ==
'{')
726 else if (*state->
p ==
'<')
728 else if (*state->
p ==
'e' && state->
p[1] ==
':') {
738 result_type =
nullptr;
740 else if (*state->
p ==
'c' && state->
p[1] ==
'[') {
749 if (*state->
p !=
']') {
756 result_type =
nullptr;
758 else if (*state->
p ==
'v' && state->
p[1] ==
'[') {
766 if (*state->
p !=
':') {
777 if (*state->
p !=
']') {
784 result_type =
nullptr;
791 state->
p = p_before_type;
792 if (isalpha((
unsigned char)*state->
p) || *state->
p ==
'_')
821 size_t * out_num_args,
822 size_t * out_num_fixed_args) {
823 if (*state->
p !=
'(') {
830 typedef struct arg_node {
832 struct arg_node * next;
834 arg_node *head =
nullptr, *tail =
nullptr;
837 if (*state->
p !=
')' && *state->
p !=
';') {
840 if (*state->
p ==
')' || *state->
p ==
';')
852 node->arg.type = arg_type;
853 node->arg.name = name;
854 node->next =
nullptr;
863 if (*state->
p ==
',') {
866 if (*state->
p ==
')' || *state->
p ==
';') {
871 else if (*state->
p !=
')' && *state->
p !=
';') {
879 *out_num_fixed_args = num_args;
881 if (*state->
p ==
';') {
883 if (*state->
p !=
')') {
886 if (*state->
p ==
')')
898 node->arg.type = arg_type;
899 node->arg.name = name;
900 node->next =
nullptr;
909 if (*state->
p ==
',') {
912 if (*state->
p ==
')') {
917 else if (*state->
p !=
')') {
927 if (*state->
p !=
')') {
934 if (state->
p[0] !=
'-' || state->
p[1] !=
'>') {
946 if (num_args > 0 && !
args) {
950 arg_node * current = head;
951 for (
size_t i = 0; i < num_args; i++) {
952 args[i] = current->arg;
953 current = current->next;
956 *out_num_args = num_args;
978 const char * signature) {
979 if (!out_type || !out_arena) {
983 if (!signature || *signature ==
'\0') {
993 parser_state state = {.
p = signature, .start = signature, .arena = *out_arena, .depth = 0};
998 if (state.
p[0] !=
'\0') {
1006 *out_arena =
nullptr;
1007 *out_type =
nullptr;
1028 const char * signature,
1050 *out_arena =
nullptr;
1058 *out_arena =
nullptr;
1059 *out_type =
nullptr;
1064 *out_type = final_type;
1089 size_t * out_num_args,
1090 size_t * out_num_fixed_args,
1099 if (*signature ==
'\0') {
1103 if (!out_arena || !out_ret_type || !out_args || !out_num_args || !out_num_fixed_args) {
1134 if (!final_func_type) {
1136 *out_arena =
nullptr;
1145 *out_arena =
nullptr;
1169 const void * itanium_subs[64];
1187 va_start(
args, fmt);
1190 if (written < 0 || (
size_t)written >= state->
remaining)
1194 state->
p += written;
1234 int digit = val % 36;
1235 buf[pos++] = (digit < 10) ? (
char)(
'0' + digit) : (char)(
'A' + digit - 10);
1239 _print(state,
"%c", buf[--pos]);
1364 bool printed_alias =
false;
1366 if (num_elements == 8 &&
is_double(element_type)) {
1368 printed_alias =
true;
1370 else if (num_elements == 16 &&
is_float(element_type)) {
1372 printed_alias =
true;
1376 printed_alias =
true;
1378 else if (num_elements == 4 &&
is_double(element_type)) {
1380 printed_alias =
true;
1382 else if (num_elements == 8 &&
is_float(element_type)) {
1384 printed_alias =
true;
1387 if (!printed_alias) {
1388 _print(state,
"v[%zu:", num_elements);
1424 _print(state,
"sint128");
1427 _print(state,
"uint128");
1430 _print(state,
"float16");
1439 _print(state,
"longdouble");
1530 size_t len = strlen(name);
1531 _print(state,
"%zu%s", len, name);
1540 const char *
p = type->
name;
1544 if (
p[0] ==
':' &&
p[1] ==
':') {
1558 const char *
end = strstr(
p,
"::");
1559 size_t part_len =
end ? (size_t)(
end -
p) : strlen(
p);
1560 _print(state,
"%zu", part_len);
1562 for (
size_t i = 0; i < part_len; i++)
1573 size_t len = strlen(type->
name);
1643 if (strstr(type->
name,
"::")) {
1644 _print(state,
"%c", prefix);
1653 const char *
p = type->
name;
1656 const char *
end = strstr(
p,
"::");
1658 lens[count] =
end -
p;
1662 lens[count] = strlen(
p);
1669 for (
int i = count - 1; i >= 0; i--) {
1670 for (
size_t j = 0; j < lens[i]; j++)
1671 _print(state,
"%c", parts[i][j]);
1767 _print(state,
"U_Complex@@");
1904 _print(state,
"sint128");
1907 _print(state,
"uint128");
1910 _print(state,
"float16");
1919 _print(state,
"longdouble");
1951 buffer[buffer_size - 1] =
'\0';
1967 if (!buffer || buffer_size == 0 || !type) {
1980 _print(&state,
"unsupported_dialect");
1988 buffer[buffer_size - 1] =
'\0';
1992 else if (buffer_size > 0)
1994 buffer[buffer_size - 1] =
'\0';
2011 const char * function_name,
2015 size_t num_fixed_args,
2018 if (!buffer || buffer_size == 0 || !
ret_type || (num_args > 0 && !
args)) {
2025 (void)function_name;
2027 for (
size_t i = 0; i < num_fixed_args; ++i) {
2032 if (num_args > num_fixed_args) {
2034 for (
size_t i = num_fixed_args; i < num_args; ++i) {
2035 if (i > num_fixed_args)
2048 if (function_name) {
2050 const char *
p = function_name;
2053 if (
p[0] ==
':' &&
p[1] ==
':') {
2065 const char *
end = strstr(
p,
"::");
2066 size_t part_len =
end ? (size_t)(
end -
p) : strlen(
p);
2067 _print(&state,
"%zu", part_len);
2068 for (
size_t i = 0; i < part_len; i++)
2078 size_t name_len = strlen(function_name);
2079 _print(&state,
"%zu%s", name_len, function_name);
2088 for (
size_t i = 0; i < num_args; ++i)
2094 if (function_name) {
2096 if (strstr(function_name,
"::")) {
2100 const char *
p = function_name;
2103 const char *
end = strstr(
p,
"::");
2105 lens[count] =
end -
p;
2109 lens[count] = strlen(
p);
2115 for (
int i = count - 1; i >= 0; i--) {
2116 for (
size_t j = 0; j < lens[i]; j++)
2117 _print(&state,
"%c", parts[i][j]);
2122 _print(&state,
"%s@", function_name);
2134 for (
size_t i = 0; i < num_args; ++i)
2139 _print(&state,
"unsupported_dialect");
2146 if (buffer_size > 0)
2147 buffer[buffer_size - 1] =
'\0';
2151 else if (buffer_size > 0)
2152 buffer[buffer_size - 1] =
'\0';
2170 if (!buffer || buffer_size == 0 || !
registry)
2178 if (entry->type && !entry->is_forward_declaration) {
2179 char type_body_buffer[1024];
2184 goto end_print_loop;
2186 _print(&state,
"@%s = %s;\n", entry->name, type_body_buffer);
2188 else if (entry->is_forward_declaration)
2189 _print(&state,
"@%s;\n", entry->name);
2191 goto end_print_loop;
infix_registry_t * registry
Definition 008_registry_introspection.c:33
infix_status status
Definition 103_unions.c:61
infix_struct_member * members
Definition 103_unions.c:55
void * args[]
Definition 202_in_structs.c:59
clock_t start
Definition 901_call_overhead.c:48
infix_type * ret_type
Definition 901_call_overhead.c:61
clock_t end
Definition 901_call_overhead.c:48
char * p
Definition 904_registry_benchmark.c:25
#define c23_nodiscard
Internal alias for the public INFIX_NODISCARD macro.
Definition compat_c23.h:92
#define INFIX_TLS
Definition error.c:68
INFIX_API infix_error_details_t infix_get_last_error(void)
Retrieves detailed information about the last error that occurred on the current thread.
Definition error.c:281
infix_error_code_t
Enumerates specific error codes.
Definition infix.h:1360
@ INFIX_CODE_SUCCESS
Definition infix.h:1362
@ INFIX_CODE_INVALID_MEMBER_TYPE
Definition infix.h:1388
@ INFIX_CODE_INTEGER_OVERFLOW
Definition infix.h:1379
@ INFIX_CODE_TYPE_TOO_LARGE
Definition infix.h:1386
@ INFIX_CODE_EMPTY_SIGNATURE
Definition infix.h:1382
@ INFIX_CODE_UNEXPECTED_TOKEN
Definition infix.h:1375
@ INFIX_CODE_MISSING_RETURN_TYPE
Definition infix.h:1378
@ INFIX_CODE_RECURSION_DEPTH_EXCEEDED
Definition infix.h:1380
@ INFIX_CODE_UNTERMINATED_AGGREGATE
Definition infix.h:1376
@ INFIX_CODE_NULL_POINTER
Definition infix.h:1364
@ INFIX_CODE_INVALID_KEYWORD
Definition infix.h:1377
@ INFIX_CODE_OUT_OF_MEMORY
Definition infix.h:1369
@ INFIX_CATEGORY_ALLOCATION
Definition infix.h:1353
@ INFIX_CATEGORY_GENERAL
Definition infix.h:1352
@ INFIX_CATEGORY_PARSER
Definition infix.h:1354
size_t source_offset
Definition infix.h:282
struct infix_type_t::@0::@1 pointer_info
Metadata for INFIX_TYPE_POINTER.
union infix_type_t::@0 meta
A union containing metadata specific to the type's category.
bool is_packed
Definition infix.h:295
struct infix_type_t::@0::@7 vector_info
Metadata for INFIX_TYPE_VECTOR.
infix_type * type
Definition infix.h:348
c23_nodiscard infix_status infix_signature_parse(const char *signature, infix_arena_t **out_arena, infix_type **out_ret_type, infix_function_argument **out_args, size_t *out_num_args, size_t *out_num_fixed_args, infix_registry_t *registry)
Parses a full function signature string into its constituent parts.
Definition signature.c:1085
struct infix_type_t::@0::@4 func_ptr_info
Metadata for INFIX_TYPE_REVERSE_TRAMPOLINE.
size_t num_elements
Definition infix.h:300
size_t size
Definition infix.h:277
size_t alignment
Definition infix.h:278
infix_struct_member * members
Definition infix.h:293
struct infix_type_t::@0::@6 complex_info
Metadata for INFIX_TYPE_COMPLEX.
c23_nodiscard infix_status infix_type_from_signature(infix_type **out_type, infix_arena_t **out_arena, const char *signature, infix_registry_t *registry)
Parses a signature string representing a single data type.
Definition signature.c:1026
const char * name
Definition infix.h:275
infix_function_argument * args
Definition infix.h:306
infix_status
Enumerates the possible status codes returned by infix API functions.
Definition infix.h:434
const char * name
Definition infix.h:347
const char * name
Definition infix.h:335
infix_type_category category
Definition infix.h:276
struct infix_type_t::@0::@2 aggregate_info
Metadata for INFIX_TYPE_STRUCT and INFIX_TYPE_UNION.
struct infix_type_t::@0::@3 array_info
Metadata for INFIX_TYPE_ARRAY.
struct infix_type_t * pointee_type
Definition infix.h:289
infix_type * type
Definition infix.h:336
struct infix_type_t * element_type
Definition infix.h:299
bool is_flexible
Definition infix.h:301
struct infix_type_t * return_type
Definition infix.h:305
struct infix_type_t::@0::@5 enum_info
Metadata for INFIX_TYPE_ENUM.
struct infix_type_t * base_type
Definition infix.h:316
uint8_t bit_width
Definition infix.h:338
size_t num_members
Definition infix.h:294
struct infix_type_t * underlying_type
Definition infix.h:312
struct infix_type_t::@0::@8 named_reference
Metadata for INFIX_TYPE_NAMED_REFERENCE.
size_t num_fixed_args
Definition infix.h:308
infix_primitive_type_id primitive_id
Metadata for INFIX_TYPE_PRIMITIVE.
Definition infix.h:286
size_t num_args
Definition infix.h:307
bool is_arena_allocated
Definition infix.h:279
@ INFIX_ERROR_ALLOCATION_FAILED
Definition infix.h:436
@ INFIX_SUCCESS
Definition infix.h:435
@ INFIX_ERROR_INVALID_ARGUMENT
Definition infix.h:437
INFIX_API c23_nodiscard infix_status infix_function_print(char *buffer, size_t buffer_size, const char *function_name, const infix_type *ret_type, const infix_function_argument *args, size_t num_args, size_t num_fixed_args, infix_print_dialect_t dialect)
Serializes a function signature's components into a string.
Definition signature.c:2009
INFIX_API c23_nodiscard infix_status infix_type_print(char *buffer, size_t buffer_size, const infix_type *type, infix_print_dialect_t dialect)
Serializes an infix_type object graph back into a signature string.
Definition signature.c:1962
infix_print_dialect_t
Specifies the output format for printing types and function signatures.
Definition infix.h:1175
@ INFIX_DIALECT_SIGNATURE
Definition infix.h:1176
@ INFIX_DIALECT_ITANIUM_MANGLING
Definition infix.h:1177
@ INFIX_DIALECT_MSVC_MANGLING
Definition infix.h:1178
#define infix_memcpy
A macro that can be defined to override the default memcpy function.
Definition infix.h:387
INFIX_API INFIX_NODISCARD infix_arena_t * infix_arena_create(size_t)
Creates a new memory arena.
Definition arena.c:52
INFIX_API INFIX_NODISCARD void * infix_arena_calloc(infix_arena_t *, size_t, size_t, size_t)
Allocates and zero-initializes a block of memory from an arena.
Definition arena.c:188
INFIX_API void infix_arena_destroy(infix_arena_t *)
Destroys an arena and frees all memory allocated from it.
Definition arena.c:83
c23_nodiscard infix_status infix_registry_print(char *buffer, size_t buffer_size, const infix_registry_t *registry)
Serializes all defined types within a registry into a single, human-readable string.
Definition signature.c:2169
INFIX_API INFIX_NODISCARD infix_status infix_type_create_pointer_to(infix_arena_t *, infix_type **, infix_type *)
Creates a new pointer type that points to a specific type.
Definition types.c:393
INFIX_API infix_struct_member infix_type_create_member(const char *, infix_type *, size_t)
A factory function to create an infix_struct_member.
Definition types.c:208
INFIX_API INFIX_NODISCARD infix_status infix_type_create_packed_struct(infix_arena_t *, infix_type **, size_t, size_t, infix_struct_member *, size_t)
Creates a new packed struct type with a user-specified layout.
Definition types.c:719
INFIX_API INFIX_NODISCARD infix_status infix_type_create_complex(infix_arena_t *, infix_type **, infix_type *)
Creates a new _Complex number type.
Definition types.c:542
INFIX_API INFIX_NODISCARD infix_type * infix_type_create_void(void)
Creates a static descriptor for the void type.
Definition types.c:200
INFIX_API INFIX_NODISCARD infix_status infix_type_create_union(infix_arena_t *, infix_type **, infix_struct_member *, size_t)
Creates a new union type from an array of members.
Definition types.c:612
INFIX_API infix_struct_member infix_type_create_bitfield_member(const char *, infix_type *, size_t, uint8_t)
A factory function to create a bitfield infix_struct_member.
Definition types.c:219
INFIX_API INFIX_NODISCARD infix_status infix_type_create_named_reference(infix_arena_t *, infix_type **, const char *, infix_aggregate_category_t)
Creates a placeholder for a named type to be resolved by a registry.
Definition types.c:777
INFIX_API INFIX_NODISCARD infix_type * infix_type_create_primitive(infix_primitive_type_id)
Creates a static descriptor for a primitive C type.
Definition types.c:144
INFIX_API INFIX_NODISCARD infix_status infix_type_create_vector(infix_arena_t *, infix_type **, infix_type *, size_t)
Creates a new SIMD vector type.
Definition types.c:573
INFIX_API INFIX_NODISCARD infix_status infix_type_create_struct(infix_arena_t *, infix_type **, infix_struct_member *, size_t)
Creates a new struct type from an array of members, calculating layout automatically.
Definition types.c:660
INFIX_API INFIX_NODISCARD infix_status infix_type_create_enum(infix_arena_t *, infix_type **, infix_type *)
Creates a new enum type with a specified underlying integer type.
Definition types.c:507
INFIX_API infix_status infix_type_create_flexible_array(infix_arena_t *, infix_type **, infix_type *)
Creates a flexible array member type ([?:type]).
Definition types.c:463
INFIX_API INFIX_NODISCARD infix_status infix_type_create_array(infix_arena_t *, infix_type **, infix_type *, size_t)
Creates a new fixed-size array type.
Definition types.c:424
@ INFIX_PRIMITIVE_UINT16
Definition infix.h:247
@ INFIX_PRIMITIVE_UINT32
Definition infix.h:249
@ INFIX_PRIMITIVE_LONG_DOUBLE
Definition infix.h:258
@ INFIX_PRIMITIVE_FLOAT
Definition infix.h:256
@ INFIX_PRIMITIVE_DOUBLE
Definition infix.h:257
@ INFIX_PRIMITIVE_SINT16
Definition infix.h:248
@ INFIX_PRIMITIVE_SINT64
Definition infix.h:252
@ INFIX_PRIMITIVE_SINT32
Definition infix.h:250
@ INFIX_PRIMITIVE_UINT8
Definition infix.h:245
@ INFIX_PRIMITIVE_UINT128
Definition infix.h:253
@ INFIX_PRIMITIVE_BOOL
Definition infix.h:244
@ INFIX_PRIMITIVE_UINT64
Definition infix.h:251
@ INFIX_PRIMITIVE_FLOAT16
Definition infix.h:255
@ INFIX_PRIMITIVE_SINT128
Definition infix.h:254
@ INFIX_PRIMITIVE_SINT8
Definition infix.h:246
@ INFIX_TYPE_UNION
Definition infix.h:231
@ INFIX_TYPE_PRIMITIVE
Definition infix.h:228
@ INFIX_TYPE_COMPLEX
Definition infix.h:235
@ INFIX_TYPE_ARRAY
Definition infix.h:232
@ INFIX_TYPE_VECTOR
Definition infix.h:236
@ INFIX_TYPE_VOID
Definition infix.h:238
@ INFIX_TYPE_POINTER
Definition infix.h:229
@ INFIX_TYPE_NAMED_REFERENCE
Definition infix.h:237
@ INFIX_TYPE_REVERSE_TRAMPOLINE
Definition infix.h:233
@ INFIX_TYPE_ENUM
Definition infix.h:234
@ INFIX_TYPE_STRUCT
Definition infix.h:230
@ INFIX_AGGREGATE_STRUCT
Definition infix.h:264
#define INFIX_API
Symbol visibility macro.
Definition infix.h:114
#define INFIX_INTERNAL
When compiling with -fvisibility=hidden, we use this to explicitly mark internal-but-shared functions...
Definition infix_config.h:220
Internal data structures, function prototypes, and constants.
INFIX_INTERNAL c23_nodiscard infix_status _infix_resolve_type_graph_inplace(infix_type **type_ptr, infix_registry_t *registry)
Resolves all named type references in a type graph in-place.
Definition type_registry.c:428
static bool is_double(const infix_type *type)
A fast inline check to determine if an infix_type is a double.
Definition infix_internals.h:791
INFIX_INTERNAL infix_type * _copy_type_graph_to_arena(infix_arena_t *, const infix_type *)
Performs a deep copy of a type graph into a destination arena.
Definition types.c:1112
INFIX_INTERNAL void _infix_type_recalculate_layout(infix_type *type)
Recalculates the layout of a fully resolved type graph.
Definition types.c:924
INFIX_INTERNAL void _infix_clear_error(void)
Clears the thread-local error state.
Definition error.c:268
static bool is_float(const infix_type *type)
A fast inline check to determine if an infix_type is a float (32-bit).
Definition infix_internals.h:783
INFIX_INTERNAL void _infix_set_error(infix_error_category_t category, infix_error_code_t code, size_t position)
Sets the thread-local error state with detailed information.
Definition error.c:175
static void _print(printer_state *state, const char *fmt,...)
Definition signature.c:1183
static void _add_itanium_sub(printer_state *state, const void *component)
Definition signature.c:1214
static infix_struct_member * parse_aggregate_members(parser_state *state, char end_char, size_t *out_num_members)
Definition signature.c:243
static bool is_function_signature_ahead(const parser_state *state)
Definition signature.c:204
static void _infix_type_print_body_only_recursive(printer_state *state, const infix_type *type)
Definition signature.c:1799
c23_nodiscard infix_status _infix_type_print_body_only(char *buffer, size_t buffer_size, const infix_type *type, infix_print_dialect_t dialect)
An internal-only function to serialize a type's body without its registered name.
Definition signature.c:1939
INFIX_INTERNAL infix_type * parse_primitive(parser_state *state)
Definition signature.c:463
#define MAX_RECURSION_DEPTH
Definition signature.c:47
static bool _find_itanium_sub(printer_state *state, const void *component, size_t *index)
Definition signature.c:1204
INFIX_INTERNAL void skip_whitespace(parser_state *state)
Definition signature.c:70
static bool parse_size_t(parser_state *state, size_t *out_val)
Definition signature.c:88
c23_nodiscard infix_status _infix_parse_type_internal(infix_type **out_type, infix_arena_t **out_arena, const char *signature)
The internal core of the signature parser.
Definition signature.c:976
static void _print_itanium_sub(printer_state *state, size_t index)
Definition signature.c:1219
static infix_status parse_function_signature_details(parser_state *state, infix_type **out_ret_type, infix_function_argument **out_args, size_t *out_num_args, size_t *out_num_fixed_args)
Definition signature.c:818
INFIX_INTERNAL void _infix_set_parser_error(parser_state *state, infix_error_code_t code)
Definition signature.c:60
static bool consume_keyword(parser_state *state, const char *keyword)
Definition signature.c:152
static infix_type * parse_packed_struct(parser_state *state)
Definition signature.c:407
static infix_type * parse_aggregate(parser_state *state, char start_char, char end_char)
Definition signature.c:366
static const char * parse_identifier(parser_state *state)
Definition signature.c:118
INFIX_INTERNAL infix_type * parse_type(parser_state *state)
Definition signature.c:592
static void _infix_type_print_itanium_recursive(printer_state *state, const infix_type *type)
Definition signature.c:1454
static void _infix_type_print_signature_recursive(printer_state *state, const infix_type *type)
Definition signature.c:1257
static const char * parse_optional_name_prefix(parser_state *state)
Definition signature.c:174
INFIX_TLS const char * g_infix_last_signature_context
A thread-local pointer to the full signature string being parsed.
Definition error.c:99
static void _infix_type_print_msvc_recursive(printer_state *state, const infix_type *type)
Definition signature.c:1606
A single entry in the registry's hash table.
Definition infix_internals.h:174
Internal definition of a memory arena.
Definition infix_internals.h:143
Describes a single argument to a C function.
Definition infix.h:346
Internal definition of a named type registry.
Definition infix_internals.h:188
_infix_registry_entry_t ** buckets
Definition infix_internals.h:193
size_t num_buckets
Definition infix_internals.h:191
Describes a single member of a C struct or union.
Definition infix.h:334
A semi-opaque structure that describes a C type.
Definition infix.h:274
Holds the complete state of the recursive descent parser during a single parse operation.
Definition infix_internals.h:199
const char * start
Definition infix_internals.h:201
infix_arena_t * arena
Definition infix_internals.h:202
int depth
Definition infix_internals.h:203
const char * p
Definition infix_internals.h:200
Definition signature.c:1164
char * p
Definition signature.c:1165
size_t remaining
Definition signature.c:1166
infix_status status
Definition signature.c:1167
const void * itanium_subs[64]
Definition signature.c:1169
size_t msvc_type_count
Definition signature.c:1173
const infix_type * msvc_types[10]
Definition signature.c:1172
size_t itanium_sub_count
Definition signature.c:1170