TEMPORARY SOLUTION: have a code-wrapped file do all lexing in serial
parent
43d6c29e8b
commit
c97b6d1983
|
@ -55,7 +55,9 @@ inline Partition
|
||||||
partition_sub_part(Partition *data, int32_t size){
|
partition_sub_part(Partition *data, int32_t size){
|
||||||
Partition result = {};
|
Partition result = {};
|
||||||
void *d = partition_allocate(data, size);
|
void *d = partition_allocate(data, size);
|
||||||
if (d) result = make_part(d, size);
|
if (d){
|
||||||
|
result = make_part(d, size);
|
||||||
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
6
4ed.cpp
6
4ed.cpp
|
@ -478,7 +478,6 @@ COMMAND_DECL(toggle_line_wrap){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(toggle_tokens){
|
COMMAND_DECL(toggle_tokens){
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 0
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -487,14 +486,12 @@ COMMAND_DECL(toggle_tokens){
|
||||||
file_kill_tokens(system, &models->mem.general, file);
|
file_kill_tokens(system, &models->mem.general, file);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
file_first_lex_parallel(system, &models->mem.general, file);
|
file_first_lex_parallel(system, &models->mem, file);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
case_change_range(System_Functions *system, Mem_Options *mem, View *view, Editing_File *file, u8 a, u8 z, u8 char_delta){
|
case_change_range(System_Functions *system, Mem_Options *mem, View *view, Editing_File *file, u8 a, u8 z, u8 char_delta){
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 0
|
|
||||||
Range range = make_range(view->edit_pos->cursor.pos, view->edit_pos->mark);
|
Range range = make_range(view->edit_pos->cursor.pos, view->edit_pos->mark);
|
||||||
if (range.start < range.end){
|
if (range.start < range.end){
|
||||||
Edit_Step step = {};
|
Edit_Step step = {};
|
||||||
|
@ -519,7 +516,6 @@ case_change_range(System_Functions *system, Mem_Options *mem, View *view, Editin
|
||||||
if (file->state.token_array.tokens)
|
if (file->state.token_array.tokens)
|
||||||
file_relex_parallel(system, mem, file, range.start, range.end, 0);
|
file_relex_parallel(system, mem, file, range.start, range.end, 0);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_panel_vsplit){
|
COMMAND_DECL(open_panel_vsplit){
|
||||||
|
|
|
@ -743,12 +743,12 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
Models *models = cmd->models;
|
Models *models = cmd->models;
|
||||||
Editing_File *file = imp_get_file(cmd, buffer);
|
Editing_File *file = imp_get_file(cmd, buffer);
|
||||||
|
|
||||||
bool32 result = false;
|
bool32 result = 0;
|
||||||
|
|
||||||
i32 new_mapid = 0;
|
i32 new_mapid = 0;
|
||||||
|
|
||||||
if (file){
|
if (file){
|
||||||
result = true;
|
result = 11;
|
||||||
switch (setting){
|
switch (setting){
|
||||||
case BufferSetting_Lex:
|
case BufferSetting_Lex:
|
||||||
{
|
{
|
||||||
|
@ -759,7 +759,12 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
if (value){
|
if (value){
|
||||||
file_first_lex_parallel(system, &models->mem.general, file);
|
if (!file->settings.virtual_white){
|
||||||
|
file_first_lex_parallel(system, &models->mem, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_first_lex_serial(system, &models->mem, file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
@ -837,8 +842,13 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
b32 full_remeasure = 0;
|
b32 full_remeasure = 0;
|
||||||
if (value){
|
if (value){
|
||||||
if (!file->settings.virtual_white){
|
if (!file->settings.virtual_white){
|
||||||
|
if (file->settings.tokens_exist && !file->state.still_lexing){
|
||||||
file->settings.virtual_white = 1;
|
file->settings.virtual_white = 1;
|
||||||
full_remeasure = 1;
|
full_remeasure = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
result = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
@ -858,6 +868,8 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
file_update_cursor_positions(models, file);
|
file_update_cursor_positions(models, file);
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
default: result = 0; break;
|
||||||
}
|
}
|
||||||
fill_buffer_summary(buffer, file, cmd);
|
fill_buffer_summary(buffer, file, cmd);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,14 +14,14 @@
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
typedef uint8_t u8;
|
typedef uint8_t u8;
|
||||||
typedef uint64_t u64;
|
|
||||||
typedef uint32_t u32;
|
|
||||||
typedef uint16_t u16;
|
typedef uint16_t u16;
|
||||||
|
typedef uint32_t u32;
|
||||||
|
typedef uint64_t u64;
|
||||||
|
|
||||||
typedef int8_t i8;
|
typedef int8_t i8;
|
||||||
typedef int64_t i64;
|
|
||||||
typedef int32_t i32;
|
|
||||||
typedef int16_t i16;
|
typedef int16_t i16;
|
||||||
|
typedef int32_t i32;
|
||||||
|
typedef int64_t i64;
|
||||||
|
|
||||||
typedef i32 bool32;
|
typedef i32 bool32;
|
||||||
typedef i8 bool8;
|
typedef i8 bool8;
|
||||||
|
|
|
@ -1955,9 +1955,9 @@ Job_Callback_Sig(job_full_lex){
|
||||||
Buffer_Type *buffer = &file->state.buffer;
|
Buffer_Type *buffer = &file->state.buffer;
|
||||||
i32 text_size = buffer_size(buffer);
|
i32 text_size = buffer_size(buffer);
|
||||||
|
|
||||||
i32 buffer_size = (text_size + 3)&(~3);
|
i32 aligned_buffer_size = (text_size + 3)&(~3);
|
||||||
|
|
||||||
while (memory->size < buffer_size){
|
while (memory->size < aligned_buffer_size){
|
||||||
system->grow_thread_memory(memory);
|
system->grow_thread_memory(memory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2019,8 +2019,7 @@ Job_Callback_Sig(job_full_lex){
|
||||||
system->acquire_lock(FRAME_LOCK);
|
system->acquire_lock(FRAME_LOCK);
|
||||||
{
|
{
|
||||||
Assert(file->state.swap_array.tokens == 0);
|
Assert(file->state.swap_array.tokens == 0);
|
||||||
file->state.swap_array.tokens = (Cpp_Token*)
|
file->state.swap_array.tokens = (Cpp_Token*) general_memory_allocate(system, general, new_max*sizeof(Cpp_Token));
|
||||||
general_memory_allocate(system, general, new_max*sizeof(Cpp_Token));
|
|
||||||
}
|
}
|
||||||
system->release_lock(FRAME_LOCK);
|
system->release_lock(FRAME_LOCK);
|
||||||
|
|
||||||
|
@ -2049,10 +2048,8 @@ Job_Callback_Sig(job_full_lex){
|
||||||
file->state.still_lexing = 0;
|
file->state.still_lexing = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
file_kill_tokens(System_Functions *system,
|
file_kill_tokens(System_Functions *system, General_Memory *general, Editing_File *file){
|
||||||
General_Memory *general, Editing_File *file){
|
|
||||||
file->settings.tokens_exist = 0;
|
file->settings.tokens_exist = 0;
|
||||||
if (file->state.still_lexing){
|
if (file->state.still_lexing){
|
||||||
system->cancel_job(BACKGROUND_THREADS, file->state.lex_job);
|
system->cancel_job(BACKGROUND_THREADS, file->state.lex_job);
|
||||||
|
@ -2069,8 +2066,8 @@ file_kill_tokens(System_Functions *system,
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
file_first_lex_parallel(System_Functions *system,
|
file_first_lex_parallel(System_Functions *system, Mem_Options *mem, Editing_File *file){
|
||||||
General_Memory *general, Editing_File *file){
|
General_Memory *general = &mem->general;
|
||||||
file->settings.tokens_exist = 1;
|
file->settings.tokens_exist = 1;
|
||||||
|
|
||||||
if (file->is_loading == 0 && file->state.still_lexing == 0){
|
if (file->is_loading == 0 && file->state.still_lexing == 0){
|
||||||
|
@ -2087,15 +2084,106 @@ file_first_lex_parallel(System_Functions *system,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
file_first_lex_serial(System_Functions *system, Mem_Options *mem, Editing_File *file){
|
||||||
|
Partition *part = &mem->part;
|
||||||
|
General_Memory *general = &mem->general;
|
||||||
|
file->settings.tokens_exist = 1;
|
||||||
|
|
||||||
|
Assert(file->state.still_lexing == 0);
|
||||||
|
|
||||||
|
if (file->is_loading == 0){
|
||||||
|
Assert(file->state.token_array.tokens == 0);
|
||||||
|
|
||||||
|
{
|
||||||
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
|
|
||||||
|
Buffer_Type *buffer = &file->state.buffer;
|
||||||
|
i32 text_size = buffer_size(buffer);
|
||||||
|
|
||||||
|
i32 mem_size = partition_remaining(part);
|
||||||
|
|
||||||
|
Cpp_Token_Array tokens;
|
||||||
|
tokens.max_count = mem_size / sizeof(Cpp_Token);
|
||||||
|
tokens.count = 0;
|
||||||
|
tokens.tokens = push_array(part, Cpp_Token, tokens.max_count);
|
||||||
|
|
||||||
|
b32 still_lexing = 1;
|
||||||
|
|
||||||
|
Cpp_Lex_Data lex = cpp_lex_data_init();
|
||||||
|
|
||||||
|
// TODO(allen): deduplicate this against relex
|
||||||
|
char *chunks[3];
|
||||||
|
i32 chunk_sizes[3];
|
||||||
|
|
||||||
|
chunks[0] = buffer->data;
|
||||||
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
|
||||||
|
chunks[1] = buffer->data + buffer->size1 + buffer->gap_size;
|
||||||
|
chunk_sizes[1] = buffer->size2;
|
||||||
|
|
||||||
|
chunks[2] = 0;
|
||||||
|
chunk_sizes[2] = 0;
|
||||||
|
|
||||||
|
i32 chunk_index = 0;
|
||||||
|
|
||||||
|
do{
|
||||||
|
char *chunk = chunks[chunk_index];
|
||||||
|
i32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
|
i32 result = cpp_lex_step(&lex, chunk, chunk_size, text_size, &tokens, NO_OUT_LIMIT);
|
||||||
|
|
||||||
|
switch (result){
|
||||||
|
case LexResult_NeedChunk: ++chunk_index; break;
|
||||||
|
case LexResult_NeedTokenMemory: InvalidCodePath;
|
||||||
|
case LexResult_HitTokenLimit: InvalidCodePath;
|
||||||
|
case LexResult_Finished: still_lexing = 0; break;
|
||||||
|
}
|
||||||
|
} while (still_lexing);
|
||||||
|
|
||||||
|
i32 new_max = LargeRoundUp(tokens.count+1, Kbytes(1));
|
||||||
|
|
||||||
|
{
|
||||||
|
Assert(file->state.swap_array.tokens == 0);
|
||||||
|
file->state.swap_array.tokens = (Cpp_Token*) general_memory_allocate(system, general, new_max*sizeof(Cpp_Token));
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 *dest = (u8*)file->state.swap_array.tokens;
|
||||||
|
u8 *src = (u8*)tokens.tokens;
|
||||||
|
|
||||||
|
memcpy(dest, src, tokens.count*sizeof(Cpp_Token));
|
||||||
|
|
||||||
|
{
|
||||||
|
Cpp_Token_Array *file_token_array = &file->state.token_array;
|
||||||
|
file_token_array->count = tokens.count;
|
||||||
|
file_token_array->max_count = new_max;
|
||||||
|
if (file_token_array->tokens){
|
||||||
|
general_memory_free(system, general, file_token_array->tokens);
|
||||||
|
}
|
||||||
|
file_token_array->tokens = file->state.swap_array.tokens;
|
||||||
|
file->state.swap_array.tokens = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// NOTE(allen): These are outside the locked section because I don't
|
||||||
|
// think getting these out of order will cause critical bugs, and I
|
||||||
|
// want to minimize what's done in locked sections.
|
||||||
|
file->state.tokens_complete = 1;
|
||||||
|
file->state.still_lexing = 0;
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
file->state.tokens_complete = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
file_relex_parallel(System_Functions *system,
|
file_relex_parallel(System_Functions *system, Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i, i32 shift_amount){
|
||||||
Mem_Options *mem, Editing_File *file,
|
|
||||||
i32 start_i, i32 end_i, i32 shift_amount){
|
|
||||||
General_Memory *general = &mem->general;
|
General_Memory *general = &mem->general;
|
||||||
Partition *part = &mem->part;
|
Partition *part = &mem->part;
|
||||||
|
|
||||||
if (file->state.token_array.tokens == 0){
|
if (file->state.token_array.tokens == 0){
|
||||||
file_first_lex_parallel(system, general, file);
|
file_first_lex_parallel(system, mem, file);
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2106,8 +2194,7 @@ file_relex_parallel(System_Functions *system,
|
||||||
i32 extra_tolerance = 100;
|
i32 extra_tolerance = 100;
|
||||||
|
|
||||||
Cpp_Token_Array *array = &file->state.token_array;
|
Cpp_Token_Array *array = &file->state.token_array;
|
||||||
Cpp_Relex_Range relex_range =
|
Cpp_Relex_Range relex_range = cpp_get_relex_range(array, start_i, end_i);
|
||||||
cpp_get_relex_range(array, start_i, end_i);
|
|
||||||
|
|
||||||
i32 relex_space_size =
|
i32 relex_space_size =
|
||||||
relex_range.end_token_index - relex_range.start_token_index + extra_tolerance;
|
relex_range.end_token_index - relex_range.start_token_index + extra_tolerance;
|
||||||
|
@ -2135,7 +2222,6 @@ file_relex_parallel(System_Functions *system,
|
||||||
chunk_sizes[2] = 0;
|
chunk_sizes[2] = 0;
|
||||||
|
|
||||||
i32 chunk_index = 0;
|
i32 chunk_index = 0;
|
||||||
|
|
||||||
char *chunk = chunks[chunk_index];
|
char *chunk = chunks[chunk_index];
|
||||||
i32 chunk_size = chunk_sizes[chunk_index];
|
i32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
|
@ -2218,6 +2304,85 @@ file_relex_parallel(System_Functions *system,
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal b32
|
||||||
|
file_relex_serial(System_Functions *system, Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i, i32 shift_amount){
|
||||||
|
General_Memory *general = &mem->general;
|
||||||
|
Partition *part = &mem->part;
|
||||||
|
|
||||||
|
if (file->state.token_array.tokens == 0){
|
||||||
|
file_first_lex_serial(system, mem, file);
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert(!file->state.still_lexing);
|
||||||
|
|
||||||
|
Buffer_Type *buffer = &file->state.buffer;
|
||||||
|
Cpp_Token_Array *array = &file->state.token_array;
|
||||||
|
|
||||||
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
|
Cpp_Token_Array relex_array;
|
||||||
|
relex_array.count = 0;
|
||||||
|
relex_array.max_count = partition_remaining(part) / sizeof(Cpp_Token);
|
||||||
|
relex_array.tokens = push_array(part, Cpp_Token, relex_array.max_count);
|
||||||
|
|
||||||
|
i32 size = buffer_size(buffer);
|
||||||
|
|
||||||
|
Cpp_Relex_Data state = cpp_relex_init(array, start_i, end_i, shift_amount);
|
||||||
|
|
||||||
|
char *chunks[3];
|
||||||
|
i32 chunk_sizes[3];
|
||||||
|
|
||||||
|
chunks[0] = buffer->data;
|
||||||
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
|
||||||
|
chunks[1] = buffer->data + buffer->size1 + buffer->gap_size;
|
||||||
|
chunk_sizes[1] = buffer->size2;
|
||||||
|
|
||||||
|
chunks[2] = 0;
|
||||||
|
chunk_sizes[2] = 0;
|
||||||
|
|
||||||
|
i32 chunk_index = 0;
|
||||||
|
char *chunk = chunks[chunk_index];
|
||||||
|
i32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
|
while (!cpp_relex_is_start_chunk(&state, chunk, chunk_size)){
|
||||||
|
++chunk_index;
|
||||||
|
chunk = chunks[chunk_index];
|
||||||
|
chunk_size = chunk_sizes[chunk_index];
|
||||||
|
}
|
||||||
|
|
||||||
|
for(;;){
|
||||||
|
Cpp_Lex_Result lex_result = cpp_relex_step(&state, chunk, chunk_size, size, array, &relex_array);
|
||||||
|
|
||||||
|
switch (lex_result){
|
||||||
|
case LexResult_NeedChunk:
|
||||||
|
++chunk_index;
|
||||||
|
chunk = chunks[chunk_index];
|
||||||
|
chunk_size = chunk_sizes[chunk_index];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case LexResult_NeedTokenMemory: InvalidCodePath;
|
||||||
|
|
||||||
|
case LexResult_Finished: goto doublebreak;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
doublebreak:;
|
||||||
|
|
||||||
|
i32 new_count = cpp_relex_get_new_count(&state, array->count, &relex_array);
|
||||||
|
if (new_count > array->max_count){
|
||||||
|
i32 new_max = LargeRoundUp(new_count, Kbytes(1));
|
||||||
|
array->tokens = (Cpp_Token*)
|
||||||
|
general_memory_reallocate(system, general, array->tokens, array->count*sizeof(Cpp_Token), new_max*sizeof(Cpp_Token));
|
||||||
|
array->max_count = new_max;
|
||||||
|
}
|
||||||
|
|
||||||
|
cpp_relex_complete(&state, array, &relex_array);
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
|
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
undo_stack_grow_string(System_Functions *system, General_Memory *general, Edit_Stack *stack, i32 extra_size){
|
undo_stack_grow_string(System_Functions *system, General_Memory *general, Edit_Stack *stack, i32 extra_size){
|
||||||
i32 old_max = stack->max;
|
i32 old_max = stack->max;
|
||||||
|
@ -2903,7 +3068,12 @@ file_do_single_edit(System_Functions *system, Models *models, Editing_File *file
|
||||||
|
|
||||||
// NOTE(allen): token fixing
|
// NOTE(allen): token fixing
|
||||||
if (file->settings.tokens_exist){
|
if (file->settings.tokens_exist){
|
||||||
|
if (!file->settings.virtual_white){
|
||||||
file_relex_parallel(system, mem, file, start, end, shift_amount);
|
file_relex_parallel(system, mem, file, start, end, shift_amount);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_relex_serial(system, mem, file, start, end, shift_amount);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): meta data
|
// NOTE(allen): meta data
|
||||||
|
@ -2989,7 +3159,13 @@ file_do_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
// TODO(allen): Write a smart fast one here someday.
|
// TODO(allen): Write a smart fast one here someday.
|
||||||
Buffer_Edit *first_edit = batch;
|
Buffer_Edit *first_edit = batch;
|
||||||
Buffer_Edit *last_edit = batch + batch_size - 1;
|
Buffer_Edit *last_edit = batch + batch_size - 1;
|
||||||
|
|
||||||
|
if (!file->settings.virtual_white){
|
||||||
file_relex_parallel(system, mem, file, first_edit->start, last_edit->end, shift_total);
|
file_relex_parallel(system, mem, file, first_edit->start, last_edit->end, shift_total);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_relex_serial(system, mem, file, first_edit->start, last_edit->end, shift_total);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
@ -3500,27 +3676,34 @@ make_string_terminated(Partition *part, char *str, i32 len){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
init_normal_file(System_Functions *system, Models *models, Editing_File *file,
|
init_normal_file(System_Functions *system, Models *models, Editing_File *file, char *buffer, i32 size){
|
||||||
char *buffer, i32 size){
|
String val = make_string(buffer, size);
|
||||||
General_Memory *general = &models->mem.general;
|
|
||||||
|
|
||||||
String val = make_string(buffer, size);
|
|
||||||
file_create_from_string(system, models, file, val);
|
file_create_from_string(system, models, file, val);
|
||||||
|
|
||||||
|
Mem_Options *mem = &models->mem;
|
||||||
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
||||||
file_first_lex_parallel(system, general, file);
|
if (!file->settings.virtual_white){
|
||||||
|
file_first_lex_parallel(system, mem, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_first_lex_serial(system, mem, file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
init_read_only_file(System_Functions *system, Models *models, Editing_File *file){
|
init_read_only_file(System_Functions *system, Models *models, Editing_File *file){
|
||||||
General_Memory *general = &models->mem.general;
|
|
||||||
|
|
||||||
String val = null_string;
|
String val = null_string;
|
||||||
file_create_from_string(system, models, file, val, 1);
|
file_create_from_string(system, models, file, val, 1);
|
||||||
|
|
||||||
|
Mem_Options *mem = &models->mem;
|
||||||
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
||||||
file_first_lex_parallel(system, general, file);
|
if (!file->settings.virtual_white){
|
||||||
|
file_first_lex_parallel(system, mem, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_first_lex_serial(system, mem, file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue