functions and macros now parsed by parser_context

master
Allen Webster 2016-09-03 01:03:03 -04:00
parent 163b99e967
commit 554a61d7a0
3 changed files with 240 additions and 234 deletions

View File

@ -460,7 +460,7 @@ char_is_alpha_true(char c)
FSTRING_INLINE fstr_bool FSTRING_INLINE fstr_bool
char_is_hex(char c) char_is_hex(char c)
{ {
return c >= '0' && c <= '9' || c >= 'A' && c <= 'F' || c >= 'a' && c <= 'f'; return (c >= '0' && c <= '9' || c >= 'A' && c <= 'F' || c >= 'a' && c <= 'f');
} }
#endif #endif
@ -489,13 +489,12 @@ string_zero(void)
#if !defined(FSTRING_GUARD) #if !defined(FSTRING_GUARD)
FSTRING_INLINE String FSTRING_INLINE String
make_string_cap(void *str, int32_t size, int32_t mem_size) make_string_cap(void *str, int32_t size, int32_t mem_size){
{
String result; String result;
result.str = (char*)str; result.str = (char*)str;
result.size = size; result.size = size;
result.memory_size = mem_size; result.memory_size = mem_size;
return result; return(result);
} }
#endif #endif
@ -506,7 +505,7 @@ make_string(void *str, int32_t size){
result.str = (char*)str; result.str = (char*)str;
result.size = size; result.size = size;
result.memory_size = size; result.memory_size = size;
return result; return(result);
} }
#endif #endif
@ -516,7 +515,7 @@ str_size(char *str)
{ {
int32_t i = 0; int32_t i = 0;
while (str[i]) ++i; while (str[i]) ++i;
return i; return(i);
} }
#endif #endif
@ -528,7 +527,7 @@ make_string_slowly(void *str)
result.str = (char*)str; result.str = (char*)str;
result.size = str_size((char*)str); result.size = str_size((char*)str);
result.memory_size = result.size; result.memory_size = result.size;
return result; return(result);
} }
#endif #endif

View File

@ -710,9 +710,8 @@ static Item_Set
allocate_item_set(Partition *part, int32_t count){ allocate_item_set(Partition *part, int32_t count){
Item_Set item_set = {0}; Item_Set item_set = {0};
if (count > 0){ if (count > 0){
int32_t memory_size = sizeof(Item_Node)*count;
item_set.items = push_array(part, Item_Node, count); item_set.items = push_array(part, Item_Node, count);
memset(item_set.items, 0, memory_size); memset(item_set.items, 0, sizeof(Item_Node)*count);
} }
return(item_set); return(item_set);
} }
@ -735,17 +734,19 @@ setup_parse_context(Cpp_Token_Stack stack){
static Cpp_Token* static Cpp_Token*
get_token(Parse_Context *context){ get_token(Parse_Context *context){
Cpp_Token *result = context->token; Cpp_Token *result = context->token;
if (result >= context->token_e){
result = 0;
}
return(result); return(result);
} }
static Cpp_Token* static Cpp_Token*
get_next_token(Parse_Context *context){ get_next_token(Parse_Context *context){
Cpp_Token *result = context->token+1; Cpp_Token *result = context->token+1;
context->token = result;
if (result >= context->token_e){ if (result >= context->token_e){
result = 0; result = 0;
} context->token = context->token_e;
else{
context->token = result;
} }
return(result); return(result);
} }
@ -762,6 +763,15 @@ get_prev_token(Parse_Context *context){
return(result); return(result);
} }
static Cpp_Token*
can_back_step(Parse_Context *context){
Cpp_Token *result = context->token-1;
if (result < context->token_s){
result = 0;
}
return(result);
}
static Cpp_Token* static Cpp_Token*
set_token(Parse_Context *context, Cpp_Token *token){ set_token(Parse_Context *context, Cpp_Token *token){
Cpp_Token *result = 0; Cpp_Token *result = 0;
@ -1191,33 +1201,39 @@ parse_enum(Partition *part, char *data,
} }
static Argument_Breakdown static Argument_Breakdown
allocate_argument_breakdown(int32_t count){ allocate_argument_breakdown(Partition *part, int32_t count){
Argument_Breakdown breakdown = {0}; Argument_Breakdown breakdown = {0};
int32_t memory_size = sizeof(Argument)*count; if (count > 0){
breakdown.count = count; breakdown.count = count;
breakdown.args = (Argument*)malloc(memory_size); breakdown.args = push_array(part, Argument, count);
memset(breakdown.args, 0, memory_size); memset(breakdown.args, 0, sizeof(Argument)*count);
}
return(breakdown); return(breakdown);
} }
/*
Parse arguments by giving pointers to the tokens:
foo(a, ... , z)
^ ^
*/
static Argument_Breakdown static Argument_Breakdown
parameter_parse(char *data, Cpp_Token *args_start_token, Cpp_Token *token){ parameter_parse(Partition *part, char *data, Cpp_Token *args_start_token, Cpp_Token *args_end_token){
int32_t arg_index = 0; int32_t arg_index = 0;
Cpp_Token *arg_token = args_start_token + 1; Cpp_Token *arg_token = args_start_token + 1;
int32_t param_string_start = arg_token->start; int32_t param_string_start = arg_token->start;
int32_t arg_count = 1; int32_t arg_count = 1;
arg_token = args_start_token; arg_token = args_start_token;
for (; arg_token < token; ++arg_token){ for (; arg_token < args_end_token; ++arg_token){
if (arg_token->type == CPP_TOKEN_COMMA){ if (arg_token->type == CPP_TOKEN_COMMA){
++arg_count; ++arg_count;
} }
} }
Argument_Breakdown breakdown = allocate_argument_breakdown(arg_count); Argument_Breakdown breakdown = allocate_argument_breakdown(part, arg_count);
arg_token = args_start_token + 1; arg_token = args_start_token + 1;
for (; arg_token <= token; ++arg_token){ for (; arg_token <= args_end_token; ++arg_token){
if (arg_token->type == CPP_TOKEN_COMMA || if (arg_token->type == CPP_TOKEN_COMMA ||
arg_token->type == CPP_TOKEN_PARENTHESE_CLOSE){ arg_token->type == CPP_TOKEN_PARENTHESE_CLOSE){
@ -1239,34 +1255,37 @@ parameter_parse(char *data, Cpp_Token *args_start_token, Cpp_Token *token){
++arg_index; ++arg_index;
++arg_token; if (arg_token+1 <= args_end_token){
if (arg_token <= token){ param_string_start = arg_token[1].start;
param_string_start = arg_token->start;
} }
--arg_token;
} }
} }
return(breakdown); return(breakdown);
} }
/*
Moves the context in the following way:
~~~~~~~ name( ~~~~~~~
^ -> ^
*/
static int32_t static int32_t
function_parse_check(int32_t *index, Cpp_Token **token_ptr, int32_t count){ function_parse_goto_name(Parse_Context *context){
int32_t result = false; int32_t result = false;
int32_t i = *index; Cpp_Token *token = 0;
Cpp_Token *token = *token_ptr;
{ {
for (; i < count; ++i, ++token){ for (; (token = get_token(context)) != 0; get_next_token(context)){
if (token->type == CPP_TOKEN_PARENTHESE_OPEN){ if (token->type == CPP_TOKEN_PARENTHESE_OPEN){
break; break;
} }
} }
if (i < count){ if (get_token(context)){
--i; do{
--token; token = get_prev_token(context);
}while(token->type == CPP_TOKEN_COMMENT);
if (token->type == CPP_TOKEN_IDENTIFIER){ if (token->type == CPP_TOKEN_IDENTIFIER){
result = true; result = true;
@ -1274,56 +1293,55 @@ function_parse_check(int32_t *index, Cpp_Token **token_ptr, int32_t count){
} }
} }
*index = i;
*token_ptr = token;
return(result); return(result);
} }
/*
Moves the context in the following way:
~~~~~~~ name( ~~~~~~~ /* XXX //
^ ---------------> ^
*/
static int32_t static int32_t
function_get_doc(int32_t *index, Cpp_Token **token_ptr, int32_t count, function_get_doc(Parse_Context *context, char *data, String *doc_string){
char *data, String *doc_string){
int32_t result = false; int32_t result = false;
int32_t i = *index; Cpp_Token *token = get_token(context);
Cpp_Token *token = *token_ptr; String lexeme = {0};
for (; i < count; ++i, ++token){ if (function_parse_goto_name(context)){
if (token->type == CPP_TOKEN_COMMENT){ if (token->type == CPP_TOKEN_IDENTIFIER){
String lexeme = make_string(data + token->start, token->size); for (; (token = get_token(context)) != 0; get_next_token(context)){
if (check_and_fix_docs(&lexeme)){ if (token->type == CPP_TOKEN_COMMENT){
*doc_string = lexeme; lexeme = get_lexeme(*token, data);
result = true; if (check_and_fix_docs(&lexeme)){
break; *doc_string = lexeme;
result = true;
break;
}
}
else if (token->type == CPP_TOKEN_BRACE_OPEN){
break;
}
} }
} }
else if (token->type == CPP_TOKEN_BRACE_OPEN){
break;
}
} }
*index = i;
*token_ptr = token;
return(result); return(result);
} }
static int32_t static int32_t
parse_cpp_name(int32_t *i_ptr, Cpp_Token **token_ptr, int32_t count, char *data, String *name){ parse_cpp_name(Parse_Context *context, char *data, String *name){
int32_t result = false; int32_t result = false;
int32_t i = *i_ptr; Cpp_Token *token = 0;
Cpp_Token *token = *token_ptr; Cpp_Token *token_start = get_token(context);
int32_t i_start = i; token = get_next_token(context);
Cpp_Token *token_start = token; if (token && token->type == CPP_TOKEN_PARENTHESE_OPEN){
token = get_next_token(context);
++i, ++token; if (token && token->type == CPP_TOKEN_IDENTIFIER){
if (i < count && token->type == CPP_TOKEN_PARENTHESE_OPEN){ token = get_next_token(context);
++i, ++token; if (token && token->type == CPP_TOKEN_PARENTHESE_CLOSE){
if (i < count && token->type == CPP_TOKEN_IDENTIFIER){
++i, ++token;
if (i < count && token->type == CPP_TOKEN_PARENTHESE_CLOSE){
*name = get_lexeme(*(token-1), data); *name = get_lexeme(*(token-1), data);
result = true; result = true;
} }
@ -1331,194 +1349,191 @@ parse_cpp_name(int32_t *i_ptr, Cpp_Token **token_ptr, int32_t count, char *data,
} }
if (!result){ if (!result){
i = i_start; set_token(context, token_start);
token = token_start;
} }
*i_ptr = i;
*token_ptr = token;
return(result); return(result);
} }
/*
Moves the context in the following way:
RETTY~ name( ~~~~~~~ )
^ ---------------> ^
*/
static int32_t static int32_t
function_sig_parse(int32_t *index, Cpp_Token **token_ptr, int32_t count, Cpp_Token *ret_start_token, function_sig_parse(Partition *part, Parse_Context *context,
char *data, Item_Set item_set, int32_t sig_count, String cpp_name){ char *data, Item_Set item_set, int32_t sig_count, String cpp_name){
int32_t result = false; int32_t result = false;
int32_t i = *index; int32_t size = 0;
Cpp_Token *token = *token_ptr; Cpp_Token *token = 0;
Cpp_Token *args_start_token = 0;
Cpp_Token *ret_token = get_token(context);
Cpp_Token *args_start_token = token+1; if (function_parse_goto_name(context)){
token = get_token(context);
args_start_token = token+1;
item_set.items[sig_count].name = get_lexeme(*token, data);
item_set.items[sig_count].name = get_lexeme(*token, data); size = token->start - ret_token->start;
item_set.items[sig_count].ret =
chop_whitespace(make_string(data + ret_token->start, size));
int32_t size = token->start - ret_start_token->start; for (; (token = get_token(context)) != 0; get_next_token(context)){
String ret = make_string(data + ret_start_token->start, size); if (token->type == CPP_TOKEN_PARENTHESE_CLOSE){
ret = chop_whitespace(ret); break;
item_set.items[sig_count].ret = ret; }
}
for (; i < count; ++i, ++token){ if (token){
if (token->type == CPP_TOKEN_PARENTHESE_CLOSE){ size = token->start + token->size - args_start_token->start;;
break; item_set.items[sig_count].args =
make_string(data + args_start_token->start, size);
item_set.items[sig_count].t = Item_Function;
item_set.items[sig_count].cpp_name = cpp_name;
item_set.items[sig_count].breakdown =
parameter_parse(part, data, args_start_token, token);
Assert(get_token(context)->type == CPP_TOKEN_PARENTHESE_CLOSE);
result = true;
} }
} }
if (i < count){
int32_t size = token->start + token->size - args_start_token->start;;
item_set.items[sig_count].args =
make_string(data + args_start_token->start, size);
item_set.items[sig_count].t = Item_Function;
item_set.items[sig_count].cpp_name = cpp_name;
Argument_Breakdown *breakdown = &item_set.items[sig_count].breakdown;
*breakdown = parameter_parse(data, args_start_token, token);
result = true;
}
*index = i;
*token_ptr = token;
return(result); return(result);
} }
/*
Moves the context in the following way:
MARKER ~~~ name( ~~~~~~~ )
^ -------------------> ^
*/
static int32_t static int32_t
function_parse(Parse_Context *context, char *data, function_parse(Partition *part, Parse_Context *context,
Item_Set item_set, int32_t sig_count, String cpp_name){ char *data, Item_Set item_set, int32_t sig_count, String cpp_name){
int32_t result = false; int32_t result = false;
Cpp_Token *jtoken = 0; String doc_string = {0};
Cpp_Token *token = get_token(context);
jtoken = get_token(context); item_set.items[sig_count].marker = get_lexeme(*token, data);
item_set.items[sig_count].marker = get_lexeme(*jtoken, data);
if (function_parse_check(get_index(context, 0), get_ptr(context), get_count(context))){ if (function_get_doc(context, data, &doc_string)){
if (jtoken->type == CPP_TOKEN_IDENTIFIER){ item_set.items[sig_count].doc_string = doc_string;
String doc_string = {0};
if (function_get_doc(get_index(context, 0), get_ptr(context),
get_count(context), data, &doc_string)){
item_set.items[sig_count].doc_string = doc_string;
}
}
} }
set_token(context, jtoken); set_token(context, token);
if (get_next_token(context)){ if (get_next_token(context)){
Cpp_Token *ret_start_token = get_token(context); if (function_sig_parse(part, context, data, item_set, sig_count, cpp_name)){
Assert(get_token(context)->type == CPP_TOKEN_PARENTHESE_CLOSE);
if (function_parse_check(get_index(context, 0), get_ptr(context), get_count(context))){ result = true;
if (function_sig_parse(get_index(context, 0), get_ptr(context), get_count(context),
ret_start_token, data, item_set, sig_count, cpp_name)){
result = true;
}
} }
} }
return(result); return(result);
} }
/*
Moves the context in the following way:
/* ~~~ // #define
^ ----> ^
*/
static int32_t static int32_t
macro_parse_check(int32_t *index, Cpp_Token **token_ptr, int32_t count){ macro_parse_check(Parse_Context *context){
int32_t result = false; int32_t result = false;
int32_t i = *index; Cpp_Token *token = 0;
Cpp_Token *token = *token_ptr;
{ if ((token = get_next_token(context)) != 0){
++i, ++token; if (token->type == CPP_TOKEN_COMMENT){
if (i < count){ if ((token = get_next_token(context)) != 0){
if (token->type == CPP_TOKEN_COMMENT){ if (token->type == CPP_PP_DEFINE){
++i, ++token; result = true;
if (i < count){
if (token->type == CPP_PP_DEFINE){
result = true;
}
} }
} }
} }
} }
*index = i;
*token_ptr = token;
return(result); return(result);
} }
/*
Moves the context in the following way:
/* ~~~ // #define ~~~~~~~~~~~~~~~~~ NOT_IN_MACRO_BODY
^ ----------------------------> ^
*/
static int32_t static int32_t
macro_parse(int32_t *index, Cpp_Token **token_ptr, int32_t count, macro_parse(Partition *part, Parse_Context *context,
char *data, Item_Set macro_set, int32_t sig_count){ char *data, Item_Set macro_set, int32_t sig_count){
int32_t result = false; int32_t result = false;
int32_t i = *index; Cpp_Token *token = 0;
Cpp_Token *token = *token_ptr; Cpp_Token *doc_token = 0;
Cpp_Token *args_start_token = 0;
if (i > 0){ String doc_string = {0};
Cpp_Token *doc_token = token-1;
String doc_string = make_string(data + doc_token->start, doc_token->size); if (macro_parse_check(context)){
token = get_token(context);
if (can_back_step(context)){
doc_token = token-1;
if (check_and_fix_docs(&doc_string)){ doc_string = get_lexeme(*doc_token, data);
macro_set.items[sig_count].doc_string = doc_string;
for (; i < count; ++i, ++token){ if (check_and_fix_docs(&doc_string)){
if (token->type == CPP_TOKEN_IDENTIFIER){ macro_set.items[sig_count].doc_string = doc_string;
break;
}
}
if (i < count && (token->flags & CPP_TFLAG_PP_BODY)){ for (; (token = get_token(context)) != 0; get_next_token(context)){
macro_set.items[sig_count].name = make_string(data + token->start, token->size); if (token->type == CPP_TOKEN_IDENTIFIER){
break;
++i, ++token;
if (i < count){
Cpp_Token *args_start_token = token;
for (; i < count; ++i, ++token){
if (token->type == CPP_TOKEN_PARENTHESE_CLOSE){
break;
}
} }
}
if (i < count){ if (get_token(context) && (token->flags & CPP_TFLAG_PP_BODY)){
int32_t start = args_start_token->start; macro_set.items[sig_count].name = get_lexeme(*token, data);
int32_t end = token->start + token->size;
macro_set.items[sig_count].args = make_string(data + start, end - start);
Argument_Breakdown *breakdown = &macro_set.items[sig_count].breakdown; if ((token = get_next_token(context)) != 0){
*breakdown = parameter_parse(data, args_start_token, token); args_start_token = token;
for (; (token = get_token(context)) != 0; get_next_token(context)){
++i, ++token; if (token->type == CPP_TOKEN_PARENTHESE_CLOSE){
if (i < count){ break;
Cpp_Token *body_start = token;
if (body_start->flags & CPP_TFLAG_PP_BODY){
for (; i < count; ++i, ++token){
if (!(token->flags & CPP_TFLAG_PP_BODY)){
break;
}
}
--i, --token;
Cpp_Token *body_end = token;
start = body_start->start;
end = body_end->start + body_end->size;
macro_set.items[sig_count].body = make_string(data + start, end - start);
} }
} }
macro_set.items[sig_count].t = Item_Macro; if (token){
result = true; int32_t start = args_start_token->start;
int32_t end = token->start + token->size;
macro_set.items[sig_count].args = make_string(data + start, end - start);
macro_set.items[sig_count].breakdown =
parameter_parse(part, data, args_start_token, token);
if ((token = get_next_token(context)) != 0){
Cpp_Token *body_start = token;
if (body_start->flags & CPP_TFLAG_PP_BODY){
for (; (token = get_token(context)) != 0; get_next_token(context)){
if (!(token->flags & CPP_TFLAG_PP_BODY)){
break;
}
}
token = get_prev_token(context);
start = body_start->start;
end = token->start + token->size;
macro_set.items[sig_count].body = make_string(data + start, end - start);
}
}
macro_set.items[sig_count].t = Item_Macro;
result = true;
}
} }
} }
} }
} }
} }
*index = i;
*token_ptr = token;
return(result); return(result);
} }
@ -1852,11 +1867,10 @@ typedef struct App_API{
} App_API; } App_API;
static App_API static App_API
allocate_app_api(int32_t count){ allocate_app_api(Partition *part, int32_t count){
App_API app_api = {0}; App_API app_api = {0};
int32_t memory_size = sizeof(App_API_Name)*count; app_api.names = push_array(part, App_API_Name, count);
app_api.names = (App_API_Name*)malloc(memory_size); memset(app_api.names, 0, sizeof(App_API_Name)*count);
memset(app_api.names, 0, memory_size);
return(app_api); return(app_api);
} }
@ -1881,25 +1895,25 @@ generate_custom_headers(){
{ {
char *data = string_parse.code.str; char *data = string_parse.code.str;
int32_t count = string_parse.tokens.count; Cpp_Token *token = 0;
Cpp_Token *tokens = string_parse.tokens.tokens;
Cpp_Token *token = tokens;
for (int32_t i = 0; i < count; ++i, ++token){ Parse_Context context_ = setup_parse_context(string_parse.tokens);
if (token->type == CPP_TOKEN_IDENTIFIER && Parse_Context *context = &context_;
!(token->flags & CPP_TFLAG_PP_BODY)){
String lexeme = make_string(data + token->start, token->size); for (; (token = get_token(context)) != 0; get_next_token(context)){
if (token->type == CPP_TOKEN_IDENTIFIER && !(token->flags & CPP_TFLAG_PP_BODY)){
String lexeme = get_lexeme(*token, data);
String_Function_Marker marker = String_Function_Marker marker =
string_function_marker_check(lexeme); string_function_marker_check(lexeme);
if (marker.parse_function){ if (marker.parse_function){
if (function_parse_check(&i, &token, count)){ if (function_parse_goto_name(context)){
++string_function_count; ++string_function_count;
} }
} }
else if (marker.parse_doc){ else if (marker.parse_doc){
if (macro_parse_check(&i, &token, count)){ if (macro_parse_check(context)){
++string_function_count; ++string_function_count;
} }
} }
@ -1916,41 +1930,35 @@ generate_custom_headers(){
char *data = code->str; char *data = code->str;
int32_t count = token_stack->count;
Cpp_Token *tokens = token_stack->tokens;
Cpp_Token *token = tokens;
Parse_Context context_ = setup_parse_context(*token_stack); Parse_Context context_ = setup_parse_context(*token_stack);
Parse_Context *context = &context_; Parse_Context *context = &context_;
String cpp_name = {0}; String cpp_name = {0};
int32_t has_cpp_name = 0; int32_t has_cpp_name = 0;
for (int32_t i = 0; i < count; ++i, ++token){ for (; get_token(context); get_next_token(context)){
if (token->type == CPP_TOKEN_IDENTIFIER && Cpp_Token *token = get_token(context);
!(token->flags & CPP_TFLAG_PP_BODY)){ if (token->type == CPP_TOKEN_IDENTIFIER && !(token->flags & CPP_TFLAG_PP_BODY)){
String lexeme = make_string(data + token->start, token->size); String lexeme = make_string(data + token->start, token->size);
String_Function_Marker marker = String_Function_Marker marker =
string_function_marker_check(lexeme); string_function_marker_check(lexeme);
if (marker.cpp_name){ if (marker.cpp_name){
if (parse_cpp_name(&i, &token, count, data, &cpp_name)){ if (parse_cpp_name(context, data, &cpp_name)){
has_cpp_name = 1; has_cpp_name = 1;
} }
} }
else if (marker.parse_function){ else if (marker.parse_function){
set_token(context, token); if (function_parse(part, context, data,
if (function_parse(context, data,
string_function_set, string_sig_count, string_function_set, string_sig_count,
cpp_name)){ cpp_name)){
++string_sig_count; ++string_sig_count;
} }
} }
else if (marker.parse_doc){ else if (marker.parse_doc){
if (macro_parse_check(&i, &token, count)){ if (macro_parse(part, context, data,
macro_parse(&i, &token, count, data, string_function_set, string_sig_count)){
string_function_set, string_sig_count);
++string_sig_count; ++string_sig_count;
} }
} }
@ -1984,12 +1992,16 @@ generate_custom_headers(){
Cpp_Token *tokens = parse->tokens.tokens; Cpp_Token *tokens = parse->tokens.tokens;
Cpp_Token *token = tokens; Cpp_Token *token = tokens;
Parse_Context context_ = setup_parse_context(parse->tokens);
Parse_Context *context = &context_;
for (int32_t i = 0; i < count; ++i, ++token){ for (int32_t i = 0; i < count; ++i, ++token){
if (token->type == CPP_TOKEN_IDENTIFIER && if (token->type == CPP_TOKEN_IDENTIFIER &&
!(token->flags & CPP_TFLAG_PP_BODY)){ !(token->flags & CPP_TFLAG_PP_BODY)){
String lexeme = make_string(data + token->start, token->size); String lexeme = make_string(data + token->start, token->size);
if (match_ss(lexeme, make_lit_string("API_EXPORT"))){ if (match_ss(lexeme, make_lit_string("API_EXPORT"))){
if (function_parse_check(&i, &token, count)){ set_token(context, token);
if (function_parse_goto_name(context)){
++line_count; ++line_count;
} }
} }
@ -1998,7 +2010,7 @@ generate_custom_headers(){
} }
Item_Set function_set = allocate_item_set(part, line_count); Item_Set function_set = allocate_item_set(part, line_count);
App_API func_4ed_names = allocate_app_api(line_count); App_API func_4ed_names = allocate_app_api(part, line_count);
int32_t sig_count = 0; int32_t sig_count = 0;
int32_t sig_count_per_file[2]; int32_t sig_count_per_file[2];
@ -2007,21 +2019,17 @@ generate_custom_headers(){
char *data = parse->code.str; char *data = parse->code.str;
int32_t count = parse->tokens.count;
Cpp_Token *tokens = parse->tokens.tokens;
Parse_Context context_ = setup_parse_context(parse->tokens); Parse_Context context_ = setup_parse_context(parse->tokens);
Parse_Context *context = &context_; Parse_Context *context = &context_;
// NOTE(allen): Header Parse // NOTE(allen): Header Parse
Cpp_Token *token = tokens; for (; get_token(context); get_next_token(context)){
for (int32_t i = 0; i < count; ++i, ++token){ Cpp_Token *token = get_token(context);
if (token->type == CPP_TOKEN_IDENTIFIER && if (token->type == CPP_TOKEN_IDENTIFIER && !(token->flags & CPP_TFLAG_PP_BODY)){
!(token->flags & CPP_TFLAG_PP_BODY)){
String lexeme = make_string(data + token->start, token->size); String lexeme = make_string(data + token->start, token->size);
if (match_ss(lexeme, make_lit_string("API_EXPORT"))){ if (match_ss(lexeme, make_lit_string("API_EXPORT"))){
set_token(context, token); set_token(context, token);
function_parse(context, data, function_set, function_parse(part, context, data, function_set,
sig_count, string_zero()); sig_count, string_zero());
if (function_set.items[sig_count].t == Item_Null){ if (function_set.items[sig_count].t == Item_Null){
function_set.items[sig_count] = null_item_node; function_set.items[sig_count] = null_item_node;

View File

@ -108,7 +108,7 @@ char_is_alpha_true(char c)
FSTRING_INLINE fstr_bool FSTRING_INLINE fstr_bool
char_is_hex(char c) char_is_hex(char c)
/* DOC(This call returns non-zero if c is any valid hexadecimal digit.) */{ /* DOC(This call returns non-zero if c is any valid hexadecimal digit.) */{
return c >= '0' && c <= '9' || c >= 'A' && c <= 'F' || c >= 'a' && c <= 'f'; return (c >= '0' && c <= '9' || c >= 'A' && c <= 'F' || c >= 'a' && c <= 'f');
} }
FSTRING_INLINE fstr_bool FSTRING_INLINE fstr_bool
@ -131,8 +131,7 @@ string_zero(void)
CPP_NAME(make_string) CPP_NAME(make_string)
FSTRING_INLINE String FSTRING_INLINE String
make_string_cap(void *str, int32_t size, int32_t mem_size) make_string_cap(void *str, int32_t size, int32_t mem_size)/*
/*
DOC_PARAM(str, The str parameter provides the of memory with which the string shall operate.) DOC_PARAM(str, The str parameter provides the of memory with which the string shall operate.)
DOC_PARAM(size, The size parameter expresses the initial size of the string. DOC_PARAM(size, The size parameter expresses the initial size of the string.
If the memory does not already contain a useful string this should be zero.) If the memory does not already contain a useful string this should be zero.)
@ -143,7 +142,7 @@ DOC(This call returns the String created from the parameters.)
result.str = (char*)str; result.str = (char*)str;
result.size = size; result.size = size;
result.memory_size = mem_size; result.memory_size = mem_size;
return result; return(result);
} }
FSTRING_INLINE String FSTRING_INLINE String
@ -159,7 +158,7 @@ DOC(This call returns the String created from the parameters.)
result.str = (char*)str; result.str = (char*)str;
result.size = size; result.size = size;
result.memory_size = size; result.memory_size = size;
return result; return(result);
} }
DOC_EXPORT /* DOC(This macro takes a literal string in quotes and uses it to create a String DOC_EXPORT /* DOC(This macro takes a literal string in quotes and uses it to create a String
@ -179,7 +178,7 @@ str_size(char *str)
/* DOC(This call returns the number of bytes before a null terminator starting at str.) */{ /* DOC(This call returns the number of bytes before a null terminator starting at str.) */{
int32_t i = 0; int32_t i = 0;
while (str[i]) ++i; while (str[i]) ++i;
return i; return(i);
} }
FSTRING_INLINE String FSTRING_INLINE String
@ -190,7 +189,7 @@ treating that as the size and memory size of the string.) */{
result.str = (char*)str; result.str = (char*)str;
result.size = str_size((char*)str); result.size = str_size((char*)str);
result.memory_size = result.size; result.memory_size = result.size;
return result; return(result);
} }
CPP_NAME(substr) CPP_NAME(substr)