progress converting the platform layer over
parent
3006d5425c
commit
c7b1328cab
|
@ -417,11 +417,11 @@ DOC_SEE(File_List)
|
||||||
*/
|
*/
|
||||||
STRUCT File_Info{
|
STRUCT File_Info{
|
||||||
/* DOC(This field is a null terminated string specifying the name of the file.) */
|
/* DOC(This field is a null terminated string specifying the name of the file.) */
|
||||||
char *filename;
|
uint8_t *filename;
|
||||||
/* DOC(This field specifies the length of the filename string not counting the null terminator.) */
|
/* DOC(This field specifies the length of the filename string not counting the null terminator.) */
|
||||||
int32_t filename_len;
|
uint32_t filename_len;
|
||||||
/* DOC(This field indicates that the description is for a folder not a file.) */
|
/* DOC(This field indicates that the description is for a folder not a file.) */
|
||||||
int32_t folder;
|
bool32 folder;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* DOC(File_List is a list of File_Info structs.) */
|
/* DOC(File_List is a list of File_Info structs.) */
|
||||||
|
@ -431,9 +431,9 @@ STRUCT File_List{
|
||||||
/* DOC(This field is an array of File_Info structs.) */
|
/* DOC(This field is an array of File_Info structs.) */
|
||||||
File_Info *infos;
|
File_Info *infos;
|
||||||
/* DOC(This field specifies the number of struts in the info array.) */
|
/* DOC(This field specifies the number of struts in the info array.) */
|
||||||
int32_t count;
|
uint32_t count;
|
||||||
/* DOC(This field is for internal use.) */
|
/* DOC(This field is for internal use.) */
|
||||||
int32_t block_size;
|
uint32_t block_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* DOC(Buffer_Identifier acts as a loosely typed description of a buffer that can either be a name or an id.) */
|
/* DOC(Buffer_Identifier acts as a loosely typed description of a buffer that can either be a name or an id.) */
|
||||||
|
|
|
@ -102,12 +102,12 @@ open_all_files_with_extension_internal(Application_Links *app, String dir, char
|
||||||
File_List list = get_file_list(app, dir.str, dir.size);
|
File_List list = get_file_list(app, dir.str, dir.size);
|
||||||
int32_t dir_size = dir.size;
|
int32_t dir_size = dir.size;
|
||||||
|
|
||||||
for (int32_t i = 0; i < list.count; ++i){
|
for (uint32_t i = 0; i < list.count; ++i){
|
||||||
File_Info *info = list.infos + i;
|
File_Info *info = list.infos + i;
|
||||||
if (info->folder){
|
if (info->folder){
|
||||||
if (recursive){
|
if (recursive){
|
||||||
dir.size = dir_size;
|
dir.size = dir_size;
|
||||||
append(&dir, info->filename);
|
append(&dir, (char*)info->filename);
|
||||||
append(&dir, "/");
|
append(&dir, "/");
|
||||||
open_all_files_with_extension_internal(app, dir, extension_list, extension_count, recursive);
|
open_all_files_with_extension_internal(app, dir, extension_list, extension_count, recursive);
|
||||||
}
|
}
|
||||||
|
@ -130,7 +130,7 @@ open_all_files_with_extension_internal(Application_Links *app, String dir, char
|
||||||
|
|
||||||
if (is_match){
|
if (is_match){
|
||||||
dir.size = dir_size;
|
dir.size = dir_size;
|
||||||
append(&dir, info->filename);
|
append(&dir, (char*)info->filename);
|
||||||
create_buffer(app, dir.str, dir.size, 0);
|
create_buffer(app, dir.str, dir.size, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
2
4ed.cpp
2
4ed.cpp
|
@ -452,7 +452,7 @@ COMMAND_DECL(toggle_line_wrap){
|
||||||
else{
|
else{
|
||||||
file->settings.unwrapped_lines = 1;
|
file->settings.unwrapped_lines = 1;
|
||||||
}
|
}
|
||||||
view_cursor_move(system, view, view->edit_pos->cursor.pos);
|
view_cursor_move(system, view, (u32)view->edit_pos->cursor.pos);
|
||||||
view_set_relative_scrolling(view, scrolling);
|
view_set_relative_scrolling(view, scrolling);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -571,7 +571,7 @@ DOC_SEE(4coder_Buffer_Positioning_System)
|
||||||
size = buffer_size(&file->state.buffer);
|
size = buffer_size(&file->state.buffer);
|
||||||
if (0 <= start && start <= end && end <= size){
|
if (0 <= start && start <= end && end <= size){
|
||||||
result = true;
|
result = true;
|
||||||
buffer_stringify(&file->state.buffer, start, end, out);
|
buffer_stringify(&file->state.buffer, (u32)start, (u32)end, out);
|
||||||
}
|
}
|
||||||
fill_buffer_summary(buffer, file, cmd);
|
fill_buffer_summary(buffer, file, cmd);
|
||||||
}
|
}
|
||||||
|
@ -672,7 +672,7 @@ DOC_SEE(Buffer_Batch_Edit_Type)
|
||||||
char *inv_str = (char*)part->base + part->pos;
|
char *inv_str = (char*)part->base + part->pos;
|
||||||
umem inv_str_max = part->max - part->pos;
|
umem inv_str_max = part->max - part->pos;
|
||||||
|
|
||||||
Edit_Spec spec = file_compute_edit(mem, file, edits, str, str_len, inverse_edits, inv_str, (u32)inv_str_max, (u32)edit_count, type);
|
Edit_Spec spec = file_compute_edit(mem, file, edits, str, (u32)str_len, inverse_edits, inv_str, (u32)inv_str_max, (u32)edit_count, type);
|
||||||
|
|
||||||
file_do_batch_edit(system, models, file, spec, hist_normal, type);
|
file_do_batch_edit(system, models, file, spec, hist_normal, type);
|
||||||
|
|
||||||
|
@ -1802,11 +1802,11 @@ DOC_SEE(Buffer_Seek)
|
||||||
if (seek.type != buffer_seek_pos){
|
if (seek.type != buffer_seek_pos){
|
||||||
result = true;
|
result = true;
|
||||||
cursor = view_compute_cursor(system, vptr, seek, 0);
|
cursor = view_compute_cursor(system, vptr, seek, 0);
|
||||||
vptr->edit_pos->mark = cursor.pos;
|
vptr->edit_pos->mark = (u32)cursor.pos;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
result = true;
|
result = true;
|
||||||
vptr->edit_pos->mark = seek.pos;
|
vptr->edit_pos->mark = (u32)seek.pos;
|
||||||
}
|
}
|
||||||
fill_view_summary(system, view, vptr, cmd);
|
fill_view_summary(system, view, vptr, cmd);
|
||||||
}
|
}
|
||||||
|
@ -1832,7 +1832,7 @@ DOC(The highlight is mutually exclusive to the cursor. When the turn_on paramet
|
||||||
if (vptr != 0){
|
if (vptr != 0){
|
||||||
result = true;
|
result = true;
|
||||||
if (turn_on){
|
if (turn_on){
|
||||||
view_set_temp_highlight(system, vptr, start, end);
|
view_set_temp_highlight(system, vptr, (u32)start, (u32)end);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
vptr->file_data.show_temp_highlight = false;
|
vptr->file_data.show_temp_highlight = false;
|
||||||
|
|
210
4ed_buffer.cpp
210
4ed_buffer.cpp
|
@ -17,12 +17,12 @@
|
||||||
#include "4coder_helper/4coder_seek_types.h"
|
#include "4coder_helper/4coder_seek_types.h"
|
||||||
|
|
||||||
typedef struct Cursor_With_Index{
|
typedef struct Cursor_With_Index{
|
||||||
umem pos;
|
u32 pos;
|
||||||
i32 index;
|
i32 index;
|
||||||
} Cursor_With_Index;
|
} Cursor_With_Index;
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
write_cursor_with_index(Cursor_With_Index *positions, i32 *count, umem pos){
|
write_cursor_with_index(Cursor_With_Index *positions, u32 *count, u32 pos){
|
||||||
positions[(*count)].index = *count;
|
positions[(*count)].index = *count;
|
||||||
positions[(*count)].pos = pos;
|
positions[(*count)].pos = pos;
|
||||||
++(*count);
|
++(*count);
|
||||||
|
@ -33,7 +33,7 @@ write_cursor_with_index(Cursor_With_Index *positions, i32 *count, umem pos){
|
||||||
internal void
|
internal void
|
||||||
buffer_quick_sort_cursors(Cursor_With_Index *positions, i32 start, i32 pivot){
|
buffer_quick_sort_cursors(Cursor_With_Index *positions, i32 start, i32 pivot){
|
||||||
i32 mid = start;
|
i32 mid = start;
|
||||||
umem pivot_pos = positions[pivot].pos;
|
u32 pivot_pos = positions[pivot].pos;
|
||||||
for (i32 i = mid; i < pivot; ++i){
|
for (i32 i = mid; i < pivot; ++i){
|
||||||
if (positions[i].pos < pivot_pos){
|
if (positions[i].pos < pivot_pos){
|
||||||
CursorSwap__(positions[mid], positions[i]);
|
CursorSwap__(positions[mid], positions[i]);
|
||||||
|
@ -78,7 +78,7 @@ buffer_unsort_cursors(Cursor_With_Index *positions, i32 count){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
buffer_update_cursors(Cursor_With_Index *sorted_positions, i32 count, i32 start, i32 end, i32 len, b32 lean_right){
|
buffer_update_cursors(Cursor_With_Index *sorted_positions, u32 count, u32 start, u32 end, u32 len, b32 lean_right){
|
||||||
i32 shift_amount = (len - (end - start));
|
i32 shift_amount = (len - (end - start));
|
||||||
Cursor_With_Index *position = sorted_positions + count - 1;
|
Cursor_With_Index *position = sorted_positions + count - 1;
|
||||||
|
|
||||||
|
@ -121,8 +121,8 @@ buffer_batch_edit_max_shift(Buffer_Edit *sorted_edits, u32 edit_count){
|
||||||
Buffer_Edit *edit = sorted_edits;
|
Buffer_Edit *edit = sorted_edits;
|
||||||
i32 shift_total = 0, shift_max = 0;
|
i32 shift_total = 0, shift_max = 0;
|
||||||
for (u32 i = 0; i < edit_count; ++i, ++edit){
|
for (u32 i = 0; i < edit_count; ++i, ++edit){
|
||||||
umem target_length = edit->end - edit->start;
|
u32 target_length = (u32)(edit->end - edit->start);
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
shift_total += (i32)(edit_length - target_length);
|
shift_total += (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -138,7 +138,7 @@ buffer_batch_edit_max_shift(Buffer_Edit *sorted_edits, u32 edit_count){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal i32
|
internal i32
|
||||||
buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, i32 count, Buffer_Edit *sorted_edits, i32 edit_count, b32 lean_right){
|
buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, u32 count, Buffer_Edit *sorted_edits, u32 edit_count, b32 lean_right){
|
||||||
Cursor_With_Index *position = sorted_positions;
|
Cursor_With_Index *position = sorted_positions;
|
||||||
Cursor_With_Index *end_position = sorted_positions + count;
|
Cursor_With_Index *end_position = sorted_positions + count;
|
||||||
Buffer_Edit *edit = sorted_edits;
|
Buffer_Edit *edit = sorted_edits;
|
||||||
|
@ -147,20 +147,20 @@ buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, i32 count,
|
||||||
|
|
||||||
if (lean_right){
|
if (lean_right){
|
||||||
for (; edit < end_edit && position < end_position; ++edit){
|
for (; edit < end_edit && position < end_position; ++edit){
|
||||||
umem start = edit->start;
|
u32 start = (u32)edit->start;
|
||||||
umem end = edit->end;
|
u32 end = (u32)edit->end;
|
||||||
|
|
||||||
for (; position->pos < start && position < end_position; ++position){
|
for (; position->pos < start && position < end_position; ++position){
|
||||||
position->pos += shift_amount;
|
position->pos += shift_amount;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem new_end = start + edit->len + shift_amount;
|
u32 new_end = start + (u32)edit->len + shift_amount;
|
||||||
for (; position->pos <= end && position < end_position; ++position){
|
for (; position->pos <= end && position < end_position; ++position){
|
||||||
position->pos = new_end;
|
position->pos = new_end;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem target_length = end - start;
|
u32 target_length = end - start;
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
shift_amount += (i32)(edit_length - target_length);
|
shift_amount += (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -171,20 +171,20 @@ buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, i32 count,
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
for (; edit < end_edit && position < end_position; ++edit){
|
for (; edit < end_edit && position < end_position; ++edit){
|
||||||
umem start = edit->start;
|
u32 start = (u32)edit->start;
|
||||||
umem end = edit->end;
|
u32 end = (u32)edit->end;
|
||||||
|
|
||||||
for (; position->pos < start && position < end_position; ++position){
|
for (; position->pos < start && position < end_position; ++position){
|
||||||
position->pos += shift_amount;
|
position->pos += shift_amount;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem new_end = start + shift_amount;
|
u32 new_end = start + shift_amount;
|
||||||
for (; position->pos <= end && position < end_position; ++position){
|
for (; position->pos <= end && position < end_position; ++position){
|
||||||
position->pos = new_end;
|
position->pos = new_end;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem target_length = end - start;
|
u32 target_length = end - start;
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
shift_amount += (i32)(edit_length - target_length);
|
shift_amount += (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -199,8 +199,8 @@ buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, i32 count,
|
||||||
}
|
}
|
||||||
|
|
||||||
for (; edit < end_edit; ++edit){
|
for (; edit < end_edit; ++edit){
|
||||||
umem target_length = edit->end - edit->start;
|
u32 target_length = (u32)(edit->end - edit->start);
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
shift_amount += (i32)(edit_length - target_length);
|
shift_amount += (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -214,9 +214,9 @@ buffer_batch_edit_update_cursors(Cursor_With_Index *sorted_positions, i32 count,
|
||||||
|
|
||||||
//////////////////////////////////////
|
//////////////////////////////////////
|
||||||
|
|
||||||
internal umem
|
internal u32
|
||||||
eol_convert_in(char *dest, char *src, umem size){
|
eol_convert_in(char *dest, char *src, u32 size){
|
||||||
umem i = 0, j = 0, k = 0;
|
u32 i = 0, j = 0, k = 0;
|
||||||
|
|
||||||
for (; j < size && src[j] != '\r'; ++j);
|
for (; j < size && src[j] != '\r'; ++j);
|
||||||
memcpy(dest, src, j);
|
memcpy(dest, src, j);
|
||||||
|
@ -238,9 +238,9 @@ eol_convert_in(char *dest, char *src, umem size){
|
||||||
return(j);
|
return(j);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal umem
|
internal u32
|
||||||
eol_in_place_convert_in(char *data, umem size){
|
eol_in_place_convert_in(char *data, u32 size){
|
||||||
umem i = 0, j = 0, k = 0;
|
u32 i = 0, j = 0, k = 0;
|
||||||
|
|
||||||
for (; j < size && data[j] != '\r'; ++j);
|
for (; j < size && data[j] != '\r'; ++j);
|
||||||
|
|
||||||
|
@ -263,9 +263,9 @@ eol_in_place_convert_in(char *data, umem size){
|
||||||
|
|
||||||
// TODO(allen): iterative memory check?
|
// TODO(allen): iterative memory check?
|
||||||
internal b32
|
internal b32
|
||||||
eol_convert_out(char *dest, umem max, char *src, umem size, umem *size_out){
|
eol_convert_out(char *dest, u32 max, char *src, u32 size, u32 *size_out){
|
||||||
b32 result = true;
|
b32 result = true;
|
||||||
umem i = 0, j = 0;
|
u32 i = 0, j = 0;
|
||||||
|
|
||||||
for (; i < size; ++i, ++j){
|
for (; i < size; ++i, ++j){
|
||||||
if (src[i] == '\n'){
|
if (src[i] == '\n'){
|
||||||
|
@ -284,9 +284,9 @@ eol_convert_out(char *dest, umem max, char *src, umem size, umem *size_out){
|
||||||
|
|
||||||
// TODO(allen): iterative memory check?
|
// TODO(allen): iterative memory check?
|
||||||
internal b32
|
internal b32
|
||||||
eol_in_place_convert_out(char *data, umem size, umem max, umem *size_out){
|
eol_in_place_convert_out(char *data, u32 size, u32 max, u32 *size_out){
|
||||||
b32 result = true;
|
b32 result = true;
|
||||||
umem i = 0;
|
u32 i = 0;
|
||||||
|
|
||||||
for (; i < size; ++i){
|
for (; i < size; ++i){
|
||||||
if (data[i] == '\n'){
|
if (data[i] == '\n'){
|
||||||
|
@ -309,10 +309,10 @@ eol_in_place_convert_out(char *data, umem size, umem max, umem *size_out){
|
||||||
|
|
||||||
typedef struct Gap_Buffer{
|
typedef struct Gap_Buffer{
|
||||||
char *data;
|
char *data;
|
||||||
umem size1;
|
u32 size1;
|
||||||
umem gap_size;
|
u32 gap_size;
|
||||||
umem size2;
|
u32 size2;
|
||||||
umem max;
|
u32 max;
|
||||||
|
|
||||||
u32 *line_starts;
|
u32 *line_starts;
|
||||||
u32 line_count;
|
u32 line_count;
|
||||||
|
@ -325,22 +325,16 @@ buffer_good(Gap_Buffer *buffer){
|
||||||
return(good);
|
return(good);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline umem
|
|
||||||
buffer_size_umem(Gap_Buffer *buffer){
|
|
||||||
umem size = buffer->size1 + buffer->size2;
|
|
||||||
return(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline u32
|
inline u32
|
||||||
buffer_size(Gap_Buffer *buffer){
|
buffer_size(Gap_Buffer *buffer){
|
||||||
umem size = buffer->size1 + buffer->size2;
|
u32 size = buffer->size1 + buffer->size2;
|
||||||
return(u32)(size);
|
return(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct Gap_Buffer_Init{
|
typedef struct Gap_Buffer_Init{
|
||||||
Gap_Buffer *buffer;
|
Gap_Buffer *buffer;
|
||||||
char *data;
|
char *data;
|
||||||
umem size;
|
u32 size;
|
||||||
} Gap_Buffer_Init;
|
} Gap_Buffer_Init;
|
||||||
|
|
||||||
internal Gap_Buffer_Init
|
internal Gap_Buffer_Init
|
||||||
|
@ -361,29 +355,29 @@ buffer_init_need_more(Gap_Buffer_Init *init){
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal umem
|
internal u32
|
||||||
buffer_init_page_size(Gap_Buffer_Init *init){
|
buffer_init_page_size(Gap_Buffer_Init *init){
|
||||||
umem result = init->size * 2;
|
u32 result = init->size * 2;
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
buffer_init_provide_page(Gap_Buffer_Init *init, void *page, umem page_size){
|
buffer_init_provide_page(Gap_Buffer_Init *init, void *page, u32 page_size){
|
||||||
Gap_Buffer *buffer = init->buffer;
|
Gap_Buffer *buffer = init->buffer;
|
||||||
buffer->data = (char*)page;
|
buffer->data = (char*)page;
|
||||||
buffer->max = page_size;
|
buffer->max = page_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
buffer_end_init(Gap_Buffer_Init *init, void *scratch, umem scratch_size){
|
buffer_end_init(Gap_Buffer_Init *init, void *scratch, u32 scratch_size){
|
||||||
Gap_Buffer *buffer = init->buffer;
|
Gap_Buffer *buffer = init->buffer;
|
||||||
b32 result = false;
|
b32 result = false;
|
||||||
|
|
||||||
if (buffer->data && buffer->max >= init->size){
|
if (buffer->data && buffer->max >= init->size){
|
||||||
umem size = init->size;
|
u32 size = init->size;
|
||||||
umem size2 = size*2;
|
u32 size2 = size*2;
|
||||||
umem osize1 = size - size2;
|
u32 osize1 = size - size2;
|
||||||
umem size1 = osize1;
|
u32 size1 = osize1;
|
||||||
|
|
||||||
if (size1 > 0){
|
if (size1 > 0){
|
||||||
size1 = eol_convert_in(buffer->data, init->data, size1);
|
size1 = eol_convert_in(buffer->data, init->data, size1);
|
||||||
|
@ -406,8 +400,8 @@ buffer_end_init(Gap_Buffer_Init *init, void *scratch, umem scratch_size){
|
||||||
typedef struct Gap_Buffer_Stream{
|
typedef struct Gap_Buffer_Stream{
|
||||||
Gap_Buffer *buffer;
|
Gap_Buffer *buffer;
|
||||||
char *data;
|
char *data;
|
||||||
umem end;
|
u32 end;
|
||||||
umem absolute_end;
|
u32 absolute_end;
|
||||||
b32 separated;
|
b32 separated;
|
||||||
b32 use_termination_character;
|
b32 use_termination_character;
|
||||||
char terminator;
|
char terminator;
|
||||||
|
@ -415,7 +409,7 @@ typedef struct Gap_Buffer_Stream{
|
||||||
static Gap_Buffer_Stream null_buffer_stream = {0};
|
static Gap_Buffer_Stream null_buffer_stream = {0};
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
buffer_stringify_loop(Gap_Buffer_Stream *stream, Gap_Buffer *buffer, umem start, umem end){
|
buffer_stringify_loop(Gap_Buffer_Stream *stream, Gap_Buffer *buffer, u32 start, u32 end){
|
||||||
b32 result = false;
|
b32 result = false;
|
||||||
|
|
||||||
if (0 <= start && start < end && end <= buffer->size1 + buffer->size2){
|
if (0 <= start && start < end && end <= buffer->size1 + buffer->size2){
|
||||||
|
@ -488,7 +482,7 @@ buffer_stringify_next(Gap_Buffer_Stream *stream){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
buffer_replace_range(Gap_Buffer *buffer, u32 start, u32 end, char *str, u32 len, i32 *shift_amount, void *scratch, umem scratch_memory, umem *request_amount){
|
buffer_replace_range(Gap_Buffer *buffer, u32 start, u32 end, char *str, u32 len, i32 *shift_amount, void *scratch, u32 scratch_memory, u32 *request_amount){
|
||||||
char *data = buffer->data;
|
char *data = buffer->data;
|
||||||
u32 size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
b32 result = false;
|
b32 result = false;
|
||||||
|
@ -497,7 +491,7 @@ buffer_replace_range(Gap_Buffer *buffer, u32 start, u32 end, char *str, u32 len,
|
||||||
assert(start <= end);
|
assert(start <= end);
|
||||||
assert(end <= size);
|
assert(end <= size);
|
||||||
|
|
||||||
umem target_length = end - start;
|
u32 target_length = end - start;
|
||||||
|
|
||||||
if (target_length <= max_i32 && len <= max_i32){
|
if (target_length <= max_i32 && len <= max_i32){
|
||||||
if (len >= target_length){
|
if (len >= target_length){
|
||||||
|
@ -508,7 +502,7 @@ buffer_replace_range(Gap_Buffer *buffer, u32 start, u32 end, char *str, u32 len,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*shift_amount + size <= buffer->max){
|
if (*shift_amount + size <= buffer->max){
|
||||||
umem move_size = 0;
|
u32 move_size = 0;
|
||||||
if (end < buffer->size1){
|
if (end < buffer->size1){
|
||||||
move_size = buffer->size1 - end;
|
move_size = buffer->size1 - end;
|
||||||
memmove(data + buffer->size1 + buffer->gap_size - move_size, data + end, move_size);
|
memmove(data + buffer->size1 + buffer->gap_size - move_size, data + end, move_size);
|
||||||
|
@ -531,7 +525,7 @@ buffer_replace_range(Gap_Buffer *buffer, u32 start, u32 end, char *str, u32 len,
|
||||||
assert(buffer->size1 + buffer->gap_size + buffer->size2 == buffer->max);
|
assert(buffer->size1 + buffer->gap_size + buffer->size2 == buffer->max);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
*request_amount = l_round_up_umem(2*(*shift_amount + size), KB(4));
|
*request_amount = l_round_up_u32(2*(*shift_amount + size), KB(4));
|
||||||
result = true;
|
result = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -546,7 +540,7 @@ typedef struct Buffer_Batch_State{
|
||||||
|
|
||||||
// TODO(allen): Now that we are just using Gap_Buffer we could afford to improve this for the Gap_Buffer's behavior.
|
// TODO(allen): Now that we are just using Gap_Buffer we could afford to improve this for the Gap_Buffer's behavior.
|
||||||
internal b32
|
internal b32
|
||||||
buffer_batch_edit_step(Buffer_Batch_State *state, Gap_Buffer *buffer, Buffer_Edit *sorted_edits, char *strings, u32 edit_count, void *scratch, umem scratch_size, umem *request_amount){
|
buffer_batch_edit_step(Buffer_Batch_State *state, Gap_Buffer *buffer, Buffer_Edit *sorted_edits, char *strings, u32 edit_count, void *scratch, u32 scratch_size, u32 *request_amount){
|
||||||
Buffer_Edit *edit = 0;
|
Buffer_Edit *edit = 0;
|
||||||
u32 i = state->i;
|
u32 i = state->i;
|
||||||
i32 shift_total = state->shift_total;
|
i32 shift_total = state->shift_total;
|
||||||
|
@ -573,10 +567,10 @@ buffer_batch_edit_step(Buffer_Batch_State *state, Gap_Buffer *buffer, Buffer_Edi
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void*
|
internal void*
|
||||||
buffer_edit_provide_memory(Gap_Buffer *buffer, void *new_data, umem new_max){
|
buffer_edit_provide_memory(Gap_Buffer *buffer, void *new_data, u32 new_max){
|
||||||
void *result = buffer->data;
|
void *result = buffer->data;
|
||||||
umem size = buffer_size_umem(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
umem new_gap_size = new_max - size;
|
u32 new_gap_size = new_max - size;
|
||||||
|
|
||||||
assert(new_max >= size);
|
assert(new_max >= size);
|
||||||
|
|
||||||
|
@ -595,14 +589,14 @@ buffer_edit_provide_memory(Gap_Buffer *buffer, void *new_data, umem new_max){
|
||||||
//
|
//
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
buffer_stringify(Gap_Buffer *buffer, umem start, umem end, char *out){
|
buffer_stringify(Gap_Buffer *buffer, u32 start, u32 end, char *out){
|
||||||
Gap_Buffer_Stream stream = {0};
|
Gap_Buffer_Stream stream = {0};
|
||||||
|
|
||||||
umem i = start;
|
u32 i = start;
|
||||||
if (buffer_stringify_loop(&stream, buffer, i, end)){
|
if (buffer_stringify_loop(&stream, buffer, i, end)){
|
||||||
b32 still_looping = false;
|
b32 still_looping = false;
|
||||||
do{
|
do{
|
||||||
umem size = stream.end - i;
|
u32 size = stream.end - i;
|
||||||
memcpy(out, stream.data + i, size);
|
memcpy(out, stream.data + i, size);
|
||||||
i = stream.end;
|
i = stream.end;
|
||||||
out += size;
|
out += size;
|
||||||
|
@ -611,19 +605,19 @@ buffer_stringify(Gap_Buffer *buffer, umem start, umem end, char *out){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal umem
|
internal u32
|
||||||
buffer_convert_out(Gap_Buffer *buffer, char *dest, umem max){
|
buffer_convert_out(Gap_Buffer *buffer, char *dest, u32 max){
|
||||||
Gap_Buffer_Stream stream = {0};
|
Gap_Buffer_Stream stream = {0};
|
||||||
u32 size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
assert(size + buffer->line_count <= max);
|
assert(size + buffer->line_count <= max);
|
||||||
|
|
||||||
umem pos = 0;
|
u32 pos = 0;
|
||||||
if (buffer_stringify_loop(&stream, buffer, 0, size)){
|
if (buffer_stringify_loop(&stream, buffer, 0, size)){
|
||||||
umem i = 0;
|
u32 i = 0;
|
||||||
b32 still_looping = false;
|
b32 still_looping = false;
|
||||||
do{
|
do{
|
||||||
umem chunk_size = stream.end - i;
|
u32 chunk_size = stream.end - i;
|
||||||
umem out_size = 0;
|
u32 out_size = 0;
|
||||||
b32 result = eol_convert_out(dest + pos, max - pos, stream.data + i, chunk_size, &out_size);
|
b32 result = eol_convert_out(dest + pos, max - pos, stream.data + i, chunk_size, &out_size);
|
||||||
assert(result);
|
assert(result);
|
||||||
i = stream.end;
|
i = stream.end;
|
||||||
|
@ -734,8 +728,8 @@ buffer_measure_character_starts(System_Functions *system, Render_Font *font, Gap
|
||||||
stream.use_termination_character = 1;
|
stream.use_termination_character = 1;
|
||||||
stream.terminator = '\n';
|
stream.terminator = '\n';
|
||||||
|
|
||||||
umem size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
umem i = 0;
|
u32 i = 0;
|
||||||
if (buffer_stringify_loop(&stream, buffer, i, size)){
|
if (buffer_stringify_loop(&stream, buffer, i, size)){
|
||||||
b32 still_looping = false;
|
b32 still_looping = false;
|
||||||
do{
|
do{
|
||||||
|
@ -1132,8 +1126,8 @@ buffer_remeasure_character_starts(System_Functions *system, Render_Font *font, G
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
buffer_remeasure_wrap_y(Gap_Buffer *buffer, umem start_line, umem end_line, i32 line_shift, f32 *wraps, f32 font_height, f32 *adv, f32 max_width){
|
buffer_remeasure_wrap_y(Gap_Buffer *buffer, u32 start_line, u32 end_line, i32 line_shift, f32 *wraps, f32 font_height, f32 *adv, f32 max_width){
|
||||||
umem new_line_count = buffer->line_count;
|
u32 new_line_count = buffer->line_count;
|
||||||
|
|
||||||
assert(0 <= start_line);
|
assert(0 <= start_line);
|
||||||
assert(start_line <= end_line);
|
assert(start_line <= end_line);
|
||||||
|
@ -1142,8 +1136,8 @@ buffer_remeasure_wrap_y(Gap_Buffer *buffer, umem start_line, umem end_line, i32
|
||||||
++end_line;
|
++end_line;
|
||||||
|
|
||||||
// Shift
|
// Shift
|
||||||
umem line_count = new_line_count;
|
u32 line_count = new_line_count;
|
||||||
umem new_end_line = end_line;
|
u32 new_end_line = end_line;
|
||||||
if (line_shift != 0){
|
if (line_shift != 0){
|
||||||
line_count -= line_shift;
|
line_count -= line_shift;
|
||||||
new_end_line += line_shift;
|
new_end_line += line_shift;
|
||||||
|
@ -1153,9 +1147,9 @@ buffer_remeasure_wrap_y(Gap_Buffer *buffer, umem start_line, umem end_line, i32
|
||||||
|
|
||||||
// Iteration data (yikes! Need better loop system)
|
// Iteration data (yikes! Need better loop system)
|
||||||
Gap_Buffer_Stream stream = {0};
|
Gap_Buffer_Stream stream = {0};
|
||||||
umem size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
umem char_i = buffer->line_starts[start_line];
|
u32 char_i = buffer->line_starts[start_line];
|
||||||
umem line_i = start_line;
|
u32 line_i = start_line;
|
||||||
|
|
||||||
// Line wrap measurement
|
// Line wrap measurement
|
||||||
f32 last_wrap = wraps[line_i];
|
f32 last_wrap = wraps[line_i];
|
||||||
|
@ -1268,11 +1262,11 @@ buffer_get_line_index_from_wrapped_y(u32 *wrap_line_index, f32 y, i32 line_heigh
|
||||||
}
|
}
|
||||||
|
|
||||||
internal Partial_Cursor
|
internal Partial_Cursor
|
||||||
buffer_partial_from_pos(Gap_Buffer *buffer, umem pos){
|
buffer_partial_from_pos(Gap_Buffer *buffer, u32 pos){
|
||||||
Partial_Cursor result = {0};
|
Partial_Cursor result = {0};
|
||||||
|
|
||||||
u32 size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
pos = clamp_umem(0, pos, size);
|
pos = clamp_u32(0, pos, size);
|
||||||
|
|
||||||
u32 line_index = buffer_get_line_index_range(buffer, (u32)pos, 0, (u32)buffer->line_count);
|
u32 line_index = buffer_get_line_index_range(buffer, (u32)pos, 0, (u32)buffer->line_count);
|
||||||
result.pos = pos;
|
result.pos = pos;
|
||||||
|
@ -1283,10 +1277,10 @@ buffer_partial_from_pos(Gap_Buffer *buffer, umem pos){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal Partial_Cursor
|
internal Partial_Cursor
|
||||||
buffer_partial_from_line_character(Gap_Buffer *buffer, umem line, umem character, b32 reversed){
|
buffer_partial_from_line_character(Gap_Buffer *buffer, u32 line, u32 character, b32 reversed){
|
||||||
Partial_Cursor result = {0};
|
Partial_Cursor result = {0};
|
||||||
|
|
||||||
umem line_index = line - 1;
|
u32 line_index = line - 1;
|
||||||
if (line_index >= buffer->line_count){
|
if (line_index >= buffer->line_count){
|
||||||
line_index = buffer->line_count - 1;
|
line_index = buffer->line_count - 1;
|
||||||
}
|
}
|
||||||
|
@ -1294,16 +1288,16 @@ buffer_partial_from_line_character(Gap_Buffer *buffer, umem line, umem character
|
||||||
line_index = 0;
|
line_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem size = buffer_size(buffer);
|
u32 size = buffer_size(buffer);
|
||||||
|
|
||||||
umem this_start = buffer->line_starts[line_index];
|
u32 this_start = buffer->line_starts[line_index];
|
||||||
umem max_character = (size-this_start) + 1;
|
u32 max_character = (size-this_start) + 1;
|
||||||
if (line_index+1 < buffer->line_count){
|
if (line_index+1 < buffer->line_count){
|
||||||
umem next_start = buffer->line_starts[line_index+1];
|
u32 next_start = buffer->line_starts[line_index+1];
|
||||||
max_character = (next_start-this_start);
|
max_character = (next_start-this_start);
|
||||||
}
|
}
|
||||||
|
|
||||||
umem adjusted_pos = 0;
|
u32 adjusted_pos = 0;
|
||||||
if (character > 0){
|
if (character > 0){
|
||||||
if (reversed){
|
if (reversed){
|
||||||
if (character > max_character){
|
if (character > max_character){
|
||||||
|
@ -1437,7 +1431,7 @@ buffer_cursor_seek(Buffer_Cursor_Seek_State *S_ptr, Buffer_Cursor_Seek_Params pa
|
||||||
default: InvalidCodePath;
|
default: InvalidCodePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
umem safe_line_index = line_index;
|
u32 safe_line_index = line_index;
|
||||||
if (line_index >= params.buffer->line_count){
|
if (line_index >= params.buffer->line_count){
|
||||||
safe_line_index = params.buffer->line_count-1;
|
safe_line_index = params.buffer->line_count-1;
|
||||||
}
|
}
|
||||||
|
@ -1466,9 +1460,9 @@ buffer_cursor_seek(Buffer_Cursor_Seek_State *S_ptr, Buffer_Cursor_Seek_Params pa
|
||||||
S.next_cursor.unwrapped_x += line_shift;
|
S.next_cursor.unwrapped_x += line_shift;
|
||||||
S.next_cursor.wrapped_x += line_shift;
|
S.next_cursor.wrapped_x += line_shift;
|
||||||
|
|
||||||
S.stream.use_termination_character = 1;
|
S.stream.use_termination_character = true;
|
||||||
S.stream.terminator = '\n';
|
S.stream.terminator = '\n';
|
||||||
if (buffer_stringify_loop(&S.stream, params.buffer, S.next_cursor.pos, S.size)){
|
if (buffer_stringify_loop(&S.stream, params.buffer, (u32)S.next_cursor.pos, S.size)){
|
||||||
do{
|
do{
|
||||||
for (; S.next_cursor.pos < S.stream.end; ++S.next_cursor.pos){
|
for (; S.next_cursor.pos < S.stream.end; ++S.next_cursor.pos){
|
||||||
u8 ch = (u8)S.stream.data[S.next_cursor.pos];
|
u8 ch = (u8)S.stream.data[S.next_cursor.pos];
|
||||||
|
@ -1713,7 +1707,7 @@ buffer_invert_edit_shift(Gap_Buffer *buffer, Buffer_Edit edit, Buffer_Edit *inve
|
||||||
inverse->len = len;
|
inverse->len = len;
|
||||||
inverse->start = edit.start + shift_amount;
|
inverse->start = edit.start + shift_amount;
|
||||||
inverse->end = edit.start + edit.len + shift_amount;
|
inverse->end = edit.start + edit.len + shift_amount;
|
||||||
buffer_stringify(buffer, edit.start, edit.end, strings + pos);
|
buffer_stringify(buffer, (u32)edit.start, (u32)edit.end, strings + pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
|
@ -1722,7 +1716,7 @@ buffer_invert_edit(Gap_Buffer *buffer, Buffer_Edit edit, Buffer_Edit *inverse, c
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct Buffer_Invert_Batch{
|
typedef struct Buffer_Invert_Batch{
|
||||||
umem i;
|
u32 i;
|
||||||
i32 shift_amount;
|
i32 shift_amount;
|
||||||
u32 len;
|
u32 len;
|
||||||
} Buffer_Invert_Batch;
|
} Buffer_Invert_Batch;
|
||||||
|
@ -1730,7 +1724,7 @@ typedef struct Buffer_Invert_Batch{
|
||||||
internal b32
|
internal b32
|
||||||
buffer_invert_batch(Buffer_Invert_Batch *state, Gap_Buffer *buffer, Buffer_Edit *edits, u32 count, Buffer_Edit *inverse, char *strings, u32 *str_pos, u32 max){
|
buffer_invert_batch(Buffer_Invert_Batch *state, Gap_Buffer *buffer, Buffer_Edit *edits, u32 count, Buffer_Edit *inverse, char *strings, u32 *str_pos, u32 max){
|
||||||
i32 shift_amount = state->shift_amount;
|
i32 shift_amount = state->shift_amount;
|
||||||
umem i = state->i;
|
u32 i = state->i;
|
||||||
Buffer_Edit *edit = edits + i;
|
Buffer_Edit *edit = edits + i;
|
||||||
Buffer_Edit *inv_edit = inverse + i;
|
Buffer_Edit *inv_edit = inverse + i;
|
||||||
b32 result = false;
|
b32 result = false;
|
||||||
|
@ -1739,8 +1733,8 @@ buffer_invert_batch(Buffer_Invert_Batch *state, Gap_Buffer *buffer, Buffer_Edit
|
||||||
if (*str_pos + edit->end - edit->start <= max){
|
if (*str_pos + edit->end - edit->start <= max){
|
||||||
buffer_invert_edit_shift(buffer, *edit, inv_edit, strings, str_pos, max, shift_amount);
|
buffer_invert_edit_shift(buffer, *edit, inv_edit, strings, str_pos, max, shift_amount);
|
||||||
|
|
||||||
umem target_length = edit->end - edit->start;
|
u32 target_length = (u32)(edit->end - edit->start);
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
shift_amount += (i32)(edit_length - target_length);
|
shift_amount += (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -1766,7 +1760,7 @@ enum Buffer_Render_Flag{
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct Buffer_Render_Item{
|
typedef struct Buffer_Render_Item{
|
||||||
umem index;
|
u32 index;
|
||||||
u32 codepoint;
|
u32 codepoint;
|
||||||
u32 flags;
|
u32 flags;
|
||||||
f32 x0, y0;
|
f32 x0, y0;
|
||||||
|
@ -1784,7 +1778,7 @@ typedef struct Render_Item_Write{
|
||||||
} Render_Item_Write;
|
} Render_Item_Write;
|
||||||
|
|
||||||
inline Render_Item_Write
|
inline Render_Item_Write
|
||||||
write_render_item(Render_Item_Write write, umem index, u32 codepoint, u32 flags){
|
write_render_item(Render_Item_Write write, u32 index, u32 codepoint, u32 flags){
|
||||||
f32 ch_width = font_get_glyph_advance(write.system, write.font, codepoint);
|
f32 ch_width = font_get_glyph_advance(write.system, write.font, codepoint);
|
||||||
|
|
||||||
if (write.x <= write.x_max && write.x + ch_width >= write.x_min){
|
if (write.x <= write.x_max && write.x + ch_width >= write.x_min){
|
||||||
|
@ -1827,8 +1821,8 @@ struct Buffer_Render_Params{
|
||||||
struct Buffer_Render_State{
|
struct Buffer_Render_State{
|
||||||
Gap_Buffer_Stream stream;
|
Gap_Buffer_Stream stream;
|
||||||
b32 still_looping;
|
b32 still_looping;
|
||||||
umem i;
|
u32 i;
|
||||||
umem size;
|
u32 size;
|
||||||
|
|
||||||
f32 shift_x;
|
f32 shift_x;
|
||||||
f32 shift_y;
|
f32 shift_y;
|
||||||
|
@ -1838,9 +1832,9 @@ struct Buffer_Render_State{
|
||||||
Render_Item_Write write;
|
Render_Item_Write write;
|
||||||
f32 byte_advance;
|
f32 byte_advance;
|
||||||
|
|
||||||
umem line;
|
u32 line;
|
||||||
umem wrap_line;
|
u32 wrap_line;
|
||||||
umem wrap_unit_end;
|
u32 wrap_unit_end;
|
||||||
b32 skipping_whitespace;
|
b32 skipping_whitespace;
|
||||||
b32 first_of_the_line;
|
b32 first_of_the_line;
|
||||||
|
|
||||||
|
@ -1883,8 +1877,8 @@ buffer_render_data(Buffer_Render_State *S_ptr, Buffer_Render_Params params, f32
|
||||||
S.shift_y += params.start_cursor.unwrapped_y;
|
S.shift_y += params.start_cursor.unwrapped_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
S.line = params.start_cursor.line - 1;
|
S.line = (u32)params.start_cursor.line - 1;
|
||||||
S.wrap_line = params.start_cursor.wrap_line - 1;
|
S.wrap_line = (u32)params.start_cursor.wrap_line - 1;
|
||||||
|
|
||||||
if (params.virtual_white){
|
if (params.virtual_white){
|
||||||
S_stop.status = BLStatus_NeedLineShift;
|
S_stop.status = BLStatus_NeedLineShift;
|
||||||
|
@ -1909,7 +1903,7 @@ buffer_render_data(Buffer_Render_State *S_ptr, Buffer_Render_Params params, f32
|
||||||
}
|
}
|
||||||
|
|
||||||
S.first_of_the_line = 1;
|
S.first_of_the_line = 1;
|
||||||
S.i = params.start_cursor.pos;
|
S.i = (u32)params.start_cursor.pos;
|
||||||
if (buffer_stringify_loop(&S.stream, params.buffer, S.i, S.size)){
|
if (buffer_stringify_loop(&S.stream, params.buffer, S.i, S.size)){
|
||||||
do{
|
do{
|
||||||
for (; S.i < S.stream.end; ++S.i){
|
for (; S.i < S.stream.end; ++S.i){
|
||||||
|
@ -1995,7 +1989,7 @@ buffer_render_data(Buffer_Render_State *S_ptr, Buffer_Render_Params params, f32
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!S.skipping_whitespace){
|
if (!S.skipping_whitespace){
|
||||||
umem I = S.step.i;
|
u32 I = S.step.i;
|
||||||
switch (n){
|
switch (n){
|
||||||
case '\r':
|
case '\r':
|
||||||
{
|
{
|
||||||
|
@ -2023,7 +2017,7 @@ buffer_render_data(Buffer_Render_State *S_ptr, Buffer_Render_Params params, f32
|
||||||
}
|
}
|
||||||
else if (S.behavior.do_number_advance){
|
else if (S.behavior.do_number_advance){
|
||||||
u8 n = (u8)S.step.value;
|
u8 n = (u8)S.step.value;
|
||||||
umem I = S.step.i;
|
u32 I = S.step.i;
|
||||||
S.skipping_whitespace = false;
|
S.skipping_whitespace = false;
|
||||||
|
|
||||||
S.ch_width = S.byte_advance;
|
S.ch_width = S.byte_advance;
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
struct Buffer_Model_Step{
|
struct Buffer_Model_Step{
|
||||||
u32 type;
|
u32 type;
|
||||||
u32 value;
|
u32 value;
|
||||||
umem i;
|
u32 i;
|
||||||
u32 byte_length;
|
u32 byte_length;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
12
4ed_file.cpp
12
4ed_file.cpp
|
@ -21,7 +21,7 @@ enum Edit_Pos_Set_Type{
|
||||||
struct File_Edit_Positions{
|
struct File_Edit_Positions{
|
||||||
GUI_Scroll_Vars scroll;
|
GUI_Scroll_Vars scroll;
|
||||||
Full_Cursor cursor;
|
Full_Cursor cursor;
|
||||||
umem mark;
|
u32 mark;
|
||||||
f32 preferred_x;
|
f32 preferred_x;
|
||||||
i32 scroll_i;
|
i32 scroll_i;
|
||||||
i32 last_set_type;
|
i32 last_set_type;
|
||||||
|
@ -385,13 +385,13 @@ edit_pos_get_new(Editing_File *file, i32 index){
|
||||||
//
|
//
|
||||||
|
|
||||||
inline Partial_Cursor
|
inline Partial_Cursor
|
||||||
file_compute_cursor_from_pos(Editing_File *file, umem pos){
|
file_compute_cursor_from_pos(Editing_File *file, u32 pos){
|
||||||
Partial_Cursor result = buffer_partial_from_pos(&file->state.buffer, pos);
|
Partial_Cursor result = buffer_partial_from_pos(&file->state.buffer, pos);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Partial_Cursor
|
inline Partial_Cursor
|
||||||
file_compute_cursor_from_line_character(Editing_File *file, umem line, umem character, b32 reversed){
|
file_compute_cursor_from_line_character(Editing_File *file, u32 line, u32 character, b32 reversed){
|
||||||
Partial_Cursor result = buffer_partial_from_line_character(&file->state.buffer, line, character, reversed);
|
Partial_Cursor result = buffer_partial_from_line_character(&file->state.buffer, line, character, reversed);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
@ -402,17 +402,17 @@ file_compute_partial_cursor(Editing_File *file, Buffer_Seek seek, Partial_Cursor
|
||||||
switch (seek.type){
|
switch (seek.type){
|
||||||
case buffer_seek_pos:
|
case buffer_seek_pos:
|
||||||
{
|
{
|
||||||
*cursor = file_compute_cursor_from_pos(file, seek.pos);
|
*cursor = file_compute_cursor_from_pos(file, (u32)seek.pos);
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
case buffer_seek_line_char:
|
case buffer_seek_line_char:
|
||||||
{
|
{
|
||||||
*cursor = file_compute_cursor_from_line_character(file, seek.line, seek.character, true);
|
*cursor = file_compute_cursor_from_line_character(file, (u32)seek.line, (u32)seek.character, true);
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
case buffer_seek_line_reverse_char:
|
case buffer_seek_line_reverse_char:
|
||||||
{
|
{
|
||||||
*cursor = file_compute_cursor_from_line_character(file, seek.line, seek.character, false);
|
*cursor = file_compute_cursor_from_line_character(file, (u32)seek.line, (u32)seek.character, false);
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -146,7 +146,7 @@ struct File_Viewing_Data{
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
|
|
||||||
Full_Cursor temp_highlight;
|
Full_Cursor temp_highlight;
|
||||||
umem temp_highlight_end_pos;
|
u32 temp_highlight_end_pos;
|
||||||
b32 show_temp_highlight;
|
b32 show_temp_highlight;
|
||||||
|
|
||||||
b32 show_whitespace;
|
b32 show_whitespace;
|
||||||
|
@ -289,14 +289,14 @@ view_file_height(View *view){
|
||||||
return (result);
|
return (result);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline size_t
|
inline u32
|
||||||
view_get_cursor_pos(View *view){
|
view_get_cursor_pos(View *view){
|
||||||
size_t result = 0;
|
u32 result = 0;
|
||||||
if (view->file_data.show_temp_highlight){
|
if (view->file_data.show_temp_highlight){
|
||||||
result = view->file_data.temp_highlight.pos;
|
result = (u32)view->file_data.temp_highlight.pos;
|
||||||
}
|
}
|
||||||
else if (view->edit_pos){
|
else if (view->edit_pos){
|
||||||
result = view->edit_pos->cursor.pos;
|
result = (u32)view->edit_pos->cursor.pos;
|
||||||
}
|
}
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
@ -402,7 +402,7 @@ view_compute_cursor(System_Functions *system, View *view, Buffer_Seek seek, b32
|
||||||
Buffer_Cursor_Seek_State state = {0};
|
Buffer_Cursor_Seek_State state = {0};
|
||||||
Buffer_Layout_Stop stop = {0};
|
Buffer_Layout_Stop stop = {0};
|
||||||
|
|
||||||
umem size = buffer_size(params.buffer);
|
u32 size = buffer_size(params.buffer);
|
||||||
|
|
||||||
f32 line_shift = 0.f;
|
f32 line_shift = 0.f;
|
||||||
u32 wrap_unit_end = 0;
|
u32 wrap_unit_end = 0;
|
||||||
|
@ -619,7 +619,7 @@ view_set_cursor_and_scroll(View *view, Full_Cursor cursor, b32 set_preferred_x,
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
view_set_temp_highlight(System_Functions *system, View *view, umem pos, umem end_pos){
|
view_set_temp_highlight(System_Functions *system, View *view, u32 pos, u32 end_pos){
|
||||||
view->file_data.temp_highlight = view_compute_cursor(system, view, seek_pos(pos), 0);
|
view->file_data.temp_highlight = view_compute_cursor(system, view, seek_pos(pos), 0);
|
||||||
view->file_data.temp_highlight_end_pos = end_pos;
|
view->file_data.temp_highlight_end_pos = end_pos;
|
||||||
view->file_data.show_temp_highlight = 1;
|
view->file_data.show_temp_highlight = 1;
|
||||||
|
@ -741,7 +741,7 @@ save_file_to_name(System_Functions *system, Models *models, Editing_File *file,
|
||||||
models->hook_save_file(&models->app_links, file->id.id);
|
models->hook_save_file(&models->app_links, file->id.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
umem max = 0, size = 0;
|
u32 max = 0, size = 0;
|
||||||
b32 dos_write_mode = file->settings.dos_write_mode;
|
b32 dos_write_mode = file->settings.dos_write_mode;
|
||||||
Gap_Buffer *buffer = &file->state.buffer;
|
Gap_Buffer *buffer = &file->state.buffer;
|
||||||
|
|
||||||
|
@ -779,7 +779,7 @@ save_file_to_name(System_Functions *system, Models *models, Editing_File *file,
|
||||||
if (!using_actual_filename && file->canon.name.str != 0){
|
if (!using_actual_filename && file->canon.name.str != 0){
|
||||||
char space[512];
|
char space[512];
|
||||||
u32 length = str_size(filename);
|
u32 length = str_size(filename);
|
||||||
system->get_canonical(filename, length, space, sizeof(space));
|
system->get_canonical((u8*)filename, length, (u8*)space, sizeof(space));
|
||||||
|
|
||||||
char *source_path = file->canon.name.str;
|
char *source_path = file->canon.name.str;
|
||||||
if (match(space, source_path)){
|
if (match(space, source_path)){
|
||||||
|
@ -877,7 +877,7 @@ file_update_cursor_positions(System_Functions *system, Models *models, Editing_F
|
||||||
for (View_Iter iter = file_view_iter_init(layout, file, 0);
|
for (View_Iter iter = file_view_iter_init(layout, file, 0);
|
||||||
file_view_iter_good(iter);
|
file_view_iter_good(iter);
|
||||||
iter = file_view_iter_next(iter)){
|
iter = file_view_iter_next(iter)){
|
||||||
umem pos = view_get_cursor_pos(iter.view);
|
u32 pos = view_get_cursor_pos(iter.view);
|
||||||
|
|
||||||
if (!iter.view->file_data.show_temp_highlight){
|
if (!iter.view->file_data.show_temp_highlight){
|
||||||
Full_Cursor cursor = view_compute_cursor(system, iter.view, seek_pos(pos), 0);
|
Full_Cursor cursor = view_compute_cursor(system, iter.view, seek_pos(pos), 0);
|
||||||
|
@ -997,8 +997,8 @@ struct Code_Wrap_State{
|
||||||
b32 consume_newline;
|
b32 consume_newline;
|
||||||
|
|
||||||
Gap_Buffer_Stream stream;
|
Gap_Buffer_Stream stream;
|
||||||
umem size;
|
u32 size;
|
||||||
umem i;
|
u32 i;
|
||||||
|
|
||||||
Render_Font *font;
|
Render_Font *font;
|
||||||
f32 tab_indent_amount;
|
f32 tab_indent_amount;
|
||||||
|
@ -1052,8 +1052,8 @@ wrap_state_set_top(Code_Wrap_State *state, f32 line_shift){
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Code_Wrap_Step{
|
struct Code_Wrap_Step{
|
||||||
umem position_start;
|
u32 position_start;
|
||||||
umem position_end;
|
u32 position_end;
|
||||||
|
|
||||||
f32 start_x;
|
f32 start_x;
|
||||||
f32 final_x;
|
f32 final_x;
|
||||||
|
@ -1062,9 +1062,9 @@ struct Code_Wrap_Step{
|
||||||
};
|
};
|
||||||
|
|
||||||
internal Code_Wrap_Step
|
internal Code_Wrap_Step
|
||||||
wrap_state_consume_token(System_Functions *system, Render_Font *font, Code_Wrap_State *state, i32 fixed_end_point){
|
wrap_state_consume_token(System_Functions *system, Render_Font *font, Code_Wrap_State *state, u32 fixed_end_point){
|
||||||
Code_Wrap_Step result = {0};
|
Code_Wrap_Step result = {0};
|
||||||
umem i = state->i;
|
u32 i = state->i;
|
||||||
|
|
||||||
result.position_start = i;
|
result.position_start = i;
|
||||||
|
|
||||||
|
@ -1102,9 +1102,9 @@ wrap_state_consume_token(System_Functions *system, Render_Font *font, Code_Wrap_
|
||||||
state->next_line_start = state->line_starts[state->line_index + 1];
|
state->next_line_start = state->line_starts[state->line_index + 1];
|
||||||
}
|
}
|
||||||
|
|
||||||
i32 line_start = state->line_starts[state->line_index];
|
u32 line_start = state->line_starts[state->line_index];
|
||||||
b32 still_looping = 0;
|
b32 still_looping = 0;
|
||||||
i32 end = state->token_ptr->start + state->token_ptr->size;
|
u32 end = state->token_ptr->start + state->token_ptr->size;
|
||||||
|
|
||||||
if (fixed_end_point >= 0 && end > fixed_end_point){
|
if (fixed_end_point >= 0 && end > fixed_end_point){
|
||||||
end = fixed_end_point;
|
end = fixed_end_point;
|
||||||
|
@ -1234,7 +1234,7 @@ struct Wrap_Indent_Pair{
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Potential_Wrap_Indent_Pair{
|
struct Potential_Wrap_Indent_Pair{
|
||||||
i32 wrap_position;
|
u32 wrap_position;
|
||||||
f32 line_shift;
|
f32 line_shift;
|
||||||
|
|
||||||
f32 wrap_x;
|
f32 wrap_x;
|
||||||
|
@ -1498,8 +1498,8 @@ file_measure_wraps(System_Functions *system, Models *models, Editing_File *file,
|
||||||
|
|
||||||
potential_marks = push_array(part, Potential_Wrap_Indent_Pair, floor32(width));
|
potential_marks = push_array(part, Potential_Wrap_Indent_Pair, floor32(width));
|
||||||
|
|
||||||
umem remaining = partition_remaining(part);
|
u32 remaining = (u32)partition_remaining(part);
|
||||||
umem pair_size = sizeof(Wrap_Indent_Pair);
|
u32 pair_size = sizeof(Wrap_Indent_Pair);
|
||||||
max_wrap_indent_mark = (i32)(remaining/pair_size);
|
max_wrap_indent_mark = (i32)(remaining/pair_size);
|
||||||
wrap_indent_marks = push_array(part, Wrap_Indent_Pair, max_wrap_indent_mark);
|
wrap_indent_marks = push_array(part, Wrap_Indent_Pair, max_wrap_indent_mark);
|
||||||
}
|
}
|
||||||
|
@ -1530,8 +1530,8 @@ file_measure_wraps(System_Functions *system, Models *models, Editing_File *file,
|
||||||
else{
|
else{
|
||||||
Gap_Buffer_Stream stream = {0};
|
Gap_Buffer_Stream stream = {0};
|
||||||
|
|
||||||
i32 word_stage = 0;
|
u32 word_stage = 0;
|
||||||
i32 i = stop.pos;
|
u32 i = stop.pos;
|
||||||
f32 x = stop.x;
|
f32 x = stop.x;
|
||||||
f32 self_x = 0;
|
f32 self_x = 0;
|
||||||
if (buffer_stringify_loop(&stream, params.buffer, i, size)){
|
if (buffer_stringify_loop(&stream, params.buffer, i, size)){
|
||||||
|
@ -1826,7 +1826,7 @@ file_measure_wraps(System_Functions *system, Models *models, Editing_File *file,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
i32 wrap_position = potential_marks[best_i].wrap_position;
|
u32 wrap_position = potential_marks[best_i].wrap_position;
|
||||||
f32 line_shift = potential_marks[best_i].line_shift;
|
f32 line_shift = potential_marks[best_i].line_shift;
|
||||||
b32 adjust_top_to_this = potential_marks[best_i].adjust_top_to_this;
|
b32 adjust_top_to_this = potential_marks[best_i].adjust_top_to_this;
|
||||||
wrap_indent_marks[real_count].wrap_position = wrap_position;
|
wrap_indent_marks[real_count].wrap_position = wrap_position;
|
||||||
|
@ -1931,8 +1931,8 @@ file_create_from_string(System_Functions *system, Models *models, Editing_File *
|
||||||
file->state = null_editing_file_state;
|
file->state = null_editing_file_state;
|
||||||
Gap_Buffer_Init init = buffer_begin_init(&file->state.buffer, val.str, val.size);
|
Gap_Buffer_Init init = buffer_begin_init(&file->state.buffer, val.str, val.size);
|
||||||
for (; buffer_init_need_more(&init); ){
|
for (; buffer_init_need_more(&init); ){
|
||||||
umem page_size = buffer_init_page_size(&init);
|
u32 page_size = buffer_init_page_size(&init);
|
||||||
page_size = l_round_up_umem(page_size, KB(4));
|
page_size = l_round_up_u32(page_size, KB(4));
|
||||||
if (page_size < KB(4)){
|
if (page_size < KB(4)){
|
||||||
page_size = KB(4);
|
page_size = KB(4);
|
||||||
}
|
}
|
||||||
|
@ -1940,7 +1940,7 @@ file_create_from_string(System_Functions *system, Models *models, Editing_File *
|
||||||
buffer_init_provide_page(&init, data, page_size);
|
buffer_init_provide_page(&init, data, page_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
umem scratch_size = partition_remaining(part);
|
u32 scratch_size = (u32)partition_remaining(part);
|
||||||
Assert(scratch_size > 0);
|
Assert(scratch_size > 0);
|
||||||
b32 init_success = buffer_end_init(&init, part->base + part->pos, scratch_size);
|
b32 init_success = buffer_end_init(&init, part->base + part->pos, scratch_size);
|
||||||
AllowLocal(init_success); Assert(init_success);
|
AllowLocal(init_success); Assert(init_success);
|
||||||
|
@ -2048,7 +2048,7 @@ Job_Callback_Sig(job_full_lex){
|
||||||
u32 text_size = buffer_size(buffer);
|
u32 text_size = buffer_size(buffer);
|
||||||
u32 aligned_buffer_size = (text_size + 3)&(~3);
|
u32 aligned_buffer_size = (text_size + 3)&(~3);
|
||||||
|
|
||||||
while (memory->size < (umem)aligned_buffer_size){
|
while (memory->size < aligned_buffer_size){
|
||||||
system->grow_thread_memory(memory);
|
system->grow_thread_memory(memory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2063,7 +2063,7 @@ Job_Callback_Sig(job_full_lex){
|
||||||
|
|
||||||
// TODO(allen): deduplicate this against relex
|
// TODO(allen): deduplicate this against relex
|
||||||
char *chunks[3];
|
char *chunks[3];
|
||||||
umem chunk_sizes[3];
|
u32 chunk_sizes[3];
|
||||||
|
|
||||||
chunks[0] = buffer->data;
|
chunks[0] = buffer->data;
|
||||||
chunk_sizes[0] = buffer->size1;
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
@ -2078,7 +2078,7 @@ Job_Callback_Sig(job_full_lex){
|
||||||
|
|
||||||
do{
|
do{
|
||||||
char *chunk = chunks[chunk_index];
|
char *chunk = chunks[chunk_index];
|
||||||
umem chunk_size = chunk_sizes[chunk_index];
|
u32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
i32 result =
|
i32 result =
|
||||||
cpp_lex_step(&lex, chunk, (i32)chunk_size, text_size, &tokens, 2048);
|
cpp_lex_step(&lex, chunk, (i32)chunk_size, text_size, &tokens, 2048);
|
||||||
|
@ -2192,7 +2192,7 @@ file_first_lex_serial(Mem_Options *mem, Editing_File *file){
|
||||||
Gap_Buffer *buffer = &file->state.buffer;
|
Gap_Buffer *buffer = &file->state.buffer;
|
||||||
i32 text_size = buffer_size(buffer);
|
i32 text_size = buffer_size(buffer);
|
||||||
|
|
||||||
umem mem_size = partition_remaining(part);
|
u32 mem_size = (u32)partition_remaining(part);
|
||||||
|
|
||||||
Cpp_Token_Array tokens;
|
Cpp_Token_Array tokens;
|
||||||
tokens.max_count = (u32)(mem_size / sizeof(Cpp_Token));
|
tokens.max_count = (u32)(mem_size / sizeof(Cpp_Token));
|
||||||
|
@ -2205,7 +2205,7 @@ file_first_lex_serial(Mem_Options *mem, Editing_File *file){
|
||||||
|
|
||||||
// TODO(allen): deduplicate this against relex
|
// TODO(allen): deduplicate this against relex
|
||||||
char *chunks[3];
|
char *chunks[3];
|
||||||
umem chunk_sizes[3];
|
u32 chunk_sizes[3];
|
||||||
|
|
||||||
chunks[0] = buffer->data;
|
chunks[0] = buffer->data;
|
||||||
chunk_sizes[0] = buffer->size1;
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
@ -2222,7 +2222,7 @@ file_first_lex_serial(Mem_Options *mem, Editing_File *file){
|
||||||
|
|
||||||
do{
|
do{
|
||||||
char *chunk = chunks[chunk_index];
|
char *chunk = chunks[chunk_index];
|
||||||
umem chunk_size = chunk_sizes[chunk_index];
|
u32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
i32 result = cpp_lex_step(&lex, chunk, (i32)chunk_size, text_size, &tokens, NO_OUT_LIMIT);
|
i32 result = cpp_lex_step(&lex, chunk, (i32)chunk_size, text_size, &tokens, NO_OUT_LIMIT);
|
||||||
|
|
||||||
|
@ -2313,7 +2313,7 @@ file_relex_parallel(System_Functions *system, Mem_Options *mem, Editing_File *fi
|
||||||
Cpp_Relex_Data state = cpp_relex_init(array, start_i, end_i, shift_amount);
|
Cpp_Relex_Data state = cpp_relex_init(array, start_i, end_i, shift_amount);
|
||||||
|
|
||||||
char *chunks[3];
|
char *chunks[3];
|
||||||
umem chunk_sizes[3];
|
u32 chunk_sizes[3];
|
||||||
|
|
||||||
chunks[0] = buffer->data;
|
chunks[0] = buffer->data;
|
||||||
chunk_sizes[0] = buffer->size1;
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
@ -2326,7 +2326,7 @@ file_relex_parallel(System_Functions *system, Mem_Options *mem, Editing_File *fi
|
||||||
|
|
||||||
i32 chunk_index = 0;
|
i32 chunk_index = 0;
|
||||||
char *chunk = chunks[chunk_index];
|
char *chunk = chunks[chunk_index];
|
||||||
umem chunk_size = chunk_sizes[chunk_index];
|
u32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
while (!cpp_relex_is_start_chunk(&state, chunk, (i32)chunk_size)){
|
while (!cpp_relex_is_start_chunk(&state, chunk, (i32)chunk_size)){
|
||||||
++chunk_index;
|
++chunk_index;
|
||||||
|
@ -2421,8 +2421,8 @@ file_relex_serial(Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i,
|
||||||
Gap_Buffer *buffer = &file->state.buffer;
|
Gap_Buffer *buffer = &file->state.buffer;
|
||||||
Cpp_Token_Array *array = &file->state.token_array;
|
Cpp_Token_Array *array = &file->state.token_array;
|
||||||
|
|
||||||
umem remaining = partition_remaining(part);
|
u32 remaining = (u32)partition_remaining(part);
|
||||||
umem token_size = sizeof(Cpp_Token);
|
u32 token_size = sizeof(Cpp_Token);
|
||||||
|
|
||||||
Temp_Memory temp = begin_temp_memory(part);
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
Cpp_Token_Array relex_array;
|
Cpp_Token_Array relex_array;
|
||||||
|
@ -2435,7 +2435,7 @@ file_relex_serial(Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i,
|
||||||
Cpp_Relex_Data state = cpp_relex_init(array, start_i, end_i, shift_amount);
|
Cpp_Relex_Data state = cpp_relex_init(array, start_i, end_i, shift_amount);
|
||||||
|
|
||||||
char *chunks[3];
|
char *chunks[3];
|
||||||
umem chunk_sizes[3];
|
u32 chunk_sizes[3];
|
||||||
|
|
||||||
chunks[0] = buffer->data;
|
chunks[0] = buffer->data;
|
||||||
chunk_sizes[0] = buffer->size1;
|
chunk_sizes[0] = buffer->size1;
|
||||||
|
@ -2446,9 +2446,9 @@ file_relex_serial(Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i,
|
||||||
chunks[2] = 0;
|
chunks[2] = 0;
|
||||||
chunk_sizes[2] = 0;
|
chunk_sizes[2] = 0;
|
||||||
|
|
||||||
umem chunk_index = 0;
|
u32 chunk_index = 0;
|
||||||
char *chunk = chunks[chunk_index];
|
char *chunk = chunks[chunk_index];
|
||||||
umem chunk_size = chunk_sizes[chunk_index];
|
u32 chunk_size = chunk_sizes[chunk_index];
|
||||||
|
|
||||||
while (!cpp_relex_is_start_chunk(&state, chunk, (i32)chunk_size)){
|
while (!cpp_relex_is_start_chunk(&state, chunk, (i32)chunk_size)){
|
||||||
++chunk_index;
|
++chunk_index;
|
||||||
|
@ -2488,7 +2488,7 @@ file_relex_serial(Mem_Options *mem, Editing_File *file, i32 start_i, i32 end_i,
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
undo_stack_grow_string(General_Memory *general, Edit_Stack *stack, umem extra_size){
|
undo_stack_grow_string(General_Memory *general, Edit_Stack *stack, u32 extra_size){
|
||||||
u32 old_max = stack->max;
|
u32 old_max = stack->max;
|
||||||
u8 *old_str = stack->strings;
|
u8 *old_str = stack->strings;
|
||||||
u32 new_max = old_max*2 + (u32)(extra_size);
|
u32 new_max = old_max*2 + (u32)(extra_size);
|
||||||
|
@ -2508,27 +2508,27 @@ undo_stack_grow_edits(General_Memory *general, Edit_Stack *stack){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
child_stack_grow_string(General_Memory *general, Small_Edit_Stack *stack, umem extra_size){
|
child_stack_grow_string(General_Memory *general, Small_Edit_Stack *stack, u32 extra_size){
|
||||||
umem old_max = stack->max;
|
u32 old_max = stack->max;
|
||||||
u8 *old_str = stack->strings;
|
u8 *old_str = stack->strings;
|
||||||
umem new_max = old_max*2 + extra_size;
|
u32 new_max = old_max*2 + extra_size;
|
||||||
u8 *new_str = (u8*)general_memory_reallocate(general, old_str, old_max, new_max);
|
u8 *new_str = (u8*)general_memory_reallocate(general, old_str, old_max, new_max);
|
||||||
stack->strings = new_str;
|
stack->strings = new_str;
|
||||||
stack->max = (u32)new_max;
|
stack->max = (u32)new_max;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
child_stack_grow_edits(General_Memory *general, Small_Edit_Stack *stack, umem amount){
|
child_stack_grow_edits(General_Memory *general, Small_Edit_Stack *stack, u32 amount){
|
||||||
umem old_max = stack->edit_max;
|
u32 old_max = stack->edit_max;
|
||||||
Buffer_Edit *old_eds = stack->edits;
|
Buffer_Edit *old_eds = stack->edits;
|
||||||
umem new_max = old_max*2 + amount;
|
u32 new_max = old_max*2 + amount;
|
||||||
Buffer_Edit *new_eds = (Buffer_Edit*)general_memory_reallocate(general, old_eds, old_max*sizeof(Buffer_Edit), new_max*sizeof(Buffer_Edit));
|
Buffer_Edit *new_eds = (Buffer_Edit*)general_memory_reallocate(general, old_eds, old_max*sizeof(Buffer_Edit), new_max*sizeof(Buffer_Edit));
|
||||||
stack->edits = new_eds;
|
stack->edits = new_eds;
|
||||||
stack->edit_max = (u32)new_max;
|
stack->edit_max = (u32)new_max;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal i32
|
internal i32
|
||||||
undo_children_push(General_Memory *general, Small_Edit_Stack *children, Buffer_Edit *edits, u32 edit_count, u8 *strings, umem string_size){
|
undo_children_push(General_Memory *general, Small_Edit_Stack *children, Buffer_Edit *edits, u32 edit_count, u8 *strings, u32 string_size){
|
||||||
i32 result = children->edit_count;
|
i32 result = children->edit_count;
|
||||||
if (children->edit_count + edit_count > children->edit_max){
|
if (children->edit_count + edit_count > children->edit_max){
|
||||||
child_stack_grow_edits(general, children, edit_count);
|
child_stack_grow_edits(general, children, edit_count);
|
||||||
|
@ -2570,7 +2570,7 @@ file_post_undo(General_Memory *general, Editing_File *file, Edit_Step step, b32
|
||||||
|
|
||||||
if (step.child_count == 0){
|
if (step.child_count == 0){
|
||||||
if (step.edit.end - step.edit.start + undo->size > undo->max){
|
if (step.edit.end - step.edit.start + undo->size > undo->max){
|
||||||
undo_stack_grow_string(general, undo, step.edit.end - step.edit.start);
|
undo_stack_grow_string(general, undo, (u32)(step.edit.end - step.edit.start));
|
||||||
}
|
}
|
||||||
|
|
||||||
Buffer_Edit inv;
|
Buffer_Edit inv;
|
||||||
|
@ -2639,7 +2639,7 @@ file_post_redo(General_Memory *general, Editing_File *file, Edit_Step step){
|
||||||
|
|
||||||
if (step.child_count == 0){
|
if (step.child_count == 0){
|
||||||
if (step.edit.end - step.edit.start + redo->size > redo->max){
|
if (step.edit.end - step.edit.start + redo->size > redo->max){
|
||||||
undo_stack_grow_string(general, redo, step.edit.end - step.edit.start);
|
undo_stack_grow_string(general, redo, (u32)(step.edit.end - step.edit.start));
|
||||||
}
|
}
|
||||||
|
|
||||||
Buffer_Edit inv;
|
Buffer_Edit inv;
|
||||||
|
@ -2707,7 +2707,7 @@ file_post_history(General_Memory *general, Editing_File *file, Edit_Step step, b
|
||||||
|
|
||||||
if (step.child_count == 0){
|
if (step.child_count == 0){
|
||||||
if (step.edit.end - step.edit.start + history->size > history->max){
|
if (step.edit.end - step.edit.start + history->size > history->max){
|
||||||
undo_stack_grow_string(general, history, step.edit.end - step.edit.start);
|
undo_stack_grow_string(general, history, (u32)(step.edit.end - step.edit.start));
|
||||||
}
|
}
|
||||||
|
|
||||||
Buffer_Edit inv;
|
Buffer_Edit inv;
|
||||||
|
@ -2780,7 +2780,7 @@ view_cursor_move(View *view, Full_Cursor cursor){
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
view_cursor_move(System_Functions *system, View *view, umem pos){
|
view_cursor_move(System_Functions *system, View *view, u32 pos){
|
||||||
Full_Cursor cursor = view_compute_cursor(system, view, seek_pos(pos), 0);
|
Full_Cursor cursor = view_compute_cursor(system, view, seek_pos(pos), 0);
|
||||||
view_cursor_move(view, cursor);
|
view_cursor_move(view, cursor);
|
||||||
}
|
}
|
||||||
|
@ -3106,8 +3106,8 @@ file_edit_cursor_fix(System_Functions *system, Models *models, Editing_File *fil
|
||||||
Cursor_With_Index *r_cursors = push_array(part, Cursor_With_Index, cursor_max);
|
Cursor_With_Index *r_cursors = push_array(part, Cursor_With_Index, cursor_max);
|
||||||
Assert(cursors != 0);
|
Assert(cursors != 0);
|
||||||
|
|
||||||
i32 cursor_count = 0;
|
u32 cursor_count = 0;
|
||||||
i32 r_cursor_count = 0;
|
u32 r_cursor_count = 0;
|
||||||
|
|
||||||
View *view = 0;
|
View *view = 0;
|
||||||
Panel *panel = 0, *used_panels = &layout->used_sentinel;
|
Panel *panel = 0, *used_panels = &layout->used_sentinel;
|
||||||
|
@ -3115,9 +3115,9 @@ file_edit_cursor_fix(System_Functions *system, Models *models, Editing_File *fil
|
||||||
view = panel->view;
|
view = panel->view;
|
||||||
if (view->file_data.file == file){
|
if (view->file_data.file == file){
|
||||||
Assert(view->edit_pos);
|
Assert(view->edit_pos);
|
||||||
write_cursor_with_index(cursors, &cursor_count, view->edit_pos->cursor.pos);
|
write_cursor_with_index(cursors, &cursor_count, (u32)view->edit_pos->cursor.pos);
|
||||||
write_cursor_with_index(cursors, &cursor_count, view->edit_pos->mark);
|
write_cursor_with_index(cursors, &cursor_count, (u32)view->edit_pos->mark);
|
||||||
write_cursor_with_index(cursors, &cursor_count, view->edit_pos->scroll_i);
|
write_cursor_with_index(cursors, &cursor_count, (u32)view->edit_pos->scroll_i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3128,10 +3128,10 @@ file_edit_cursor_fix(System_Functions *system, Models *models, Editing_File *fil
|
||||||
Marker *markers = &marker_it->marker_0;
|
Marker *markers = &marker_it->marker_0;
|
||||||
for (u32 i = 0; i < count; ++i){
|
for (u32 i = 0; i < count; ++i){
|
||||||
if (markers[i].lean_right){
|
if (markers[i].lean_right){
|
||||||
write_cursor_with_index(r_cursors, &r_cursor_count, markers[i].pos);
|
write_cursor_with_index(r_cursors, &r_cursor_count, (u32)markers[i].pos);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
write_cursor_with_index(cursors, &cursor_count, markers[i].pos);
|
write_cursor_with_index(cursors, &cursor_count, (u32)markers[i].pos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3157,7 +3157,7 @@ file_edit_cursor_fix(System_Functions *system, Models *models, Editing_File *fil
|
||||||
if (view->file_data.file == file){
|
if (view->file_data.file == file){
|
||||||
Assert(view->edit_pos);
|
Assert(view->edit_pos);
|
||||||
|
|
||||||
umem cursor_pos = cursors[cursor_count++].pos;
|
u32 cursor_pos = cursors[cursor_count++].pos;
|
||||||
Full_Cursor new_cursor = view_compute_cursor(system, view, seek_pos(cursor_pos), 0);
|
Full_Cursor new_cursor = view_compute_cursor(system, view, seek_pos(cursor_pos), 0);
|
||||||
|
|
||||||
GUI_Scroll_Vars scroll = view->edit_pos->scroll;
|
GUI_Scroll_Vars scroll = view->edit_pos->scroll;
|
||||||
|
@ -3223,10 +3223,10 @@ file_do_single_edit(System_Functions *system, Models *models, Editing_File *file
|
||||||
u32 end = (u32)spec.step.edit.end;
|
u32 end = (u32)spec.step.edit.end;
|
||||||
u32 str_len = (u32)spec.step.edit.len;
|
u32 str_len = (u32)spec.step.edit.len;
|
||||||
|
|
||||||
umem scratch_size = partition_remaining(part);
|
u32 scratch_size = (u32)partition_remaining(part);
|
||||||
|
|
||||||
Assert(scratch_size > 0);
|
Assert(scratch_size > 0);
|
||||||
umem request_amount = 0;
|
u32 request_amount = 0;
|
||||||
Assert(end <= buffer_size(&file->state.buffer));
|
Assert(end <= buffer_size(&file->state.buffer));
|
||||||
while (buffer_replace_range(&file->state.buffer, start, end, str, str_len, &shift_amount, part->base + part->pos, scratch_size, &request_amount)){
|
while (buffer_replace_range(&file->state.buffer, start, end, str, str_len, &shift_amount, part->base + part->pos, scratch_size, &request_amount)){
|
||||||
void *new_data = 0;
|
void *new_data = 0;
|
||||||
|
@ -3303,7 +3303,7 @@ file_do_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
|
|
||||||
u32 scratch_size = (u32)partition_remaining(part);
|
u32 scratch_size = (u32)partition_remaining(part);
|
||||||
Buffer_Batch_State state = {0};
|
Buffer_Batch_State state = {0};
|
||||||
umem request_amount = 0;
|
u32 request_amount = 0;
|
||||||
while (buffer_batch_edit_step(&state, &file->state.buffer, batch,
|
while (buffer_batch_edit_step(&state, &file->state.buffer, batch,
|
||||||
(char*)str_base, batch_size, part->base + part->pos,
|
(char*)str_base, batch_size, part->base + part->pos,
|
||||||
scratch_size, &request_amount)){
|
scratch_size, &request_amount)){
|
||||||
|
@ -3354,8 +3354,8 @@ file_do_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
for (; token < end_token; ++token){
|
for (; token < end_token; ++token){
|
||||||
original = *token;
|
original = *token;
|
||||||
for (; edit < end_edit && edit->start <= original.start; ++edit){
|
for (; edit < end_edit && edit->start <= original.start; ++edit){
|
||||||
umem target_length = edit->end - edit->start;
|
u32 target_length = (u32)(edit->end - edit->start);
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
local_shift = (i32)(edit_length - target_length);
|
local_shift = (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -3367,8 +3367,8 @@ file_do_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
token->start += shift_amount;
|
token->start += shift_amount;
|
||||||
local_shift = 0;
|
local_shift = 0;
|
||||||
for (; edit < end_edit && edit->start < original.start + original.size; ++edit){
|
for (; edit < end_edit && edit->start < original.start + original.size; ++edit){
|
||||||
umem target_length = edit->end - edit->start;
|
u32 target_length = (u32)(edit->end - edit->start);
|
||||||
umem edit_length = edit->len;
|
u32 edit_length = (u32)edit->len;
|
||||||
if (edit_length > target_length){
|
if (edit_length > target_length){
|
||||||
local_shift = (i32)(edit_length - target_length);
|
local_shift = (i32)(edit_length - target_length);
|
||||||
}
|
}
|
||||||
|
@ -3464,8 +3464,8 @@ apply_history_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
file_do_single_edit(system, models, file, spec, history_mode);
|
file_do_single_edit(system, models, file, spec, history_mode);
|
||||||
|
|
||||||
if (view){
|
if (view){
|
||||||
view_cursor_move(system, view, step.edit.start + step.edit.len);
|
view_cursor_move(system, view, (u32)(step.edit.start + step.edit.len));
|
||||||
view->edit_pos->mark = view->edit_pos->cursor.pos;
|
view->edit_pos->mark = (u32)view->edit_pos->cursor.pos;
|
||||||
|
|
||||||
Style *style = main_style(models);
|
Style *style = main_style(models);
|
||||||
view_post_paste_effect(view, 0.333f, (u32)step.edit.start, (u32)step.edit.len, style->main.undo_color);
|
view_post_paste_effect(view, 0.333f, (u32)step.edit.start, (u32)step.edit.len, style->main.undo_color);
|
||||||
|
@ -3594,15 +3594,15 @@ working_set_clipboard_roll_down(Working_Set *working){
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
clipboard_copy(System_Functions *system, General_Memory *general, Working_Set *working, Range range, Editing_File *file){
|
clipboard_copy(System_Functions *system, General_Memory *general, Working_Set *working, Range range, Editing_File *file){
|
||||||
umem size = range.end - range.start;
|
u32 size = (u32)(range.end - range.start);
|
||||||
String *dest = working_set_next_clipboard_string(general, working, (u32)size);
|
String *dest = working_set_next_clipboard_string(general, working, (u32)size);
|
||||||
buffer_stringify(&file->state.buffer, range.start, range.end, dest->str);
|
buffer_stringify(&file->state.buffer, (u32)range.start, (u32)range.end, dest->str);
|
||||||
dest->size = (i32)size;
|
dest->size = (i32)size;
|
||||||
system->post_clipboard(*dest);
|
system->post_clipboard(*dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal Edit_Spec
|
internal Edit_Spec
|
||||||
file_compute_edit(Mem_Options *mem, Editing_File *file, Buffer_Edit *edits, char *str_base, umem str_size, Buffer_Edit *inverse_array, char *inv_str, u32 inv_max, u32 edit_count, i32 batch_type){
|
file_compute_edit(Mem_Options *mem, Editing_File *file, Buffer_Edit *edits, char *str_base, u32 str_size, Buffer_Edit *inverse_array, char *inv_str, u32 inv_max, u32 edit_count, i32 batch_type){
|
||||||
General_Memory *general = &mem->general;
|
General_Memory *general = &mem->general;
|
||||||
|
|
||||||
u32 inv_str_pos = 0;
|
u32 inv_str_pos = 0;
|
||||||
|
@ -4260,7 +4260,7 @@ get_exhaustive_info(System_Functions *system, Working_Set *working_set, Exhausti
|
||||||
|
|
||||||
result.info = loop->infos + i;
|
result.info = loop->infos + i;
|
||||||
loop->full_path.size = loop->r;
|
loop->full_path.size = loop->r;
|
||||||
append_sc(&loop->full_path, result.info->filename);
|
append_sc(&loop->full_path, (char*)result.info->filename);
|
||||||
terminate_with_null(&loop->full_path);
|
terminate_with_null(&loop->full_path);
|
||||||
|
|
||||||
Editing_File *file = working_set_canon_contains(working_set, loop->full_path);
|
Editing_File *file = working_set_canon_contains(working_set, loop->full_path);
|
||||||
|
@ -4493,16 +4493,6 @@ show_gui_u64(GUI_Target *target, String *string, i32 indent_level, i32 h_align,
|
||||||
gui_do_text_field(target, *string, null_string);
|
gui_do_text_field(target, *string, null_string);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
|
||||||
show_gui_umem(GUI_Target *target, String *string, i32 indent_level, i32 h_align, char *message, umem x){
|
|
||||||
string->size = 0;
|
|
||||||
append_label(string, indent_level, message);
|
|
||||||
append_padding(string, '-', h_align);
|
|
||||||
append_s_char(string, ' ');
|
|
||||||
append_u64_to_str(string, x);
|
|
||||||
gui_do_text_field(target, *string, null_string);
|
|
||||||
}
|
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
show_gui_int_int(GUI_Target *target, String *string, i32 indent_level, i32 h_align, char *message, i32 x, i32 m){
|
show_gui_int_int(GUI_Target *target, String *string, i32 indent_level, i32 h_align, char *message, i32 x, i32 m){
|
||||||
string->size = 0;
|
string->size = 0;
|
||||||
|
@ -4556,9 +4546,9 @@ show_gui_scroll(GUI_Target *target, String *string,
|
||||||
internal void
|
internal void
|
||||||
show_gui_cursor(GUI_Target *target, String *string, i32 indent_level, i32 h_align, char *message,Full_Cursor cursor){
|
show_gui_cursor(GUI_Target *target, String *string, i32 indent_level, i32 h_align, char *message,Full_Cursor cursor){
|
||||||
show_gui_line (target, string, indent_level , 0, message, 0);
|
show_gui_line (target, string, indent_level , 0, message, 0);
|
||||||
show_gui_umem (target, string, indent_level+1, h_align, " pos ", cursor.pos);
|
show_gui_u64 (target, string, indent_level+1, h_align, " pos ", cursor.pos);
|
||||||
show_gui_umem (target, string, indent_level+1, h_align, " line ", cursor.line);
|
show_gui_u64 (target, string, indent_level+1, h_align, " line ", cursor.line);
|
||||||
show_gui_umem (target, string, indent_level+1, h_align, " column ", cursor.character);
|
show_gui_u64 (target, string, indent_level+1, h_align, " column ", cursor.character);
|
||||||
show_gui_float(target, string, indent_level+1, h_align, " unwrapped_x ", cursor.unwrapped_x);
|
show_gui_float(target, string, indent_level+1, h_align, " unwrapped_x ", cursor.unwrapped_x);
|
||||||
show_gui_float(target, string, indent_level+1, h_align, " unwrapped_y ", cursor.unwrapped_y);
|
show_gui_float(target, string, indent_level+1, h_align, " unwrapped_y ", cursor.unwrapped_y);
|
||||||
show_gui_float(target, string, indent_level+1, h_align, " wrapped_x ", cursor.wrapped_x);
|
show_gui_float(target, string, indent_level+1, h_align, " wrapped_x ", cursor.wrapped_x);
|
||||||
|
@ -4993,13 +4983,13 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
if (file_info.name_match){
|
if (file_info.name_match){
|
||||||
id.id[0] = (u64)(file_info.info);
|
id.id[0] = (u64)(file_info.info);
|
||||||
|
|
||||||
char *str = file_info.info->filename;
|
char *str = (char*)file_info.info->filename;
|
||||||
i32 len = file_info.info->filename_len;
|
i32 len = file_info.info->filename_len;
|
||||||
String filename = make_string_cap(str, len, len + 1);
|
String filename = make_string_cap(str, len, len + 1);
|
||||||
|
|
||||||
if (gui_do_file_option(target, id, filename, file_info.is_folder, file_info.message)){
|
if (gui_do_file_option(target, id, filename, file_info.is_folder, file_info.message)){
|
||||||
if (file_info.is_folder){
|
if (file_info.is_folder){
|
||||||
set_last_folder_sc(&hdir->string, file_info.info->filename, '/');
|
set_last_folder_sc(&hdir->string, (char*)file_info.info->filename, '/');
|
||||||
do_new_directory = 1;
|
do_new_directory = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5470,7 +5460,6 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
#define SHOW_GUI_INT(n, h, str, v) show_gui_int(target, &string, n, h, " " str " ", v)
|
#define SHOW_GUI_INT(n, h, str, v) show_gui_int(target, &string, n, h, " " str " ", v)
|
||||||
#define SHOW_GUI_INT_INT(n, h, str, v, m) show_gui_int_int(target, &string, n, h, " " str " ", v, m)
|
#define SHOW_GUI_INT_INT(n, h, str, v, m) show_gui_int_int(target, &string, n, h, " " str " ", v, m)
|
||||||
#define SHOW_GUI_U64(n, h, str, v) show_gui_u64(target, &string, n, h, " " str " ", v)
|
#define SHOW_GUI_U64(n, h, str, v) show_gui_u64(target, &string, n, h, " " str " ", v)
|
||||||
#define SHOW_GUI_UMEM(n, h, str, v) show_gui_umem(target, &string, n, h, " " str " ", v)
|
|
||||||
#define SHOW_GUI_ID(n, h, str, v) show_gui_id(target, &string, n, h, " " str, v)
|
#define SHOW_GUI_ID(n, h, str, v) show_gui_id(target, &string, n, h, " " str, v)
|
||||||
#define SHOW_GUI_FLOAT(n, h, str, v) show_gui_float(target, &string, n, h, " " str " ", v)
|
#define SHOW_GUI_FLOAT(n, h, str, v) show_gui_float(target, &string, n, h, " " str " ", v)
|
||||||
#define SHOW_GUI_BOOL(n, h, str, v) do { if (v) { show_gui_line(target, &string, n, h, " " str " ", "true"); }\
|
#define SHOW_GUI_BOOL(n, h, str, v) do { if (v) { show_gui_line(target, &string, n, h, " " str " ", "true"); }\
|
||||||
|
@ -5510,8 +5499,8 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
SHOW_GUI_LINE(1, "file data:");
|
SHOW_GUI_LINE(1, "file data:");
|
||||||
SHOW_GUI_BOOL(2, h_align, "has file", view_ptr->file_data.file);
|
SHOW_GUI_BOOL(2, h_align, "has file", view_ptr->file_data.file);
|
||||||
SHOW_GUI_BOOL(2, h_align, "show temp highlight", view_ptr->file_data.show_temp_highlight);
|
SHOW_GUI_BOOL(2, h_align, "show temp highlight", view_ptr->file_data.show_temp_highlight);
|
||||||
SHOW_GUI_UMEM(2, h_align, "start temp highlight", view_ptr->file_data.temp_highlight.pos);
|
SHOW_GUI_U64(2, h_align, "start temp highlight", view_ptr->file_data.temp_highlight.pos);
|
||||||
SHOW_GUI_UMEM(2, h_align, "end temp highlight", view_ptr->file_data.temp_highlight_end_pos);
|
SHOW_GUI_U64(2, h_align, "end temp highlight", view_ptr->file_data.temp_highlight_end_pos);
|
||||||
|
|
||||||
SHOW_GUI_BOOL(2, h_align, "show whitespace", view_ptr->file_data.show_whitespace);
|
SHOW_GUI_BOOL(2, h_align, "show whitespace", view_ptr->file_data.show_whitespace);
|
||||||
SHOW_GUI_BOOL(2, h_align, "locked", view_ptr->file_data.file_locked);
|
SHOW_GUI_BOOL(2, h_align, "locked", view_ptr->file_data.file_locked);
|
||||||
|
@ -5529,7 +5518,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
SHOW_GUI_BLANK (2);
|
SHOW_GUI_BLANK (2);
|
||||||
SHOW_GUI_CURSOR(2, h_align, "cursor:", edit_pos->cursor);
|
SHOW_GUI_CURSOR(2, h_align, "cursor:", edit_pos->cursor);
|
||||||
SHOW_GUI_BLANK (2);
|
SHOW_GUI_BLANK (2);
|
||||||
SHOW_GUI_UMEM (2, h_align, "mark", edit_pos->mark);
|
SHOW_GUI_U64 (2, h_align, "mark", edit_pos->mark);
|
||||||
SHOW_GUI_FLOAT (2, h_align, "preferred_x", edit_pos->preferred_x);
|
SHOW_GUI_FLOAT (2, h_align, "preferred_x", edit_pos->preferred_x);
|
||||||
SHOW_GUI_INT (2, h_align, "scroll_i", edit_pos->scroll_i);
|
SHOW_GUI_INT (2, h_align, "scroll_i", edit_pos->scroll_i);
|
||||||
}
|
}
|
||||||
|
@ -5927,9 +5916,9 @@ draw_file_loaded(System_Functions *system, View *view, i32_Rect rect, b32 is_act
|
||||||
|
|
||||||
f32 left_side_space = 0;
|
f32 left_side_space = 0;
|
||||||
|
|
||||||
umem remaining = partition_remaining(part);
|
u32 remaining = (u32)partition_remaining(part);
|
||||||
umem render_item_size = sizeof(Buffer_Render_Item);
|
u32 render_item_size = sizeof(Buffer_Render_Item);
|
||||||
u32 max = (u32)(remaining / render_item_size);
|
u32 max = remaining / render_item_size;
|
||||||
Buffer_Render_Item *items = push_array(part, Buffer_Render_Item, max);
|
Buffer_Render_Item *items = push_array(part, Buffer_Render_Item, max);
|
||||||
|
|
||||||
Font_ID font_id = file->settings.font_id;
|
Font_ID font_id = file->settings.font_id;
|
||||||
|
@ -6049,12 +6038,12 @@ draw_file_loaded(System_Functions *system, View *view, i32_Rect rect, b32 is_act
|
||||||
u32 mark_color = style->main.mark_color;
|
u32 mark_color = style->main.mark_color;
|
||||||
Buffer_Render_Item *item = items;
|
Buffer_Render_Item *item = items;
|
||||||
Buffer_Render_Item *item_end = item + count;
|
Buffer_Render_Item *item_end = item + count;
|
||||||
umem prev_ind = max_umem;
|
u32 prev_ind = max_u32;
|
||||||
u32 highlight_color = 0;
|
u32 highlight_color = 0;
|
||||||
u32 highlight_this_color = 0;
|
u32 highlight_this_color = 0;
|
||||||
|
|
||||||
for (; item < item_end; ++item){
|
for (; item < item_end; ++item){
|
||||||
umem ind = item->index;
|
u32 ind = item->index;
|
||||||
highlight_this_color = 0;
|
highlight_this_color = 0;
|
||||||
if (tokens_use && ind != prev_ind){
|
if (tokens_use && ind != prev_ind){
|
||||||
Cpp_Token current_token = token_array.tokens[token_i-1];
|
Cpp_Token current_token = token_array.tokens[token_i-1];
|
||||||
|
|
|
@ -34,7 +34,7 @@ hot_directory_quick_partition(File_Info *infos, i32 start, i32 pivot){
|
||||||
i32 comp = 0;
|
i32 comp = 0;
|
||||||
comp = p->folder - a->folder;
|
comp = p->folder - a->folder;
|
||||||
if (comp == 0){
|
if (comp == 0){
|
||||||
comp = compare_cc(a->filename, p->filename);
|
comp = compare_cc((char*)a->filename, (char*)p->filename);
|
||||||
}
|
}
|
||||||
if (comp < 0){
|
if (comp < 0){
|
||||||
Swap(File_Info, *a, infos[start]);
|
Swap(File_Info, *a, infos[start]);
|
||||||
|
|
|
@ -31,7 +31,7 @@ handle_equal(Plat_Handle a, Plat_Handle b){
|
||||||
#define Sys_Set_File_List_Sig(name) void name(File_List *file_list, char *directory, char *canon_directory_out, u32 *canon_directory_size_out, u32 canon_directory_max)
|
#define Sys_Set_File_List_Sig(name) void name(File_List *file_list, char *directory, char *canon_directory_out, u32 *canon_directory_size_out, u32 canon_directory_max)
|
||||||
typedef Sys_Set_File_List_Sig(System_Set_File_List);
|
typedef Sys_Set_File_List_Sig(System_Set_File_List);
|
||||||
|
|
||||||
#define Sys_Get_Canonical_Sig(name) u32 name(char *filename, u32 len, char *buffer, u32 max)
|
#define Sys_Get_Canonical_Sig(name) u32 name(u8 *src, u32 len, u8 *dst, u32 max)
|
||||||
typedef Sys_Get_Canonical_Sig(System_Get_Canonical);
|
typedef Sys_Get_Canonical_Sig(System_Get_Canonical);
|
||||||
|
|
||||||
// file load/save
|
// file load/save
|
||||||
|
@ -47,7 +47,7 @@ typedef Sys_Load_File_Sig(System_Load_File);
|
||||||
#define Sys_Load_Close_Sig(name) b32 name(Plat_Handle handle)
|
#define Sys_Load_Close_Sig(name) b32 name(Plat_Handle handle)
|
||||||
typedef Sys_Load_Close_Sig(System_Load_Close);
|
typedef Sys_Load_Close_Sig(System_Load_Close);
|
||||||
|
|
||||||
#define Sys_Save_File_Sig(name) b32 name(char *filename, char *buffer, umem size)
|
#define Sys_Save_File_Sig(name) b32 name(char *filename, char *buffer, u32 size)
|
||||||
typedef Sys_Save_File_Sig(System_Save_File);
|
typedef Sys_Save_File_Sig(System_Save_File);
|
||||||
|
|
||||||
// file changes
|
// file changes
|
||||||
|
@ -136,8 +136,8 @@ enum Thread_Group_ID{
|
||||||
|
|
||||||
struct Thread_Memory{
|
struct Thread_Memory{
|
||||||
void *data;
|
void *data;
|
||||||
i32 size;
|
u32 size;
|
||||||
i32 id;
|
u32 id;
|
||||||
};
|
};
|
||||||
inline Thread_Memory
|
inline Thread_Memory
|
||||||
thread_memory_zero(){
|
thread_memory_zero(){
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
|
|
||||||
struct Translation_State{
|
struct Translation_State{
|
||||||
u8 fill_buffer[4];
|
u8 fill_buffer[4];
|
||||||
umem fill_start_i;
|
u32 fill_start_i;
|
||||||
u8 fill_i;
|
u8 fill_i;
|
||||||
u8 fill_expected;
|
u8 fill_expected;
|
||||||
};
|
};
|
||||||
|
@ -47,7 +47,7 @@ struct Translation_Emits{
|
||||||
#define SINGLE_BYTE_ERROR_CLASS max_u8
|
#define SINGLE_BYTE_ERROR_CLASS max_u8
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
translating_consume_byte(Translation_State *tran, u8 ch, umem i, umem size, Translation_Byte_Description *desc_out){
|
translating_consume_byte(Translation_State *tran, u8 ch, u32 i, u32 size, Translation_Byte_Description *desc_out){
|
||||||
desc_out->byte_class = 0;
|
desc_out->byte_class = 0;
|
||||||
if ((ch >= ' ' && ch < 0x7F) || ch == '\t' || ch == '\n' || ch == '\r'){
|
if ((ch >= ' ' && ch < 0x7F) || ch == '\t' || ch == '\n' || ch == '\r'){
|
||||||
desc_out->byte_class = 1;
|
desc_out->byte_class = 1;
|
||||||
|
@ -146,7 +146,7 @@ translating_select_emit_rule_with_font(System_Functions *system, Render_Font *fo
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
translating_generate_emits(Translation_State *tran, Translation_Emit_Rule emit_rule, u8 ch, umem i, Translation_Emits *emits_out){
|
translating_generate_emits(Translation_State *tran, Translation_Emit_Rule emit_rule, u8 ch, u32 i, Translation_Emits *emits_out){
|
||||||
emits_out->step_count = 0;
|
emits_out->step_count = 0;
|
||||||
switch (emit_rule.emit_type){
|
switch (emit_rule.emit_type){
|
||||||
default: goto skip_all;
|
default: goto skip_all;
|
||||||
|
@ -199,7 +199,7 @@ translating_generate_emits(Translation_State *tran, Translation_Emit_Rule emit_r
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
translating_fully_process_byte(System_Functions *system, Render_Font *font, Translation_State *tran, u8 ch, umem i, umem size, Translation_Emits *emits_out){
|
translating_fully_process_byte(System_Functions *system, Render_Font *font, Translation_State *tran, u8 ch, u32 i, u32 size, Translation_Emits *emits_out){
|
||||||
Translation_Byte_Description description = {0};
|
Translation_Byte_Description description = {0};
|
||||||
translating_consume_byte(tran, ch, i, size, &description);
|
translating_consume_byte(tran, ch, i, size, &description);
|
||||||
Translation_Emit_Rule emit_rule = {0};
|
Translation_Emit_Rule emit_rule = {0};
|
||||||
|
|
|
@ -360,7 +360,7 @@ internal b32
|
||||||
get_canon_name(System_Functions *system, Editing_File_Canon_Name *canon_name, String filename){
|
get_canon_name(System_Functions *system, Editing_File_Canon_Name *canon_name, String filename){
|
||||||
canon_name->name = make_fixed_width_string(canon_name->name_);
|
canon_name->name = make_fixed_width_string(canon_name->name_);
|
||||||
|
|
||||||
canon_name->name.size = system->get_canonical(filename.str, filename.size, canon_name->name.str, canon_name->name.memory_size);
|
canon_name->name.size = system->get_canonical((u8*)filename.str, filename.size, (u8*)canon_name->name.str, canon_name->name.memory_size);
|
||||||
terminate_with_null(&canon_name->name);
|
terminate_with_null(&canon_name->name);
|
||||||
|
|
||||||
b32 result = (canon_name->name.size != 0);
|
b32 result = (canon_name->name.size != 0);
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
/*
|
|
||||||
Build target for the 'pens' project.
|
|
||||||
By Allen Webster
|
|
||||||
Created 09.01.2017 (dd.mm.yyyy)
|
|
||||||
*/
|
|
||||||
|
|
||||||
// TOP
|
|
||||||
|
|
||||||
struct Arena{
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
// BOTTOM
|
|
||||||
|
|
|
@ -1409,11 +1409,8 @@ get_bindings(void *data, int32_t size){
|
||||||
bind(context, 'k', MDFR_ALT, kill_rect);
|
bind(context, 'k', MDFR_ALT, kill_rect);
|
||||||
bind(context, ' ', MDFR_ALT | MDFR_CTRL, multi_line_edit);
|
bind(context, ' ', MDFR_ALT | MDFR_CTRL, multi_line_edit);
|
||||||
|
|
||||||
bind(context, key_page_up, MDFR_ALT, miblo_increment_time_stamp);
|
bind(context, key_page_up, MDFR_ALT, miblo_increment_basic);
|
||||||
bind(context, key_page_down, MDFR_ALT, miblo_decrement_time_stamp);
|
bind(context, key_page_down, MDFR_ALT, miblo_decrement_basic);
|
||||||
|
|
||||||
bind(context, key_home, MDFR_ALT, miblo_increment_time_stamp_minute);
|
|
||||||
bind(context, key_end, MDFR_ALT, miblo_decrement_time_stamp_minute);
|
|
||||||
|
|
||||||
end_map(context);
|
end_map(context);
|
||||||
|
|
||||||
|
|
220
win32_4ed.cpp
220
win32_4ed.cpp
|
@ -284,7 +284,7 @@ Sys_Memory_Free_Sig(system_memory_free){
|
||||||
}
|
}
|
||||||
|
|
||||||
#define Win32GetMemory(size) system_memory_allocate(size)
|
#define Win32GetMemory(size) system_memory_allocate(size)
|
||||||
#define Win32FreeMemory(ptr) system_memory_free(ptr)
|
#define Win32FreeMemory(ptr) system_memory_free(ptr, 0)
|
||||||
|
|
||||||
#define Win32ScratchPartition sysshared_scratch_partition
|
#define Win32ScratchPartition sysshared_scratch_partition
|
||||||
#define Win32ScratchPartitionGrow sysshared_partition_grow
|
#define Win32ScratchPartitionGrow sysshared_partition_grow
|
||||||
|
@ -721,14 +721,17 @@ Sys_File_Can_Be_Made_Sig(system_file_can_be_made){
|
||||||
|
|
||||||
Partition *scratch = &shared_vars.scratch;
|
Partition *scratch = &shared_vars.scratch;
|
||||||
Temp_Memory temp = begin_temp_memory(scratch);
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
umem len = str_size(filename);
|
u32 len = str_size(filename);
|
||||||
umem max = (len+1)*2;
|
u32 filename_16_max = (len+1)*2;
|
||||||
u16 *filename_16 = push_array(scratch, u16, max);
|
u16 *filename_16 = push_array(scratch, u16, filename_16_max);
|
||||||
|
|
||||||
b32 error = false;
|
b32 convert_error = false;
|
||||||
utf8_to_utf16_minimal_checking(filename_16, max, (u8*)filename, len, &error);
|
u32 filename_16_len = (u32)utf8_to_utf16_minimal_checking(filename_16, filename_16_max-1, (u8*)filename, len, &convert_error);
|
||||||
|
filename_16[filename_16_len] = 0;;
|
||||||
|
|
||||||
if (!error){
|
if (!convert_error){
|
||||||
|
filename_16[filename_16_len] = 0;
|
||||||
|
|
||||||
HANDLE file = CreateFile((LPCWSTR)filename_16, FILE_APPEND_DATA, 0, 0, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
HANDLE file = CreateFile((LPCWSTR)filename_16, FILE_APPEND_DATA, 0, 0, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
|
|
||||||
if (file != 0 && file != INVALID_HANDLE_VALUE){
|
if (file != 0 && file != INVALID_HANDLE_VALUE){
|
||||||
|
@ -813,13 +816,14 @@ Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
|
|
||||||
u32 required_size = character_count*2 + file_count * sizeof(File_Info);
|
u32 required_size = character_count*2 + file_count * sizeof(File_Info);
|
||||||
if (file_list->block_size < (i32)required_size){
|
if (file_list->block_size < (i32)required_size){
|
||||||
system_memory_free(file_list->block, 0);
|
Win32FreeMemory(file_list->block);
|
||||||
file_list->block = system_memory_allocate(required_size);
|
file_list->block = system_memory_allocate(required_size);
|
||||||
file_list->block_size = required_size;
|
file_list->block_size = required_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
umem remaining_size = required_size;
|
||||||
file_list->infos = (File_Info*)file_list->block;
|
file_list->infos = (File_Info*)file_list->block;
|
||||||
char *name = (char*)(file_list->infos + file_count);
|
u8 *name = (u8*)(file_list->infos + file_count);
|
||||||
if (file_list->block != 0){
|
if (file_list->block != 0){
|
||||||
search = FindFirstFile((LPWSTR)filename_16, &find_data);
|
search = FindFirstFile((LPWSTR)filename_16, &find_data);
|
||||||
|
|
||||||
|
@ -832,14 +836,15 @@ Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
info->folder = (find_data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0;
|
info->folder = (find_data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0;
|
||||||
info->filename = name;
|
info->filename = name;
|
||||||
|
|
||||||
//u32 length = copy_fast_unsafe_cc(name, find_data.cFileName);
|
|
||||||
u32 size = 0;
|
u32 size = 0;
|
||||||
for(;find_data.cFileName[size];++size);
|
for(;find_data.cFileName[size];++size);
|
||||||
umem length = utf16_to_utf8_minimal_checking(info->filename, remaining_size, file_data.cFileName, size, &convert_error);
|
umem length = utf16_to_utf8_minimal_checking(info->filename, remaining_size, (u16*)find_data.cFileName, size, &convert_error);
|
||||||
|
|
||||||
if (!convert_error){
|
if (!convert_error){
|
||||||
name += length;
|
name += length;
|
||||||
|
remaining_size += length;
|
||||||
|
|
||||||
info->filename_len = length;
|
info->filename_len = (u32)length;
|
||||||
*name++ = 0;
|
*name++ = 0;
|
||||||
String fname = make_string_cap(info->filename, info->filename_len, info->filename_len+1);
|
String fname = make_string_cap(info->filename, info->filename_len, info->filename_len+1);
|
||||||
replace_char(&fname, '\\', '/');
|
replace_char(&fname, '\\', '/');
|
||||||
|
@ -872,43 +877,54 @@ Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal u32
|
internal u32
|
||||||
win32_canonical_ascii_name(char *src, u32 len, char *dst, u32 max){
|
win32_canonical_name(u16 *src, u32 len, u16 *dst, u32 max){
|
||||||
u32 result = 0;
|
u32 result = 0;
|
||||||
|
|
||||||
char src_space[MAX_PATH + 32];
|
if (len >= 2 && ((src[0] >= 'a' && src[0] <= 'z') || (src[0] >= 'A' && src[0] <= 'Z')) && src[1] == ':'){
|
||||||
if (len < sizeof(src_space) && len >= 2 && ((src[0] >= 'a' && src[0] <= 'z') || (src[0] >= 'A' && src[0] <= 'Z')) && src[1] == ':'){
|
|
||||||
memcpy(src_space, src, len);
|
|
||||||
src_space[len] = 0;
|
|
||||||
|
|
||||||
HANDLE file = CreateFile(src_space, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
HANDLE file = CreateFile((LPWSTR)src, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
|
|
||||||
if (file != INVALID_HANDLE_VALUE){
|
if (file != INVALID_HANDLE_VALUE){
|
||||||
DWORD final_length = GetFinalPathNameByHandle(file, dst, max, 0);
|
DWORD final_length = GetFinalPathNameByHandle(file, (LPWSTR)dst, max, 0);
|
||||||
|
|
||||||
if (final_length < max && final_length >= 4){
|
if (final_length < max && final_length >= 4){
|
||||||
if (dst[final_length-1] == 0){
|
if (dst[final_length-1] == 0){
|
||||||
--final_length;
|
--final_length;
|
||||||
}
|
}
|
||||||
final_length -= 4;
|
final_length -= 4;
|
||||||
memmove(dst, dst+4, final_length);
|
memmove(dst, dst+4, final_length*sizeof(u16));
|
||||||
dst[final_length] = 0;
|
dst[final_length] = 0;
|
||||||
result = final_length;
|
result = (u32)final_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
CloseHandle(file);
|
CloseHandle(file);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
String src_str = make_string(src, len);
|
//String src_str = make_string(src, len);
|
||||||
String path_str = path_of_directory(src_str);
|
//String path_str = path_of_directory(src_str);
|
||||||
String front_str = front_of_directory(src_str);
|
//String front_str = front_of_directory(src_str);
|
||||||
|
|
||||||
memcpy(src_space, path_str.str, path_str.size);
|
Partition *scratch = &shared_vars.scratch;
|
||||||
src_space[path_str.size] = 0;
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
HANDLE dir = CreateFile(src_space, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, 0, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS | FILE_FLAG_OVERLAPPED, 0);
|
u16 *path_src = push_array(scratch, u16, len+1);
|
||||||
|
memcpy(path_src, src, len*sizeof(u16));
|
||||||
|
u32 path_end = len;
|
||||||
|
for (u32 j = len; j > 0; --j){
|
||||||
|
if (path_src[j] == '/' || path_src[j] == '\\'){
|
||||||
|
path_end = j+1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
path_src[path_end] = 0;
|
||||||
|
|
||||||
|
u32 front_size = len - path_end;
|
||||||
|
u16 *front_src = path_src + path_end;
|
||||||
|
|
||||||
|
HANDLE dir = CreateFile((LPWSTR)src, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, 0, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS | FILE_FLAG_OVERLAPPED, 0);
|
||||||
|
|
||||||
if (dir != INVALID_HANDLE_VALUE){
|
if (dir != INVALID_HANDLE_VALUE){
|
||||||
DWORD final_length = GetFinalPathNameByHandle(dir, dst, max, 0);
|
DWORD final_length = GetFinalPathNameByHandle(dir, (LPWSTR)dst, max, 0);
|
||||||
|
|
||||||
if (final_length < max && final_length >= 4){
|
if (final_length < max && final_length >= 4){
|
||||||
if (dst[final_length-1] == 0){
|
if (dst[final_length-1] == 0){
|
||||||
|
@ -917,15 +933,18 @@ win32_canonical_ascii_name(char *src, u32 len, char *dst, u32 max){
|
||||||
final_length -= 4;
|
final_length -= 4;
|
||||||
memmove(dst, dst+4, final_length);
|
memmove(dst, dst+4, final_length);
|
||||||
dst[final_length++] = '\\';
|
dst[final_length++] = '\\';
|
||||||
memcpy(dst + final_length, front_str.str, front_str.size);
|
memcpy(dst + final_length, front_src, front_size);
|
||||||
final_length += front_str.size;
|
final_length += front_size;
|
||||||
dst[final_length] = 0;
|
dst[final_length] = 0;
|
||||||
result = final_length;
|
result = (u32)final_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
CloseHandle(dir);
|
CloseHandle(dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return(result);
|
return(result);
|
||||||
|
@ -933,20 +952,57 @@ win32_canonical_ascii_name(char *src, u32 len, char *dst, u32 max){
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Get_Canonical_Sig(system_get_canonical){
|
Sys_Get_Canonical_Sig(system_get_canonical){
|
||||||
u32 result = win32_canonical_ascii_name(filename, len, buffer, max);
|
u32 result = 0;
|
||||||
|
|
||||||
|
Partition *scratch = &shared_vars.scratch;
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
|
u32 src_16_max = (len+1)*2;
|
||||||
|
u16 *src_16 = push_array(scratch, u16, src_16_max);
|
||||||
|
|
||||||
|
u32 dst_16_max = (max+1)*2;
|
||||||
|
u16 *dst_16 = push_array(scratch, u16, dst_16_max);
|
||||||
|
|
||||||
|
b32 convert_error = false;
|
||||||
|
u32 src_16_len = (u32)utf8_to_utf16_minimal_checking(src_16, src_16_max-1, src, len, &convert_error);
|
||||||
|
src_16[src_16_len] = 0;
|
||||||
|
|
||||||
|
if (!convert_error){
|
||||||
|
u32 dst_16_len = win32_canonical_name(src_16, src_16_len, dst_16, dst_16_max);
|
||||||
|
|
||||||
|
result = (u32)utf16_to_utf8_minimal_checking(dst, max-1, dst_16, dst_16_len, &convert_error);
|
||||||
|
if (!convert_error){
|
||||||
|
dst[result] = 0;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
result = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Load_Handle_Sig(system_load_handle){
|
Sys_Load_Handle_Sig(system_load_handle){
|
||||||
b32 result = 0;
|
b32 result = false;
|
||||||
HANDLE file = CreateFile(filename, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
|
||||||
|
|
||||||
|
Partition *scratch = &shared_vars.scratch;
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
|
u32 len = 0;
|
||||||
|
for (;filename[len];++len);
|
||||||
|
|
||||||
|
u32 filename_16_max = (len+1)*2;
|
||||||
|
u16 *filename_16 = push_array(scratch, u16, filename_16_max);
|
||||||
|
|
||||||
|
HANDLE file = CreateFile((LPWSTR)filename_16, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
if (file != INVALID_HANDLE_VALUE){
|
if (file != INVALID_HANDLE_VALUE){
|
||||||
*(HANDLE*)handle_out = file;
|
*(HANDLE*)handle_out = file;
|
||||||
result = 1;
|
result = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -983,36 +1039,52 @@ Sys_Load_File_Sig(system_load_file){
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Load_Close_Sig(system_load_close){
|
Sys_Load_Close_Sig(system_load_close){
|
||||||
b32 result = 0;
|
b32 result = false;
|
||||||
HANDLE file = *(HANDLE*)(&handle);
|
HANDLE file = *(HANDLE*)(&handle);
|
||||||
if (CloseHandle(file)){
|
if (CloseHandle(file)){
|
||||||
result = 1;
|
result = true;
|
||||||
}
|
}
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Save_File_Sig(system_save_file){
|
Sys_Save_File_Sig(system_save_file){
|
||||||
b32 result = 0;
|
b32 result = false;
|
||||||
HANDLE file = CreateFile(filename, GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
Partition *scratch = &shared_vars.scratch;
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
if (file != INVALID_HANDLE_VALUE){
|
u32 len = 0;
|
||||||
DWORD written_total = 0;
|
for (;filename[len];++len);
|
||||||
DWORD written_size = 0;
|
|
||||||
|
u32 filename_16_max = (len+1)*2;
|
||||||
|
u16 *filename_16 = push_array(scratch, u16, filename_16_max);
|
||||||
|
|
||||||
|
b32 convert_error = false;
|
||||||
|
u32 filename_16_len = (u32)utf8_to_utf16_minimal_checking(filename_16, filename_16_max-1, (u8*)filename, len, &convert_error);
|
||||||
|
|
||||||
|
if (!convert_error){
|
||||||
|
filename_16[filename_16_len] = 0;
|
||||||
|
|
||||||
result = 1;
|
HANDLE file = CreateFile((LPWSTR)filename_16, GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
|
if (file != INVALID_HANDLE_VALUE){
|
||||||
while (written_total < size){
|
DWORD written_total = 0;
|
||||||
if (!WriteFile(file, buffer + written_total, size - written_total, &written_size, 0)){
|
DWORD written_size = 0;
|
||||||
result = 0;
|
|
||||||
break;
|
result = true;
|
||||||
|
|
||||||
|
while (written_total < size){
|
||||||
|
if (!WriteFile(file, buffer + written_total, size - written_total, &written_size, 0)){
|
||||||
|
result = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
written_total += written_size;
|
||||||
}
|
}
|
||||||
written_total += written_size;
|
|
||||||
|
CloseHandle(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
CloseHandle(file);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1023,21 +1095,54 @@ Sys_Now_Time_Sig(system_now_time){
|
||||||
}
|
}
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
Win32DirectoryExists(char *path){
|
Win32DirectoryExists(u8 *path){
|
||||||
DWORD attrib = GetFileAttributes(path);
|
b32 result = false;
|
||||||
return (attrib != INVALID_FILE_ATTRIBUTES && (attrib & FILE_ATTRIBUTE_DIRECTORY));
|
Partition *scratch = &shared_vars.scratch;
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
|
u32 len = 0;
|
||||||
|
for(;path[len];++len);
|
||||||
|
|
||||||
|
u32 path_16_max = (len+1)*2;
|
||||||
|
u16 *path_16 = push_array(scratch, u16, path_16_max);
|
||||||
|
|
||||||
|
b32 convert_error = false;
|
||||||
|
u32 path_16_len = (u32)utf8_to_utf16_minimal_checking(path_16, path_16_max-1, path, len, &convert_error);
|
||||||
|
|
||||||
|
if (!convert_error){
|
||||||
|
path_16[path_16_len] = 0;
|
||||||
|
|
||||||
|
DWORD attrib = GetFileAttributes((LPWSTR)path_16);
|
||||||
|
result = (attrib != INVALID_FILE_ATTRIBUTES && (attrib & FILE_ATTRIBUTE_DIRECTORY));
|
||||||
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Get_Binary_Path_Sig(system_get_binary_path){
|
Sys_Get_Binary_Path_Sig(system_get_binary_path){
|
||||||
i32 result = 0;
|
i32 result = 0;
|
||||||
i32 size = GetModuleFileName(0, out->str, out->memory_size);
|
|
||||||
if (size < out->memory_size-1){
|
Partition *scratch = &shared_vars.scratch;
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
|
u32 filename_16_max = (out->memory_size+1)*2;
|
||||||
|
u16 *filename_16 = push_array(scratch, u16, filename_16_max);
|
||||||
|
|
||||||
|
u32 length_16 = GetModuleFileName(0, (LPWSTR)filename_16, filename_16_max);
|
||||||
|
|
||||||
|
b32 convert_error = false;
|
||||||
|
u32 size = (u32)utf16_to_utf8_minimal_checking((u8*)out->str, out->memory_size-1, filename_16, length_16, &convert_error);
|
||||||
|
|
||||||
|
if (!convert_error){
|
||||||
out->size = size;
|
out->size = size;
|
||||||
remove_last_folder(out);
|
remove_last_folder(out);
|
||||||
terminate_with_null(out);
|
terminate_with_null(out);
|
||||||
result = out->size;
|
result = out->size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1053,8 +1158,7 @@ Sys_File_Exists_Sig(system_file_exists){
|
||||||
copy_ss(&full_filename, make_string(filename, len));
|
copy_ss(&full_filename, make_string(filename, len));
|
||||||
terminate_with_null(&full_filename);
|
terminate_with_null(&full_filename);
|
||||||
|
|
||||||
file = CreateFile(full_filename.str, GENERIC_READ, 0, 0,
|
file = CreateFile(full_filename.str, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
|
|
||||||
|
|
||||||
if (file != INVALID_HANDLE_VALUE){
|
if (file != INVALID_HANDLE_VALUE){
|
||||||
CloseHandle(file);
|
CloseHandle(file);
|
||||||
|
|
Loading…
Reference in New Issue