functions and macros now parsed by parser_context
This commit is contained in:
parent
163b99e967
commit
554a61d7a0
|
@ -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
|
||||||
|
|
||||||
|
|
438
4ed_metagen.cpp
438
4ed_metagen.cpp
|
@ -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 = ¯o_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;
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue