Started the preprocessor situation *sigh*; fixed an issue with how I was handling UNC paths
parent
ed625f4e09
commit
6b7d09b9d5
|
@ -0,0 +1,11 @@
|
||||||
|
/*
|
||||||
|
4coder_cpp_preprocessor.cpp - An unoptimized non-in-place preprocessor.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// TOP
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// BOTTOM
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
/*
|
||||||
|
4coder_cpp_preprocessor.h - An unoptimized non-in-place preprocessor.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// TOP
|
||||||
|
|
||||||
|
#if !defined(FCODER_CPP_PREPROCESSOR_H)
|
||||||
|
#define FCODER_CPP_PREPROCESSOR_H
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// BOTTOM
|
||||||
|
|
||||||
|
|
|
@ -119,6 +119,20 @@ Sys_Memory_Free_Sig(system_memory_free){
|
||||||
// Files
|
// Files
|
||||||
//
|
//
|
||||||
|
|
||||||
|
internal String
|
||||||
|
win32_remove_unc_prefix_characters(String path){
|
||||||
|
if (match_part(path, make_lit_string("\\\\?\\UNC"))){
|
||||||
|
path.size -= 6;
|
||||||
|
memmove(path.str, path.str + 6, path.size);
|
||||||
|
path.str[0] = '\\';
|
||||||
|
}
|
||||||
|
else if (match_part(path, make_lit_string("\\\\?\\"))){
|
||||||
|
path.size -= 4;
|
||||||
|
memmove(path.str, path.str + 4, path.size);
|
||||||
|
}
|
||||||
|
return(path);
|
||||||
|
}
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Set_File_List_Sig(system_set_file_list){
|
Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
b32 clear_list = true;
|
b32 clear_list = true;
|
||||||
|
@ -134,12 +148,19 @@ Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
DWORD final_length = GetFinalPathNameByHandle_utf8(dir_handle, (u8*)dir_space, sizeof(dir_space), 0);
|
DWORD final_length = GetFinalPathNameByHandle_utf8(dir_handle, (u8*)dir_space, sizeof(dir_space), 0);
|
||||||
CloseHandle(dir_handle);
|
CloseHandle(dir_handle);
|
||||||
|
|
||||||
if (final_length + 2 < sizeof(dir_space)){
|
if (final_length + 3 < sizeof(dir_space)){
|
||||||
u8 *c_str_dir = (u8*)dir_space;
|
u8 *c_str_dir = (u8*)dir_space;
|
||||||
|
if (c_str_dir[final_length - 1] == 0){
|
||||||
|
--final_length;
|
||||||
|
}
|
||||||
|
String str_dir = make_string(c_str_dir, final_length);
|
||||||
|
String adjusted_str_dir = win32_remove_unc_prefix_characters(str_dir);
|
||||||
|
|
||||||
|
c_str_dir = (u8*)adjusted_str_dir.str;
|
||||||
|
final_length = adjusted_str_dir.size;
|
||||||
c_str_dir[final_length] = '\\';
|
c_str_dir[final_length] = '\\';
|
||||||
c_str_dir[final_length+1] = '*';
|
c_str_dir[final_length + 1] = '*';
|
||||||
c_str_dir[final_length+2] = 0;
|
c_str_dir[final_length + 2] = 0;
|
||||||
|
|
||||||
if (canon_directory_out != 0){
|
if (canon_directory_out != 0){
|
||||||
if (final_length+1 < canon_directory_max){
|
if (final_length+1 < canon_directory_max){
|
||||||
|
@ -264,12 +285,14 @@ Sys_Get_Canonical_Sig(system_get_canonical){
|
||||||
if (file != INVALID_HANDLE_VALUE){
|
if (file != INVALID_HANDLE_VALUE){
|
||||||
DWORD final_length = GetFinalPathNameByHandle_utf8(file, (u8*)buffer, max, 0);
|
DWORD final_length = GetFinalPathNameByHandle_utf8(file, (u8*)buffer, max, 0);
|
||||||
|
|
||||||
if (final_length < max && final_length >= 4){
|
if (final_length + 3 < max){
|
||||||
if (buffer[final_length - 1] == 0){
|
if (buffer[final_length - 1] == 0){
|
||||||
--final_length;
|
--final_length;
|
||||||
}
|
}
|
||||||
//final_length -= 4;
|
String str_dir = make_string(buffer, final_length);
|
||||||
//memmove(buffer, buffer+4, final_length);
|
String adjusted_str_dir = win32_remove_unc_prefix_characters(str_dir);
|
||||||
|
buffer = adjusted_str_dir.str;
|
||||||
|
final_length = adjusted_str_dir.size;
|
||||||
buffer[final_length] = 0;
|
buffer[final_length] = 0;
|
||||||
result = final_length;
|
result = final_length;
|
||||||
}
|
}
|
||||||
|
@ -289,12 +312,14 @@ Sys_Get_Canonical_Sig(system_get_canonical){
|
||||||
if (dir != INVALID_HANDLE_VALUE){
|
if (dir != INVALID_HANDLE_VALUE){
|
||||||
DWORD final_length = GetFinalPathNameByHandle_utf8(dir, (u8*)buffer, max, 0);
|
DWORD final_length = GetFinalPathNameByHandle_utf8(dir, (u8*)buffer, max, 0);
|
||||||
|
|
||||||
if (final_length < max && final_length >= 4){
|
if (final_length + 3 < max){
|
||||||
if (buffer[final_length-1] == 0){
|
if (buffer[final_length-1] == 0){
|
||||||
--final_length;
|
--final_length;
|
||||||
}
|
}
|
||||||
final_length -= 4;
|
String str_dir = make_string(buffer, final_length);
|
||||||
memmove(buffer, buffer+4, final_length);
|
String adjusted_str_dir = win32_remove_unc_prefix_characters(str_dir);
|
||||||
|
buffer = adjusted_str_dir.str;
|
||||||
|
final_length = adjusted_str_dir.size;
|
||||||
buffer[final_length++] = '\\';
|
buffer[final_length++] = '\\';
|
||||||
memcpy(buffer + final_length, front_str.str, front_str.size);
|
memcpy(buffer + final_length, front_str.str, front_str.size);
|
||||||
final_length += front_str.size;
|
final_length += front_str.size;
|
||||||
|
|
|
@ -32,14 +32,14 @@ command_list = {
|
||||||
{"echo build: x64 & ./build.sh", .os = "mac" }, }, },
|
{"echo build: x64 & ./build.sh", .os = "mac" }, }, },
|
||||||
{ .name = "build site",
|
{ .name = "build site",
|
||||||
.out = "*site*", .footer_panel = false, .save_dirty_files = true,
|
.out = "*site*", .footer_panel = false, .save_dirty_files = true,
|
||||||
.cmd = { {"build_site.bat", .os = "win" },
|
.cmd = { {"build_site.bat" , .os = "win" },
|
||||||
{"./build_site.sh" , .os = "linux"},
|
{"./build_site.sh", .os = "linux"},
|
||||||
{"./build_site.sh" , .os = "mac" }, }, },
|
{"./build_site.sh", .os = "mac" }, }, },
|
||||||
{ .name = "build string",
|
{ .name = "build string",
|
||||||
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
||||||
.cmd = { {"build_string.bat", .os = "win" },
|
.cmd = { {"build_string.bat" , .os = "win" },
|
||||||
{"./build_string.sh" , .os = "linux"},
|
{"./build_string.sh", .os = "linux"},
|
||||||
{"./build_string.sh" , .os = "mac" }, }, },
|
{"./build_string.sh", .os = "mac" }, }, },
|
||||||
{ .name = "build x86",
|
{ .name = "build x86",
|
||||||
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
||||||
.cmd = { {build_x86_win32, .os = "win" },
|
.cmd = { {build_x86_win32, .os = "win" },
|
||||||
|
@ -47,24 +47,32 @@ command_list = {
|
||||||
{build_x86_mac , .os = "mac" }, }, },
|
{build_x86_mac , .os = "mac" }, }, },
|
||||||
{ .name = "build metadata",
|
{ .name = "build metadata",
|
||||||
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
||||||
.cmd = { {"build_metadata.bat", .os = "win" },
|
.cmd = { {"build_metadata.bat" , .os = "win" },
|
||||||
{"./build_metadata.sh" , .os = "linux"},
|
{"./build_metadata.sh", .os = "linux"},
|
||||||
{"./build_metadata.sh" , .os = "mac" }, }, },
|
{"./build_metadata.sh", .os = "mac" }, }, },
|
||||||
{ .name = "package",
|
{ .name = "package",
|
||||||
.out = "*package*", .footer_panel = false, .save_dirty_files = true,
|
.out = "*package*", .footer_panel = false, .save_dirty_files = true,
|
||||||
.cmd = { {"package.bat", .os = "win" },
|
.cmd = { {"package.bat" , .os = "win" },
|
||||||
{"./package.sh" , .os = "linux"},
|
{"./package.sh", .os = "linux"},
|
||||||
{"./package.sh" , .os = "mac" }, }, },
|
{"./package.sh", .os = "mac" }, }, },
|
||||||
{ .name = "build config parser generator",
|
{ .name = "build config parser generator",
|
||||||
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
||||||
.cmd = { {"build_config_parser_generator.bat", .os = "win" },
|
.cmd = { {"build_config_parser_generator.bat" , .os = "win" },
|
||||||
{"./build_config_parser_generator.sh" , .os = "linux"},
|
{"./build_config_parser_generator.sh", .os = "linux"},
|
||||||
{"./build_config_parser_generator.sh" , .os = "mac" }, }, },
|
{"./build_config_parser_generator.sh", .os = "mac" }, }, },
|
||||||
{ .name = "generate config parser",
|
{ .name = "generate config parser",
|
||||||
.out = "*gen*", .footer_panel = false, .save_dirty_files = true,
|
.out = "*gen*", .footer_panel = false, .save_dirty_files = true,
|
||||||
.cmd = { {"..\\build\\generate_config_parser", .os = "win" },
|
.cmd = { {"..\\build\\generate_config_parser", .os = "win" },
|
||||||
{"../build/generate_config_parser", .os = "linux"},
|
{"../build/generate_config_parser" , .os = "linux"},
|
||||||
{"../build/generate_config_parser", .os = "mac" }, }, },
|
{"../build/generate_config_parser" , .os = "mac" }, }, },
|
||||||
|
{ .name = "build cpp preproc test",
|
||||||
|
.out = "*compilation*", .footer_panel = true, .save_dirty_files = true,
|
||||||
|
.cmd = { {"pushd test_preproc & build.bat", .os = "win"},
|
||||||
|
}, },
|
||||||
|
{ .name = "run cpp preproc test",
|
||||||
|
.out = "*run*", .footer_panel = false, .save_dirty_files = true,
|
||||||
|
.cmd = { {"pushd test_preproc & ..\\..\\build\\test_preproc test_1_src.cpp test_1_res.i", .os = "win"},
|
||||||
|
}, },
|
||||||
};
|
};
|
||||||
|
|
||||||
fkey_command[1] = "build x64";
|
fkey_command[1] = "build x64";
|
||||||
|
@ -76,3 +84,5 @@ fkey_command[6] = "build config parser generator";
|
||||||
fkey_command[7] = "generate config parser";
|
fkey_command[7] = "generate config parser";
|
||||||
fkey_command[12] = "package";
|
fkey_command[12] = "package";
|
||||||
|
|
||||||
|
//fkey_command[1] = "build cpp preproc test";
|
||||||
|
//fkey_command[2] = "run cpp preproc test";
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
1
|
1
|
||||||
0
|
0
|
||||||
115
|
116
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
@echo off
|
||||||
|
|
||||||
|
set opts=-FC -GR- -EHa- -nologo -Zi
|
||||||
|
set code=%cd%
|
||||||
|
pushd ..\..\build
|
||||||
|
cl %opts% %code%\test_preproc_main.cpp -Fetest_preproc
|
||||||
|
popd
|
|
@ -0,0 +1,139 @@
|
||||||
|
#line 1 "test_1_src.cpp"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#line 26 "test_1_src.cpp"
|
||||||
|
|
||||||
|
2;
|
||||||
|
|
||||||
|
#line 30 "test_1_src.cpp"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
3;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#line 49 "test_1_src.cpp"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#line 59 "test_1_src.cpp"
|
||||||
|
|
||||||
|
4;
|
||||||
|
|
||||||
|
#line 63 "test_1_src.cpp"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(5 + (0));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(5 + (4));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(5 + ((5 + (4))));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(((4 + (0))) + ((4 + (1))) + ((4 + (2))));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(baz(4, 4, 4, 4));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
BAR;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FOO(0) + 20;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(a) + 2*(b) + (c)/2 +(d) + 2*(e) + (f)/2 +(g) + 2*(h) + (i)/2 +(j) + 2*(k) + (l)/2 +(m) + 2*(n) + (o)/2 +(p) + 2*(q) + (r)/2 +(s) + 2*(t) + (u)/2 + 0;
|
||||||
|
|
||||||
|
#line 138 "test_1_src.cpp"
|
||||||
|
|
|
@ -0,0 +1,138 @@
|
||||||
|
|
||||||
|
// F0
|
||||||
|
|
||||||
|
#if !defined(FOO)
|
||||||
|
#define FOO 0
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
// F1
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO 1
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
// F2
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO 2
|
||||||
|
|
||||||
|
#if !defined(FOO)
|
||||||
|
|
||||||
|
2;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// F3
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define BAR 3
|
||||||
|
|
||||||
|
#ifdef FOO
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
#elif defined(BAR)
|
||||||
|
|
||||||
|
BAR;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
3;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// F4
|
||||||
|
|
||||||
|
#define FOO 4
|
||||||
|
|
||||||
|
#if FOO < BAR
|
||||||
|
|
||||||
|
BAR;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// F5
|
||||||
|
|
||||||
|
#undef BAR
|
||||||
|
#define BAR(a) (5 + (a))
|
||||||
|
|
||||||
|
BAR(0);
|
||||||
|
|
||||||
|
// F9
|
||||||
|
|
||||||
|
BAR(FOO);
|
||||||
|
|
||||||
|
// F14
|
||||||
|
|
||||||
|
BAR(BAR(FOO));
|
||||||
|
|
||||||
|
// F15
|
||||||
|
|
||||||
|
#undef BAR
|
||||||
|
#define BAR(a,b,c) ((a) + (b) + (c))
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO(n) (4 + (n))
|
||||||
|
|
||||||
|
BAR(FOO(0), FOO(1), FOO(2));
|
||||||
|
|
||||||
|
// F16
|
||||||
|
|
||||||
|
#undef BAR
|
||||||
|
#define BAR(a,...) (a(__VA_ARGS__))
|
||||||
|
|
||||||
|
BAR(baz, 4, 4, 4, 4);
|
||||||
|
|
||||||
|
// F17
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO FOO
|
||||||
|
|
||||||
|
FOO;
|
||||||
|
|
||||||
|
// F18
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO BAR
|
||||||
|
|
||||||
|
#undef BAR
|
||||||
|
#define BAR FOO
|
||||||
|
|
||||||
|
BAR;
|
||||||
|
|
||||||
|
// F20
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO(a) FOO(a) + 20
|
||||||
|
|
||||||
|
FOO(0);
|
||||||
|
|
||||||
|
// L1
|
||||||
|
|
||||||
|
#undef FOO
|
||||||
|
#define FOO(x)\
|
||||||
|
x(a,b,c)\
|
||||||
|
x(d,e,f)\
|
||||||
|
x(g,h,i)\
|
||||||
|
x(j,k,l)\
|
||||||
|
x(m,n,o)\
|
||||||
|
x(p,q,r)\
|
||||||
|
x(s,t,u)
|
||||||
|
|
||||||
|
#undef BAR
|
||||||
|
#define BAR(x,y,z) (x) + 2*(y) + (z)/2 +
|
||||||
|
|
||||||
|
FOO(BAR) 0;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
/*
|
||||||
|
* Mr. 4th Dimention - Allen Webster
|
||||||
|
*
|
||||||
|
* 10.06.2018
|
||||||
|
*
|
||||||
|
* Test bed for developing 4coder_cpp_preprocessor
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
// TOP
|
||||||
|
|
||||||
|
#include "../4ed_defines.h"
|
||||||
|
#include "../meta/4ed_meta_defines.h"
|
||||||
|
|
||||||
|
#include "../4coder_file.h"
|
||||||
|
|
||||||
|
#include "../4coder_lib/4coder_mem.h"
|
||||||
|
#include "../4coder_lib/4cpp_lexer.h"
|
||||||
|
#include "../4coder_cpp_preprocessor.h"
|
||||||
|
|
||||||
|
#include "../4coder_cpp_preprocessor.cpp"
|
||||||
|
|
||||||
|
void
|
||||||
|
print_usage(void){
|
||||||
|
fprintf(stdout, "test_preproc src correct_result\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv){
|
||||||
|
if (argc != 3){
|
||||||
|
print_usage();
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *input_file_name = argv[1];
|
||||||
|
char *compare_file_name = argv[2];
|
||||||
|
|
||||||
|
i32 memory_size = MB(512);
|
||||||
|
void *memory = malloc(memory_size);
|
||||||
|
Partition part = make_part(memory, memory_size);
|
||||||
|
String text = file_dump(&part, input_file_name);
|
||||||
|
if (text.str != 0){
|
||||||
|
String compare_text = file_dump(&part, compare_file_name);
|
||||||
|
if (compare_text.str != 0){
|
||||||
|
if (text.size != compare_text.size ||
|
||||||
|
memcmp(text.str, compare_text.str, text.size) != 0){
|
||||||
|
fprintf(stdout, "dif failed\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
fprintf(stdout, "could not open comparison file %s\n", compare_file_name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
fprintf(stdout, "could not open input %s\n", input_file_name);
|
||||||
|
}
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// BOTTOM
|
Loading…
Reference in New Issue