compressed file reading and parsing into meta_parse
parent
56b04115b3
commit
59f1731746
1270
4coder_API.html
1270
4coder_API.html
File diff suppressed because it is too large
Load Diff
|
@ -50,7 +50,7 @@
|
|||
#define FREE_FILE_LIST_SIG(n) void n(Application_Links *app, File_List list)
|
||||
#define MEMORY_ALLOCATE_SIG(n) void* n(Application_Links *app, int32_t size)
|
||||
#define MEMORY_SET_PROTECTION_SIG(n) bool32 n(Application_Links *app, void *ptr, int32_t size, Memory_Protect_Flags flags)
|
||||
#define MEMORY_FREE_SIG(n) void n(Application_Links *app, void *mem, int32_t size)
|
||||
#define MEMORY_FREE_SIG(n) void n(Application_Links *app, void *ptr, int32_t size)
|
||||
#define FILE_EXISTS_SIG(n) bool32 n(Application_Links *app, char *filename, int32_t len)
|
||||
#define DIRECTORY_CD_SIG(n) bool32 n(Application_Links *app, char *dir, int32_t *len, int32_t capacity, char *rel_path, int32_t rel_len)
|
||||
#define GET_4ED_PATH_SIG(n) bool32 n(Application_Links *app, char *out, int32_t capacity)
|
||||
|
|
|
@ -1,5 +1,8 @@
|
|||
|
||||
|
||||
#define ENUM(type,name) typedef type name; enum name##_
|
||||
#define FLAGENUM(name) typedef uint32_t name; enum name##_
|
||||
|
||||
/* DOC(bool32 is an alias name to signal that an integer parameter or field is for
|
||||
true/false vales.) */
|
||||
typedef int32_t bool32;
|
||||
|
@ -20,9 +23,6 @@ typedef int32_t Buffer_ID;
|
|||
the interval [1,16].) */
|
||||
typedef int32_t View_ID;
|
||||
|
||||
#define ENUM(type,name) typedef type name; enum name##_
|
||||
#define FLAGENUM(name) typedef uint32_t name; enum name##_
|
||||
|
||||
/* DOC(A Key_Modifier acts as an index for specifying modifiers in arrays.) */
|
||||
ENUM(int32_t, Key_Modifier){
|
||||
MDFR_SHIFT_INDEX,
|
||||
|
|
110
4ed_metagen.cpp
110
4ed_metagen.cpp
|
@ -387,9 +387,10 @@ typedef struct Item_Set{
|
|||
Item_Node *items;
|
||||
} Item_Set;
|
||||
|
||||
typedef struct Struct_Set{
|
||||
Item_Node *structs;
|
||||
} Struct_Set;
|
||||
typedef struct Parse{
|
||||
String code;
|
||||
Cpp_Token_Stack tokens;
|
||||
} Parse;
|
||||
|
||||
static Item_Node null_item_node = {0};
|
||||
|
||||
|
@ -415,6 +416,15 @@ file_dump(char *filename){
|
|||
return(result);
|
||||
}
|
||||
|
||||
static Parse
|
||||
meta_parse(char *filename){
|
||||
Parse result = {0};
|
||||
result.code = file_dump(filename);
|
||||
result.tokens = cpp_make_token_stack(1024);
|
||||
cpp_lex_file(result.code.str, result.code.size, &result.tokens);
|
||||
return(result);
|
||||
}
|
||||
|
||||
static String
|
||||
get_first_line(String source){
|
||||
String line = {0};
|
||||
|
@ -454,9 +464,12 @@ is_comment(String str){
|
|||
return(result);
|
||||
}
|
||||
|
||||
typedef struct Parse{
|
||||
Cpp_Token_Stack tokens;
|
||||
} Parse;
|
||||
typedef enum Doc_Note_Type{
|
||||
DOC_PARAM,
|
||||
DOC_RETURN,
|
||||
DOC,
|
||||
DOC_SEE
|
||||
} Doc_Note_Type;
|
||||
|
||||
static int32_t
|
||||
check_and_fix_docs(String *lexeme){
|
||||
|
@ -479,13 +492,6 @@ check_and_fix_docs(String *lexeme){
|
|||
return(result);
|
||||
}
|
||||
|
||||
typedef enum Doc_Note_Type{
|
||||
DOC_PARAM,
|
||||
DOC_RETURN,
|
||||
DOC,
|
||||
DOC_SEE
|
||||
} Doc_Note_Type;
|
||||
|
||||
static String
|
||||
doc_note_string[] = {
|
||||
make_lit_string("DOC_PARAM"),
|
||||
|
@ -1163,7 +1169,7 @@ parse_enum(Partition *part, char *data,
|
|||
int32_t start_i = i;
|
||||
|
||||
for (; i < count; ++i, ++token){
|
||||
if (token->type == CPP_TOKEN_PARENTHESE_CLOSE){
|
||||
if (token->type == CPP_TOKEN_BRACE_OPEN){
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -1804,24 +1810,15 @@ generate_custom_headers(){
|
|||
Partition part_ = make_part(mem, size);
|
||||
Partition *part = &part_;
|
||||
|
||||
String string_code = file_dump("internal_4coder_string.cpp");
|
||||
Cpp_Token_Stack string_tokens = {0};
|
||||
Parse string_parse = meta_parse("internal_4coder_string.cpp");
|
||||
|
||||
int32_t string_function_count = 0;
|
||||
|
||||
{
|
||||
String *code = &string_code;
|
||||
Cpp_Token_Stack *token_stack = &string_tokens;
|
||||
char *data = string_parse.code.str;
|
||||
|
||||
char *data = code->str;
|
||||
int32_t size = code->size;
|
||||
|
||||
*token_stack = cpp_make_token_stack(1024);
|
||||
cpp_lex_file(data, size, token_stack);
|
||||
|
||||
|
||||
int32_t count = token_stack->count;
|
||||
Cpp_Token *tokens = token_stack->tokens;
|
||||
int32_t count = string_parse.tokens.count;
|
||||
Cpp_Token *tokens = string_parse.tokens.tokens;
|
||||
Cpp_Token *token = tokens;
|
||||
|
||||
for (int32_t i = 0; i < count; ++i, ++token){
|
||||
|
@ -1850,8 +1847,8 @@ generate_custom_headers(){
|
|||
int32_t string_sig_count = 0;
|
||||
|
||||
{
|
||||
String *code = &string_code;
|
||||
Cpp_Token_Stack *token_stack = &string_tokens;
|
||||
String *code = &string_parse.code;
|
||||
Cpp_Token_Stack *token_stack = &string_parse.tokens;
|
||||
|
||||
char *data = code->str;
|
||||
|
||||
|
@ -1904,22 +1901,16 @@ generate_custom_headers(){
|
|||
// App API parsing
|
||||
//
|
||||
|
||||
String code_data[2];
|
||||
code_data[0] = file_dump("4ed_api_implementation.cpp");
|
||||
code_data[1] = file_dump("win32_api_impl.cpp");
|
||||
Parse parses[2];
|
||||
parses[0] = meta_parse("4ed_api_implementation.cpp");
|
||||
parses[1] = meta_parse("win32_api_impl.cpp");
|
||||
|
||||
int32_t line_count = 0;
|
||||
|
||||
for (int32_t J = 0; J < 2; ++J){
|
||||
String *code = &code_data[J];
|
||||
Parse *parse = &parses[J];
|
||||
|
||||
char *data = code->str;
|
||||
int32_t size = code->size;
|
||||
|
||||
parse->tokens = cpp_make_token_stack(512);
|
||||
cpp_lex_file(data, size, &parse->tokens);
|
||||
char *data = parse->code.str;
|
||||
|
||||
int32_t count = parse->tokens.count;
|
||||
Cpp_Token *tokens = parse->tokens.tokens;
|
||||
|
@ -1944,10 +1935,9 @@ generate_custom_headers(){
|
|||
int32_t sig_count_per_file[2];
|
||||
|
||||
for (int32_t J = 0; J < 2; ++J){
|
||||
String *code = &code_data[J];
|
||||
Parse *parse = &parses[J];
|
||||
|
||||
char *data = code->str;
|
||||
char *data = parse->code.str;
|
||||
|
||||
int32_t count = parse->tokens.count;
|
||||
Cpp_Token *tokens = parse->tokens.tokens;
|
||||
|
@ -2084,14 +2074,14 @@ generate_custom_headers(){
|
|||
// NOTE(allen): Documentation
|
||||
{
|
||||
Item_Set typedef_set = {0};
|
||||
Struct_Set struct_set = {0};
|
||||
Item_Set struct_set = {0};
|
||||
Item_Set flag_set = {0};
|
||||
Item_Set enum_set = {0};
|
||||
|
||||
String type_code[1];
|
||||
type_code[0] = file_dump("4coder_os_types.h");
|
||||
Parse type_parse[1];
|
||||
type_parse[0] = meta_parse("4coder_types.h");
|
||||
|
||||
Cpp_Token_Stack types_token_array[1];
|
||||
int32_t file_count = ArrayCount(type_parse);
|
||||
|
||||
int32_t typedef_count = 0;
|
||||
int32_t struct_count = 0;
|
||||
|
@ -2106,16 +2096,11 @@ generate_custom_headers(){
|
|||
make_lit_string("FLAGENUM"),
|
||||
};
|
||||
|
||||
for (int32_t J = 0; J < 1; ++J){
|
||||
char *data = type_code[J].str;
|
||||
int32_t size = type_code[J].size;
|
||||
for (int32_t J = 0; J < file_count; ++J){
|
||||
char *data = type_parse[J].code.str;
|
||||
|
||||
Cpp_Token_Stack types_tokens = cpp_make_token_stack(512);
|
||||
cpp_lex_file(data, size, &types_tokens);
|
||||
types_token_array[J] = types_tokens;
|
||||
|
||||
int32_t count = types_tokens.count;
|
||||
Cpp_Token *tokens = types_tokens.tokens;
|
||||
int32_t count = type_parse[J].tokens.count;
|
||||
Cpp_Token *tokens = type_parse[J].tokens.tokens;
|
||||
Cpp_Token *token = tokens;
|
||||
|
||||
for (int32_t i = 0; i < count; ++i, ++token){
|
||||
|
@ -2150,7 +2135,7 @@ generate_custom_headers(){
|
|||
}
|
||||
|
||||
if (struct_count > 0){
|
||||
struct_set.structs = push_array(part, Item_Node, struct_count);
|
||||
struct_set.items = push_array(part, Item_Node, struct_count);
|
||||
}
|
||||
|
||||
if (enum_count > 0){
|
||||
|
@ -2166,10 +2151,9 @@ generate_custom_headers(){
|
|||
int32_t flag_index = 0;
|
||||
int32_t enum_index = 0;
|
||||
|
||||
for (int32_t J = 0; J < 1; ++J){
|
||||
char *data = type_code[J].str;
|
||||
|
||||
Cpp_Token_Stack types_tokens = types_token_array[J];
|
||||
for (int32_t J = 0; J < file_count; ++J){
|
||||
char *data = type_parse[J].code.str;
|
||||
Cpp_Token_Stack types_tokens = type_parse[J].tokens;
|
||||
|
||||
int32_t count = types_tokens.count;
|
||||
Cpp_Token *tokens = types_tokens.tokens;
|
||||
|
@ -2199,7 +2183,7 @@ generate_custom_headers(){
|
|||
{
|
||||
if (parse_struct(part, (match_index == 1),
|
||||
data, tokens, count, &token,
|
||||
struct_set.structs + struct_index)){
|
||||
struct_set.items + struct_index)){
|
||||
++struct_index;
|
||||
}
|
||||
i = (int32_t)(token - tokens);
|
||||
|
@ -2242,8 +2226,8 @@ generate_custom_headers(){
|
|||
file = fopen(STRING_H, "wb");
|
||||
|
||||
{
|
||||
String *code = &string_code;
|
||||
Cpp_Token_Stack *token_stack = &string_tokens;
|
||||
String *code = &string_parse.code;
|
||||
Cpp_Token_Stack *token_stack = &string_parse.tokens;
|
||||
|
||||
int32_t start = 0;
|
||||
|
||||
|
@ -2705,7 +2689,7 @@ generate_custom_headers(){
|
|||
}
|
||||
|
||||
for (int32_t i = 0; i < struct_count; ++i){
|
||||
String name = struct_set.structs[i].name;
|
||||
String name = struct_set.items[i].name;
|
||||
fprintf(file,
|
||||
"<li>"
|
||||
"<a href='#%.*s_doc'>%.*s</a>"
|
||||
|
@ -2913,7 +2897,7 @@ generate_custom_headers(){
|
|||
}
|
||||
|
||||
for (int32_t i = 0; i < struct_count; ++i, ++I){
|
||||
Item_Node *member = &struct_set.structs[i];
|
||||
Item_Node *member = &struct_set.items[i];
|
||||
String name = member->name;
|
||||
fprintf(file,
|
||||
"<div id='%.*s_doc' style='margin-bottom: 1cm;'>\n"
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#define MEMORY_ALLOCATE_SIG(n) void* n(Application_Links *app, int32_t size)
|
||||
#define MEMORY_SET_PROTECTION_SIG(n) bool32 n(Application_Links *app, void *ptr, int32_t size, Memory_Protect_Flags flags)
|
||||
#define MEMORY_FREE_SIG(n) void n(Application_Links *app, void *mem, int32_t size)
|
||||
#define MEMORY_FREE_SIG(n) void n(Application_Links *app, void *ptr, int32_t size)
|
||||
#define FILE_EXISTS_SIG(n) bool32 n(Application_Links *app, char *filename, int32_t len)
|
||||
#define DIRECTORY_CD_SIG(n) bool32 n(Application_Links *app, char *dir, int32_t *len, int32_t capacity, char *rel_path, int32_t rel_len)
|
||||
#define GET_4ED_PATH_SIG(n) bool32 n(Application_Links *app, char *out, int32_t capacity)
|
||||
|
|
2
build.c
2
build.c
|
@ -267,7 +267,7 @@ standard_build(char *cdir, uint32_t flags){
|
|||
#if 1
|
||||
{
|
||||
BEGIN_TIME_SECTION();
|
||||
build(OPTS, cdir, "fsm_table_generator.cpp",
|
||||
build(OPTS | DEBUG_INFO, cdir, "fsm_table_generator.cpp",
|
||||
META_DIR, "fsmgen", 0);
|
||||
END_TIME_SECTION("build fsm generator");
|
||||
}
|
||||
|
|
|
@ -13,7 +13,11 @@ as this is the only one that will be used for generating headers and docs.
|
|||
|
||||
API_EXPORT void*
|
||||
Memory_Allocate(Application_Links *app, int32_t size)/*
|
||||
DOC(TODO)
|
||||
DOC_PARAM(size, The size in bytes of the block that should be returned.)
|
||||
DOC(This calls to a low level OS allocator which means it is best used
|
||||
for infrequent, large allocations. The size of the block must be remembered
|
||||
if it will be freed or if it's mem protection status will be changed.)
|
||||
DOC_SEE(memory_free)
|
||||
*/{
|
||||
void *result = VirtualAlloc(0, size, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
|
||||
return(result);
|
||||
|
@ -21,7 +25,13 @@ DOC(TODO)
|
|||
|
||||
API_EXPORT bool32
|
||||
Memory_Set_Protection(Application_Links *app, void *ptr, int32_t size, Memory_Protect_Flags flags)/*
|
||||
DOC(TODO)
|
||||
DOC_PARAM(ptr, The base of the block on which to set memory protection flags.)
|
||||
DOC_PARAM(size, The size that was originally used to allocate this block.)
|
||||
DOC_PARAM(flags, The new memory protection flags.)
|
||||
DOC(This call sets the memory protection flags of a block of memory that was previously
|
||||
allocate by memory_allocate.)
|
||||
DOC_SEE(memory_allocate)
|
||||
DOC_SEE(Memory_Protect_Flags)
|
||||
*/{
|
||||
bool32 result = false;
|
||||
DWORD old_protect = 0;
|
||||
|
@ -56,10 +66,14 @@ DOC(TODO)
|
|||
}
|
||||
|
||||
API_EXPORT void
|
||||
Memory_Free(Application_Links *app, void *mem, int32_t size)/*
|
||||
DOC(TODO)
|
||||
Memory_Free(Application_Links *app, void *ptr, int32_t size)/*
|
||||
DOC_PARAM(mem, The base of a block to free.)
|
||||
DOC_PARAM(size, The size that was originally used to allocate this block.)
|
||||
DOC(This call frees a block of memory that was previously allocated by
|
||||
memory_allocate.)
|
||||
DOC_SEE(memory_allocate)
|
||||
*/{
|
||||
VirtualFree(mem, 0, MEM_RELEASE);
|
||||
VirtualFree(ptr, 0, MEM_RELEASE);
|
||||
}
|
||||
|
||||
API_EXPORT bool32
|
||||
|
@ -177,7 +191,12 @@ DOC_SEE(Mouse_Cursor_Show_Type)
|
|||
}
|
||||
|
||||
API_EXPORT void
|
||||
Toggle_Fullscreen(Application_Links *app){
|
||||
Toggle_Fullscreen(Application_Links *app)/*
|
||||
DOC(This call tells 4coder to switch into or out of full screen mode.
|
||||
The changes of full screen mode do not take effect until the end of the current frame.
|
||||
On Windows this call will not work unless 4coder was started in "stream mode".
|
||||
Stream mode can be enabled with -S or -F flags on the command line to 4ed.)
|
||||
*/{
|
||||
/* NOTE(allen): Don't actually change window size now!
|
||||
Tell the platform layer to do the toggle (or to cancel the toggle)
|
||||
later when the app.step function isn't running. If the size changes
|
||||
|
@ -193,7 +212,13 @@ Toggle_Fullscreen(Application_Links *app){
|
|||
}
|
||||
|
||||
API_EXPORT bool32
|
||||
Is_Fullscreen(Application_Links *app){
|
||||
Is_Fullscreen(Application_Links *app)/*
|
||||
DOC_SEE(This call returns true if the 4coder is in full screen mode. This call
|
||||
takes toggles that have already occured this frame into account. So it may return
|
||||
true even though the frame has not ended and actually put 4coder into full screen. If
|
||||
it returns true though, 4coder will definitely be full screen by the beginning of the next
|
||||
frame if the state is not changed.)
|
||||
*/{
|
||||
/* NOTE(allen): This is a fancy way to say 'full_screen XOR do_toggle'
|
||||
This way this function can always report the state the fullscreen
|
||||
will have when the next frame runs, given the number of toggles
|
||||
|
@ -203,7 +228,10 @@ Is_Fullscreen(Application_Links *app){
|
|||
}
|
||||
|
||||
API_EXPORT void
|
||||
Send_Exit_Signal(Application_Links *app){
|
||||
Send_Exit_Signal(Application_Links *app)/*
|
||||
DOC_SEE(This call sends a signal to 4coder to attempt to exit. If there are unsaved
|
||||
files this triggers a dialogue ensuring you're okay with closing.)
|
||||
*/{
|
||||
win32vars.send_exit_signal = 1;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue