progress on the site baking system; stream lined build.bat
parent
87003907a7
commit
987eeb06ec
37
4coder_mem.h
37
4coder_mem.h
|
@ -8,7 +8,8 @@
|
|||
|
||||
struct Partition{
|
||||
char *base;
|
||||
int32_t pos, max;
|
||||
int32_t pos;
|
||||
int32_t max;
|
||||
};
|
||||
|
||||
struct Temp_Memory{
|
||||
|
@ -16,6 +17,12 @@ struct Temp_Memory{
|
|||
int32_t pos;
|
||||
};
|
||||
|
||||
struct Tail_Temp_Partition{
|
||||
Partition part;
|
||||
void *handle;
|
||||
int32_t old_max;
|
||||
};
|
||||
|
||||
inline Partition
|
||||
make_part(void *memory, int32_t size){
|
||||
Partition partition;
|
||||
|
@ -43,12 +50,12 @@ partition_align(Partition *data, uint32_t boundary){
|
|||
|
||||
inline void*
|
||||
partition_current(Partition *data){
|
||||
return data->base + data->pos;
|
||||
return(data->base + data->pos);
|
||||
}
|
||||
|
||||
inline int32_t
|
||||
partition_remaining(Partition *data){
|
||||
return data->max - data->pos;
|
||||
return(data->max - data->pos);
|
||||
}
|
||||
|
||||
inline Partition
|
||||
|
@ -58,7 +65,7 @@ partition_sub_part(Partition *data, int32_t size){
|
|||
if (d){
|
||||
result = make_part(d, size);
|
||||
}
|
||||
return result;
|
||||
return(result);
|
||||
}
|
||||
|
||||
#define push_struct(part, T) (T*)partition_allocate(part, sizeof(T))
|
||||
|
@ -70,7 +77,7 @@ begin_temp_memory(Partition *data){
|
|||
Temp_Memory result;
|
||||
result.handle = data;
|
||||
result.pos = data->pos;
|
||||
return result;
|
||||
return(result);
|
||||
}
|
||||
|
||||
inline void
|
||||
|
@ -78,6 +85,26 @@ end_temp_memory(Temp_Memory temp){
|
|||
((Partition*)temp.handle)->pos = temp.pos;
|
||||
}
|
||||
|
||||
inline Tail_Temp_Partition
|
||||
begin_tail_part(Partition *data, int32_t size){
|
||||
Tail_Temp_Partition result = {0};
|
||||
if (data->pos + size <= data->max){
|
||||
result.handle = data;
|
||||
result.old_max = data->max;
|
||||
data->max -= size;
|
||||
result.part = make_part(data->base + data->max, size);
|
||||
}
|
||||
return(result);
|
||||
}
|
||||
|
||||
inline void
|
||||
end_tail_part(Tail_Temp_Partition temp){
|
||||
if (temp.handle){
|
||||
Partition *part = (Partition*)temp.handle;
|
||||
part->max = temp.old_max;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
NOTE(allen):
|
||||
This is a very week general purpose allocator system.
|
||||
|
|
17
TODO.txt
17
TODO.txt
|
@ -91,10 +91,6 @@
|
|||
|
||||
; BEFORE I SHIP
|
||||
;
|
||||
; [X] query buffer font info
|
||||
; [X] issues with drive letters
|
||||
; [X] ad hoc call for setting up/down keys for interactive screens
|
||||
; [X] miblo's various number editors
|
||||
; [] decent options for indentation rules for text & presentation
|
||||
;
|
||||
|
||||
|
@ -145,6 +141,14 @@
|
|||
; [X] use strange theme
|
||||
; [X] cuber's return to previous buffer idea
|
||||
; [X] find matches for current identifier
|
||||
; [X] query buffer font info
|
||||
; [X] issues with drive letters
|
||||
; [X] ad hoc call for setting up/down keys for interactive screens
|
||||
; [X] miblo's various number editors
|
||||
; [X] eliminate the need for the lexer state's spare array.
|
||||
; [X] fix buffer render item capacity issue
|
||||
; [X] tab to complete folder names in the new file dialogue
|
||||
; [X] API docs have duplicate ids?
|
||||
|
||||
; Token related upgrades
|
||||
; [X] tokens in the custom API
|
||||
|
@ -154,10 +158,6 @@
|
|||
; [X] inserting lines at end of block comment
|
||||
; [] switch to line classification system
|
||||
; [] more built in options for auto indenting
|
||||
;
|
||||
; [X] eliminate the need for the lexer state's spare array.
|
||||
; [X] fix buffer render item capacity issue
|
||||
; [X] tab to complete folder names in the new file dialogue
|
||||
|
||||
; Arbitrary wrap positions
|
||||
; [X] allow for arbitrary wrap positions independent of view width
|
||||
|
@ -196,7 +196,6 @@
|
|||
|
||||
; [] user file bar string
|
||||
; [] option to not open *messages* every startup
|
||||
; [] API docs have duplicate ids?
|
||||
; [] API docs as text file
|
||||
; [] read only files
|
||||
; [] option to hide hidden files
|
||||
|
|
17
build.cpp
17
build.cpp
|
@ -117,6 +117,7 @@ typedef union _LARGE_INTEGER {
|
|||
|
||||
extern "C"{
|
||||
DWORD WINAPI GetCurrentDirectoryA(_In_ DWORD nBufferLength, _Out_ LPTSTR lpBuffer);
|
||||
BOOL WINAPI SetCurrentDirectoryA(_In_ LPCTSTR lpPathName);
|
||||
|
||||
BOOL WINAPI QueryPerformanceCounter(_Out_ LARGE_INTEGER *lpPerformanceCount);
|
||||
|
||||
|
@ -130,10 +131,17 @@ DWORD WINAPI GetCurrentDirectoryA(_In_ DWORD nBufferLength, _Out_ LPTSTR lpBuf
|
|||
static uint64_t perf_frequency;
|
||||
|
||||
static Temp_Dir
|
||||
pushdir(char *dir){}
|
||||
pushdir(char *dir){
|
||||
Temp_Dir temp = {0};
|
||||
GetCurrentDirectoryA(sizeof(temp.dir), temp.dir);
|
||||
SetCurrentDirectoryA(dir);
|
||||
return(temp);
|
||||
}
|
||||
|
||||
static void
|
||||
popdir(Temp_Dir temp){}
|
||||
popdir(Temp_Dir temp){
|
||||
SetCurrentDirectoryA(temp.dir);
|
||||
}
|
||||
|
||||
static void
|
||||
init_time_system(){
|
||||
|
@ -923,7 +931,12 @@ static void
|
|||
site_build(char *cdir, uint32_t flags){
|
||||
{
|
||||
BEGIN_TIME_SECTION();
|
||||
// TODO(allen): Figure out how to do these strings the right way... fuck.
|
||||
#if defined(IS_WINDOWS)
|
||||
build(OPTS | SITE_INCLUDES | flags, cdir, "site\\sitegen.cpp", BUILD_SITE_DIR, "sitegen", 0);
|
||||
#else
|
||||
build(OPTS | SITE_INCLUDES | flags, cdir, "site/sitegen.cpp", BUILD_SITE_DIR, "sitegen", 0);
|
||||
#endif
|
||||
END_TIME_SECTION("build sitegen");
|
||||
}
|
||||
|
||||
|
|
|
@ -1,8 +1,6 @@
|
|||
@echo off
|
||||
|
||||
REM this is not really working... it's slowing down the build time
|
||||
REM IF NOT DEFINED clset (call "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" x64)
|
||||
REM SET clset=64
|
||||
IF NOT DEFINED LIB (call "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" x64)
|
||||
|
||||
SET SRC=%1
|
||||
if "%SRC%" == "" SET SRC=4coder_default_bindings.cpp
|
||||
|
|
|
@ -305,7 +305,7 @@ CUSTOM_COMMAND_SIG(cursor_to_surrounding_scope){
|
|||
|
||||
finished:;
|
||||
if (found_result){
|
||||
view_set_cursor(app, &view, seek_pos(result), 0);
|
||||
view_set_cursor(app, &view, seek_pos(result), 1);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Binary file not shown.
|
@ -91,10 +91,22 @@ static Document_Item null_document_item = {0};
|
|||
enum{
|
||||
ItemType_Document,
|
||||
ItemType_Image,
|
||||
ItemType_GenericFile,
|
||||
// never below this
|
||||
ItemType_COUNT,
|
||||
};
|
||||
|
||||
struct Basic_Node{
|
||||
Basic_Node *next;
|
||||
};
|
||||
|
||||
#define NodeGetData(node, T) ((T*) ((node)+1))
|
||||
|
||||
struct Basic_List{
|
||||
Basic_Node *head;
|
||||
Basic_Node *tail;
|
||||
};
|
||||
|
||||
struct Abstract_Item{
|
||||
int32_t item_type;
|
||||
char *name;
|
||||
|
@ -110,26 +122,21 @@ struct Abstract_Item{
|
|||
|
||||
// Image value members
|
||||
char *source_file;
|
||||
char *out_file;
|
||||
char *extension;
|
||||
float w_h_ratio;
|
||||
float h_w_ratio;
|
||||
Basic_List img_instantiations;
|
||||
};
|
||||
static Abstract_Item null_abstract_item = {0};
|
||||
|
||||
struct Basic_Node{
|
||||
Basic_Node *next;
|
||||
};
|
||||
|
||||
#define NodeGetData(node, T) ((T*) ((node)+1))
|
||||
|
||||
struct Basic_List{
|
||||
Basic_Node *head;
|
||||
Basic_Node *tail;
|
||||
struct Image_Instantiation{
|
||||
int32_t w, h;
|
||||
};
|
||||
|
||||
struct Document_System{
|
||||
Basic_List doc_list;
|
||||
Basic_List img_list;
|
||||
Basic_List file_list;
|
||||
Partition *part;
|
||||
};
|
||||
|
||||
|
@ -195,20 +202,42 @@ get_item_by_name(Basic_List list, char *name){
|
|||
return(result);
|
||||
}
|
||||
|
||||
static Image_Instantiation*
|
||||
get_image_instantiation(Basic_List list, int32_t w, int32_t h){
|
||||
Image_Instantiation *result = 0;
|
||||
|
||||
for (Basic_Node *node = list.head;
|
||||
node != 0;
|
||||
node = node->next){
|
||||
Image_Instantiation *instantiation = NodeGetData(node, Image_Instantiation);
|
||||
if (instantiation->w == w && instantiation->h == h){
|
||||
result = instantiation;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return(result);
|
||||
}
|
||||
|
||||
static Abstract_Item*
|
||||
create_item(Partition *part, Basic_List *list, char *name){
|
||||
int32_t is_new_name = 1;
|
||||
|
||||
Abstract_Item *lookup = get_item_by_name(*list, name);
|
||||
|
||||
Abstract_Item *result = 0;
|
||||
if (is_new_name){
|
||||
if (lookup == 0){
|
||||
result = (Abstract_Item*)push_item_on_list(part, list, sizeof(Abstract_Item));
|
||||
}
|
||||
|
||||
return(result);
|
||||
}
|
||||
|
||||
static void
|
||||
add_image_instantiation(Partition *part, Basic_List *list, int32_t w, int32_t h){
|
||||
Image_Instantiation *instantiation = (Image_Instantiation*)push_item_on_list(part, list, sizeof(Image_Instantiation));
|
||||
instantiation->w = w;
|
||||
instantiation->h = h;
|
||||
}
|
||||
|
||||
static void
|
||||
set_section_name(Partition *part, Document_Item *item, char *name, int32_t show_title){
|
||||
int32_t name_len = str_size(name);
|
||||
|
@ -241,27 +270,38 @@ begin_document_description(Abstract_Item *doc, Partition *part, char *title, int
|
|||
}
|
||||
|
||||
static Abstract_Item*
|
||||
add_image_description(Document_System *system, char *asset_directory, char *source_file, char *out_file, char *name){
|
||||
add_generic_file(Document_System *system, char *source_file, char *extension, char *name){
|
||||
Abstract_Item *item = create_item(system->part, &system->file_list, name);
|
||||
if (item){
|
||||
item->item_type = ItemType_GenericFile;
|
||||
item->extension = extension;
|
||||
item->source_file = source_file;
|
||||
item->name = name;
|
||||
}
|
||||
return(item);
|
||||
}
|
||||
|
||||
static Abstract_Item*
|
||||
add_image_description(Document_System *system, char *source_file, char *extension, char *name){
|
||||
Abstract_Item *item = create_item(system->part, &system->img_list, name);
|
||||
if (item){
|
||||
item->item_type = ItemType_Image;
|
||||
item->extension = extension;
|
||||
item->source_file = source_file;
|
||||
item->out_file = out_file;
|
||||
item->name = name;
|
||||
|
||||
char str[256];
|
||||
String s = make_fixed_width_string(str);
|
||||
append_sc(&s, asset_directory);
|
||||
append_sc(&s, "/");
|
||||
append_sc(&s, source_file);
|
||||
terminate_with_null(&s);
|
||||
|
||||
int32_t w = 0, h = 0, comp = 0;
|
||||
int32_t stbi_r = stbi_info(str, &w, &h, &comp);
|
||||
assert(stbi_r);
|
||||
int32_t stbi_r = stbi_info(source_file, &w, &h, &comp);
|
||||
if (!stbi_r){
|
||||
fprintf(stderr, "Did not find file %s\n", source_file);
|
||||
item->w_h_ratio = 1.f;
|
||||
item->h_w_ratio = 1.f;
|
||||
}
|
||||
else{
|
||||
item->w_h_ratio = ((float)w/(float)h);
|
||||
item->h_w_ratio = ((float)h/(float)w);
|
||||
}
|
||||
}
|
||||
return(item);
|
||||
}
|
||||
|
||||
|
@ -453,9 +493,17 @@ doc_get_link_string(Abstract_Item *doc, char *space, int32_t capacity){
|
|||
}
|
||||
|
||||
static int32_t
|
||||
img_get_link_string(Abstract_Item *img, char *space, int32_t capacity){
|
||||
img_get_link_string(Abstract_Item *img, char *space, int32_t capacity, int32_t w, int32_t h){
|
||||
String str = make_string_cap(space, 0, capacity);
|
||||
append_sc(&str, img->out_file);
|
||||
append_sc(&str, img->name);
|
||||
|
||||
append_sc(&str, "_");
|
||||
append_int_to_str(&str, w);
|
||||
append_sc(&str, "_");
|
||||
append_int_to_str(&str, h);
|
||||
|
||||
append_sc(&str, ".");
|
||||
append_sc(&str, img->extension);
|
||||
int32_t result = terminate_with_null(&str);
|
||||
return(result);
|
||||
}
|
||||
|
@ -477,7 +525,7 @@ append_section_number(String *out, Section_Counter *section_counter){
|
|||
}
|
||||
|
||||
static int32_t
|
||||
extract_command_body(String *out, String l, int32_t *i_in_out, int32_t *body_start_out, int32_t *body_end_out, String command_name){
|
||||
extract_command_body(String *out, String l, int32_t *i_in_out, int32_t *body_start_out, int32_t *body_end_out, String command_name, int32_t require_body){
|
||||
int32_t result = 0;
|
||||
|
||||
int32_t i = *i_in_out;
|
||||
|
@ -507,6 +555,7 @@ extract_command_body(String *out, String l, int32_t *i_in_out, int32_t *body_sta
|
|||
result = 1;
|
||||
}
|
||||
else{
|
||||
if (require_body){
|
||||
#define STR_START "<span style='color:#F00'>! Doc generator error: missing body for "
|
||||
#define STR_SLOW " !</span>"
|
||||
append_sc(out, STR_START);
|
||||
|
@ -516,6 +565,7 @@ extract_command_body(String *out, String l, int32_t *i_in_out, int32_t *body_sta
|
|||
|
||||
fprintf(stderr, "error: missing body for %.*s\n", command_name.size, command_name.str);
|
||||
}
|
||||
}
|
||||
|
||||
*i_in_out = i;
|
||||
*body_start_out = body_start;
|
||||
|
@ -559,7 +609,7 @@ html_render_section_header(String *out, String section_name, String section_id,
|
|||
#define HTML_WIDTH 800
|
||||
|
||||
static void
|
||||
write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_system, Section_Counter *section_counter){
|
||||
write_enriched_text_html(String *out, Partition *part, Enriched_Text *text, Document_System *doc_system, Section_Counter *section_counter){
|
||||
String source = text->source;
|
||||
|
||||
append_sc(out, "<div>");
|
||||
|
@ -609,6 +659,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
Cmd_BeginLink,
|
||||
Cmd_EndLink,
|
||||
Cmd_Image,
|
||||
Cmd_Video,
|
||||
// never below this
|
||||
Cmd_COUNT,
|
||||
};
|
||||
|
@ -629,6 +680,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
enriched_commands[Cmd_BeginLink] = make_lit_string("BEGIN_LINK");
|
||||
enriched_commands[Cmd_EndLink] = make_lit_string("END_LINK");
|
||||
enriched_commands[Cmd_Image] = make_lit_string("IMAGE");
|
||||
enriched_commands[Cmd_Video] = make_lit_string("VIDEO");
|
||||
|
||||
i = command_end;
|
||||
|
||||
|
@ -641,7 +693,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
case Cmd_BeginStyle:
|
||||
{
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string);
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
@ -660,7 +712,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
case Cmd_DocLink:
|
||||
{
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string);
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
@ -703,7 +755,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
{
|
||||
// TODO(allen): undo the duplication of this body extraction code.
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string);
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
@ -717,7 +769,7 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
case Cmd_BeginLink:
|
||||
{
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string);
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
@ -746,7 +798,6 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
append_ss(out, body_text);
|
||||
}
|
||||
append_sc(out, "'>");
|
||||
|
||||
}
|
||||
}break;
|
||||
|
||||
|
@ -757,19 +808,32 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
|
||||
case Cmd_Image:
|
||||
{
|
||||
// TODO(allen): generalize this
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string);
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
||||
int32_t pixel_height = 10;
|
||||
int32_t pixel_width = HTML_WIDTH / 4;
|
||||
int32_t pixel_width = HTML_WIDTH;
|
||||
|
||||
body_start = 0, body_end = 0;
|
||||
has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 0);
|
||||
if (has_body){
|
||||
String size_parameter = substr(l, body_start, body_end - body_start);
|
||||
if (match_part_sc(size_parameter, "width:")){
|
||||
String width_string = substr_tail(size_parameter, sizeof("width:")-1);
|
||||
if (str_is_int_s(width_string)){
|
||||
pixel_width = str_to_int_s(width_string);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Abstract_Item *img_lookup = 0;
|
||||
if (match_part_sc(body_text, "image:")){
|
||||
String img_name = substr_tail(body_text, sizeof("image:")-1);
|
||||
img_lookup = get_item_by_name(doc_system->img_list, img_name);
|
||||
Abstract_Item *img_lookup = get_item_by_name(doc_system->img_list, img_name);
|
||||
|
||||
if (img_lookup){
|
||||
pixel_height = CEIL32(pixel_width*img_lookup->h_w_ratio);
|
||||
|
@ -777,8 +841,9 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
append_sc(out, "<img src='");
|
||||
|
||||
char space[256];
|
||||
if (img_get_link_string(img_lookup, space, sizeof(space))){
|
||||
if (img_get_link_string(img_lookup, space, sizeof(space), pixel_width, pixel_height)){
|
||||
append_sc(out, space);
|
||||
add_image_instantiation(part, &img_lookup->img_instantiations, pixel_width, pixel_height);
|
||||
}
|
||||
else{
|
||||
NotImplemented;
|
||||
|
@ -793,6 +858,33 @@ write_enriched_text_html(String *out, Enriched_Text *text, Document_System *doc_
|
|||
}
|
||||
}
|
||||
}break;
|
||||
|
||||
case Cmd_Video:
|
||||
{
|
||||
// TODO(allen): generalize this
|
||||
int32_t body_start = 0, body_end = 0;
|
||||
int32_t has_body = extract_command_body(out, l, &i, &body_start, &body_end, command_string, 1);
|
||||
|
||||
int32_t pixel_width = HTML_WIDTH;
|
||||
int32_t pixel_height = (int32_t)(pixel_width * 0.5625);
|
||||
|
||||
if (has_body){
|
||||
String body_text = substr(l, body_start, body_end - body_start);
|
||||
body_text = skip_chop_whitespace(body_text);
|
||||
|
||||
if (match_part_sc(body_text, "youtube:")){
|
||||
String youtube_str = substr_tail(body_text, sizeof("youtube:")-1);
|
||||
|
||||
append_sc(out, "<iframe width='");
|
||||
append_int_to_str(out, pixel_width);
|
||||
append_sc(out, "' height='");
|
||||
append_int_to_str(out, pixel_height);
|
||||
append_sc(out, "' src='");
|
||||
append_ss(out, youtube_str);
|
||||
append_sc(out, "' allowfullscreen> </iframe>");
|
||||
}
|
||||
}
|
||||
}break;
|
||||
}
|
||||
}
|
||||
else{
|
||||
|
@ -1428,6 +1520,7 @@ doc_item_head_html(String *out, Partition *part, Document_System *doc_system, Us
|
|||
append_sc(out,
|
||||
"<html lang=\"en-US\">"
|
||||
"<head>"
|
||||
"<link rel='shortcut icon' type='image/x-icon' href='4coder_icon.ico' />"
|
||||
"<title>");
|
||||
|
||||
append_ss(out, item->section.name);
|
||||
|
@ -1505,7 +1598,7 @@ doc_item_head_html(String *out, Partition *part, Document_System *doc_system, Us
|
|||
|
||||
case Doc_Enriched_Text:
|
||||
{
|
||||
write_enriched_text_html(out, item->text.text, doc_system, section_counter);
|
||||
write_enriched_text_html(out, part, item->text.text, doc_system, section_counter);
|
||||
}break;
|
||||
|
||||
case Doc_Element_List:
|
||||
|
|
|
@ -69,18 +69,11 @@ make_out_string(int32_t x){
|
|||
}
|
||||
|
||||
static void
|
||||
do_file_copy(Partition *part, char *src_dir, char *src_file, char *dst_dir, char *dst_file){
|
||||
char src[256];
|
||||
do_file_copy(Partition *part, char *src_file, char *dst_dir, char *dst_file){
|
||||
char dst[256];
|
||||
String str = {0};
|
||||
int32_t success = 0;
|
||||
|
||||
str = make_fixed_width_string(src);
|
||||
append_sc(&str, src_dir);
|
||||
append_sc(&str, "/");
|
||||
append_sc(&str, src_file);
|
||||
terminate_with_null(&str);
|
||||
|
||||
str = make_fixed_width_string(dst);
|
||||
append_sc(&str, dst_dir);
|
||||
append_sc(&str, "/");
|
||||
|
@ -90,7 +83,7 @@ do_file_copy(Partition *part, char *src_dir, char *src_file, char *dst_dir, char
|
|||
Temp_Memory temp = begin_temp_memory(part);
|
||||
int32_t mem_size = partition_remaining(part);
|
||||
void *mem = push_block(part, mem_size);
|
||||
FILE *in = fopen(src, "rb");
|
||||
FILE *in = fopen(src_file, "rb");
|
||||
if (in){
|
||||
fseek(in, 0, SEEK_END);
|
||||
int32_t file_size = ftell(in);
|
||||
|
@ -111,7 +104,9 @@ do_file_copy(Partition *part, char *src_dir, char *src_file, char *dst_dir, char
|
|||
}
|
||||
end_temp_memory(temp);
|
||||
|
||||
assert(success);
|
||||
if (!success){
|
||||
fprintf(stderr, "Could not copy from %s to %s\n", src_file, dst);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
111
site/sitegen.cpp
111
site/sitegen.cpp
|
@ -11,6 +11,8 @@
|
|||
|
||||
#define STB_IMAGE_IMPLEMENTATION
|
||||
#include "stb_image.h"
|
||||
#define STB_IMAGE_RESIZE_IMPLEMENTATION
|
||||
#include "stb_image_resize.h"
|
||||
|
||||
#include "4coder_version.h"
|
||||
#define FSTRING_IMPLEMENTATION
|
||||
|
@ -125,9 +127,10 @@ assert_files_are_equal(char *directory, char *filename1, char *filename2){
|
|||
static void
|
||||
do_html_output(Document_System *doc_system, Partition *part, char *dst_directory, Abstract_Item *doc){
|
||||
// NOTE(allen): Output
|
||||
Temp_Memory temp = begin_temp_memory(part);
|
||||
int32_t out_size = 10 << 20;
|
||||
Tail_Temp_Partition temp = begin_tail_part(part, out_size);
|
||||
|
||||
String out = str_alloc(part, 10 << 20);
|
||||
String out = str_alloc(&temp.part, out_size);
|
||||
assert(out.str);
|
||||
Out_Context context = {0};
|
||||
set_context_directory(&context, dst_directory);
|
||||
|
@ -144,7 +147,7 @@ assert_files_are_equal(char *directory, char *filename1, char *filename2){
|
|||
}
|
||||
}
|
||||
|
||||
end_temp_memory(temp);
|
||||
end_tail_part(temp);
|
||||
}
|
||||
|
||||
static Abstract_Item*
|
||||
|
@ -319,6 +322,32 @@ assert_files_are_equal(char *directory, char *filename1, char *filename2){
|
|||
return(doc);
|
||||
}
|
||||
|
||||
static Abstract_Item*
|
||||
generate_tutorials(Document_System *doc_system, Partition *part, char *src_directory){
|
||||
Enriched_Text *roadmap = push_struct(part, Enriched_Text);
|
||||
*roadmap = load_enriched_text(part, src_directory, "tutorials.txt");
|
||||
|
||||
Abstract_Item *doc = begin_document_description(doc_system, "4coder Tutorials", "tutorials", 0);
|
||||
add_enriched_text(doc, roadmap);
|
||||
end_document_description(doc);
|
||||
|
||||
return(doc);
|
||||
}
|
||||
|
||||
static String
|
||||
push_string(Partition *part, int32_t size){
|
||||
String str = {0};
|
||||
str.memory_size = size;
|
||||
str.str = push_array(part, char, size);
|
||||
partition_align(part, 4);
|
||||
return(str);
|
||||
}
|
||||
|
||||
static void
|
||||
do_image_resize(Partition *part, char *src_file, char *dst_dir, char *dst_file, int32_t w, int32_t h){
|
||||
do_file_copy(part, src_file, dst_dir, dst_file);
|
||||
}
|
||||
|
||||
static void
|
||||
generate_site(char *code_directory, char *asset_directory, char *src_directory, char *dst_directory){
|
||||
int32_t size = (512 << 20);
|
||||
|
@ -327,22 +356,46 @@ generate_site(char *code_directory, char *asset_directory, char *src_directory,
|
|||
|
||||
Partition part_ = make_part(mem, size);
|
||||
Partition *part = &part_;
|
||||
String str;
|
||||
|
||||
Document_System doc_system = create_document_system(part);
|
||||
add_image_description(&doc_system, asset_directory, "4coder_green.png", "4coder_logo.png", "4coder_logo");
|
||||
|
||||
// TODO(allen): code compression here
|
||||
str = push_string(part, 256);
|
||||
append_sc(&str, asset_directory);
|
||||
append_sc(&str, "/4coder_logo_low_green.png");
|
||||
terminate_with_null(&str);
|
||||
add_image_description(&doc_system, str.str, "png", "4coder_logo");
|
||||
|
||||
str = push_string(part, 256);
|
||||
append_sc(&str, asset_directory);
|
||||
append_sc(&str, "/screen_1.png");
|
||||
terminate_with_null(&str);
|
||||
add_image_description(&doc_system, str.str, "png", "screen_1");
|
||||
|
||||
str = push_string(part, 256);
|
||||
append_sc(&str, asset_directory);
|
||||
append_sc(&str, "/screen_2.png");
|
||||
terminate_with_null(&str);
|
||||
add_image_description(&doc_system, str.str, "png", "screen_2");
|
||||
|
||||
str = push_string(part, 256);
|
||||
append_sc(&str, asset_directory);
|
||||
append_sc(&str, "/screen_3.png");
|
||||
terminate_with_null(&str);
|
||||
add_image_description(&doc_system, str.str, "png", "screen_3");
|
||||
|
||||
str = push_string(part, 256);
|
||||
append_sc(&str, asset_directory);
|
||||
append_sc(&str, "/4coder_icon.ico");
|
||||
terminate_with_null(&str);
|
||||
add_generic_file(&doc_system, str.str, "ico", "4coder_icon");
|
||||
|
||||
generate_homepage(&doc_system, part, src_directory);
|
||||
generate_4coder_docs(&doc_system, part, code_directory, src_directory);
|
||||
generate_feature_list(&doc_system, part, src_directory);
|
||||
generate_roadmap(&doc_system, part, src_directory);
|
||||
|
||||
for (Basic_Node *node = doc_system.img_list.head;
|
||||
node != 0;
|
||||
node = node->next){
|
||||
Abstract_Item *img = NodeGetData(node, Abstract_Item);
|
||||
assert(img->item_type == ItemType_Image);
|
||||
do_file_copy(part, asset_directory, img->source_file, dst_directory, img->out_file);
|
||||
}
|
||||
generate_tutorials(&doc_system, part, src_directory);
|
||||
|
||||
for (Basic_Node *node = doc_system.doc_list.head;
|
||||
node != 0;
|
||||
|
@ -351,6 +404,40 @@ generate_site(char *code_directory, char *asset_directory, char *src_directory,
|
|||
assert(doc->item_type == ItemType_Document);
|
||||
do_html_output(&doc_system, part, dst_directory, doc);
|
||||
}
|
||||
|
||||
for (Basic_Node *node = doc_system.file_list.head;
|
||||
node != 0;
|
||||
node = node->next){
|
||||
Abstract_Item *file = NodeGetData(node, Abstract_Item);
|
||||
assert(file->item_type == ItemType_GenericFile);
|
||||
|
||||
char space[256];
|
||||
String str = make_fixed_width_string(space);
|
||||
append_sc(&str, file->name);
|
||||
append_sc(&str, ".");
|
||||
append_sc(&str, file->extension);
|
||||
terminate_with_null(&str);
|
||||
|
||||
do_file_copy(part, file->source_file, dst_directory, space);
|
||||
}
|
||||
|
||||
for (Basic_Node *node = doc_system.img_list.head;
|
||||
node != 0;
|
||||
node = node->next){
|
||||
Abstract_Item *img = NodeGetData(node, Abstract_Item);
|
||||
assert(img->item_type == ItemType_Image);
|
||||
|
||||
for (Basic_Node *node = img->img_instantiations.head;
|
||||
node != 0;
|
||||
node = node->next){
|
||||
Image_Instantiation *inst = NodeGetData(node, Image_Instantiation);
|
||||
|
||||
char space[256];
|
||||
if (img_get_link_string(img, space, sizeof(space), inst->w, inst->h)){
|
||||
do_image_resize(part, img->source_file, dst_directory, space, inst->w, inst->h);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char **argv){
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
|
||||
\IMAGE{image:4coder_logo}
|
||||
\BEGIN_LINK{document:home}
|
||||
\IMAGE{image:4coder_logo}{width:200}
|
||||
\END_LINK
|
||||
|
||||
This page provides a list of 4coder features for anyone trying to determine whether 4coder is the right editor for them. If a feature is missing here you should check out the \BEGIN_LINK{document:roadmap} roadmap \END_LINK page to see what is coming in the future. If the feature you want is on neither, you should contact \BEGIN_STYLE{code} editor@4coder.net \END_STYLE. Some features that are already in 4coder might be missing from this list, if you want to be sure you should contact \BEGIN_STYLE{code} editor@4coder.net \END_STYLE.
|
||||
|
||||
|
@ -29,7 +31,6 @@ This page provides a list of 4coder features for anyone trying to determine whet
|
|||
\BEGIN_ITEM Easy key rebinding \END_ITEM
|
||||
\BEGIN_ITEM Create custom commands \END_ITEM
|
||||
\BEGIN_ITEM Buffer reading and editing \END_ITEM
|
||||
\BEGIN_ITEM Buffer reading and editing \END_ITEM
|
||||
\BEGIN_ITEM View opening, closing, positioning \END_ITEM
|
||||
\BEGIN_ITEM Access to the code intelligence engine \END_ITEM
|
||||
\END_LIST
|
||||
|
|
|
@ -1,14 +1,24 @@
|
|||
|
||||
\IMAGE{image:4coder_logo}
|
||||
\BEGIN_LINK{document:home}
|
||||
\IMAGE{image:4coder_logo}{width:200}
|
||||
\END_LINK
|
||||
|
||||
4coder is a code editor that first and foremost targets the needs C/C++ developers so that developers in that space can be as efficient as possible. Here you can learn about the features of 4coder, how to get started with 4coder, and how to get the absolute most out of 4cocer.
|
||||
4coder is a code editor that first and foremost targets the needs of C/C++ developers so they can be as efficient as possible. Here you can learn about the features of 4coder, how to get started with 4coder, and how to get the absolute most out of 4coder.
|
||||
|
||||
If you cannot find what you are looking for please contact \BEGIN_STYLE{code} editor@4coder.net \END_STYLE with questions.
|
||||
|
||||
\BEGIN_LINK{!http://patreon.com/mr4thdimention} Get an alpha build by supporting development \END_LINK
|
||||
|
||||
\BEGIN_LINK{document:features} The official 4coder feature list \END_LINK
|
||||
|
||||
\BEGIN_LINK{document:roadmap} The official 4coder road map \END_LINK
|
||||
|
||||
\BEGIN_LINK{document:custom_docs} The official documentation for the 4coder customization system \END_LINK
|
||||
|
||||
\BEGIN_LINK{document:tutorials} Using 4coder tutorials \END_LINK
|
||||
|
||||
\IMAGE{image:screen_1}
|
||||
|
||||
\IMAGE{image:screen_2}
|
||||
|
||||
\IMAGE{image:screen_3}
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
|
||||
\IMAGE{image:4coder_logo}
|
||||
\BEGIN_LINK{document:home}
|
||||
\IMAGE{image:4coder_logo}{width:200}
|
||||
\END_LINK
|
||||
|
||||
This page provides an outline of planned 4coder features roughly sorted by priority. If a feature is missing here it may be on the \BEGIN_LINK{document:features} features \END_LINK page which means it is already in 4coder. If a feature is missing from both lists and you would like to recommend it for consideration, send your recommendation to \BEGIN_STYLE{code} editor@4coder.net \END_STYLE. If you believe the priority sorting of the items should be tweaked because certain items are more important than others, that recommendation can also be sent to the same 4coder email as any other recommendation.
|
||||
|
||||
|
@ -8,28 +10,50 @@ Each section represents one major type of todo item, within each section the ite
|
|||
\SECTION{General Editing}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Unicode buffer formats \END_ITEM
|
||||
\BEGIN_ITEM Fix up the undo/redo system - improve efficiency and fix a few buggy details \END_ITEM
|
||||
\BEGIN_ITEM Properply handle files with read-only access \END_ITEM
|
||||
\BEGIN_ITEM Options for hiding or showing hidden files \END_ITEM
|
||||
\BEGIN_ITEM Change font size \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{Code Layout}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Reduce code "jumpieness" by adding brace/paren m atching rules and scoping rules \END_ITEM
|
||||
\BEGIN_ITEM Regain the ability to parse in parallel with a smarter background job system \END_ITEM
|
||||
\BEGIN_ITEM Add partial remeasurement systems to decrease the amount of CPU work put into layout \END_ITEM
|
||||
\BEGIN_ITEM Expand code layout to also virtualize trailing whitespace and newline characters \END_ITEM
|
||||
\BEGIN_ITEM Expand code layout to virtualize all whitespace \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{Buffer Driven GUI}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Labels \END_ITEM
|
||||
\BEGIN_ITEM Clickable buttons \END_ITEM
|
||||
\BEGIN_ITEM Arbitrary non-editable regions \END_ITEM
|
||||
\BEGIN_ITEM Tables \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{Code Intelligence}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Create a usable "in stream" preprocessor \END_ITEM
|
||||
\BEGIN_ITEM Create a usable "in stream" parser \END_ITEM
|
||||
\BEGIN_ITEM Preprocessor effect visualization \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{API "Main" Upgrade}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Expose undo/redo grouping so that edits can be treated as one undo/redo event \END_ITEM
|
||||
\BEGIN_ITEM Improve the control over the view/cursor positioning \END_ITEM
|
||||
\BEGIN_ITEM Generic control over rendering cursor, mark, and highlight regions \END_ITEM
|
||||
\BEGIN_ITEM Move the concept of the cursor and mark entirely onto the custom side \END_ITEM
|
||||
\BEGIN_ITEM Virtual text for ghosted word completion and in-line compiler errors \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{API Miscellanea}
|
||||
\BEGIN_LIST
|
||||
\BEGIN_ITEM Expose the file bar string \END_ITEM
|
||||
\BEGIN_ITEM Expose the binding of initial files to views such as *messages* \END_ITEM
|
||||
\BEGIN_ITEM Make command maps modifiable and allow them to be created and discarded at any time \END_ITEM
|
||||
\END_LIST
|
||||
|
||||
\SECTION{Cross OS Miscellanea}
|
||||
|
|
|
@ -0,0 +1,12 @@
|
|||
|
||||
\BEGIN_LINK{document:home}
|
||||
\IMAGE{image:4coder_logo}{width:200}
|
||||
\END_LINK
|
||||
|
||||
Getting started with 4coder and navigating your files:
|
||||
|
||||
\VIDEO{youtube:https://www.youtube.com/embed/h5cbOcnSrcc}
|
||||
|
||||
More tutorials coming soon.
|
||||
|
||||
|
Loading…
Reference in New Issue