4coder/meta/build.cpp

1041 lines
25 KiB
C++
Raw Normal View History

/*
4coder development build rule.
*/
// TOP
2016-09-04 20:41:48 +00:00
#include <stdio.h> // include system for windows
#include <stdlib.h> // include system for linux (YAY!)
#include <stdint.h>
#include <assert.h>
2016-09-04 20:41:48 +00:00
#include <string.h>
#include "../common/4coder_version.h"
#define FSTRING_INLINE static
#include "../internal_4coder_string.cpp"
//
// reusable
//
#define IS_64BIT
// NOTE(allen): Compiler/OS cracking.
#if defined(_MSC_VER)
# define IS_CL
# define snprintf _snprintf
# if defined(_WIN32)
# define IS_WINDOWS
# pragma comment(lib, "Kernel32.lib")
# else
2016-09-04 20:41:48 +00:00
# error This compiler/platform combo is not supported yet
# endif
2016-09-04 20:41:48 +00:00
#elif defined(__GNUC__) || defined(__GNUG__)
# define IS_GCC
2016-09-04 20:41:48 +00:00
# if defined(__gnu_linux__)
2016-09-04 20:41:48 +00:00
# define IS_LINUX
# else
2016-09-04 20:41:48 +00:00
# error This compiler/platform combo is not supported yet
# endif
#else
#error This compiler is not supported yet
#endif
#if defined(IS_WINDOWS)
# define ONLY_WINDOWS(x) x
# define ONLY_LINUX(x) (void)0
#elif defined(IS_LINUX)
# define ONLY_WINDOWS(x) (void)0
# define ONLY_LINUX(x) x
#else
# define ONLY_WIN(x) (void)0
# define ONLY_LINUX(x) (void)0
#endif
static char cmd[4096];
2016-08-29 01:03:26 +00:00
static int32_t error_state = 0;
static int32_t prev_error = 0;
#define systemf(...) do{ \
int32_t n = snprintf(cmd, sizeof(cmd), __VA_ARGS__); \
assert(n < sizeof(cmd)); \
prev_error = system(cmd); \
if (prev_error != 0) error_state = 1; \
}while(0)
2016-09-04 20:41:48 +00:00
static void init_time_system();
static uint64_t get_time();
static int32_t get_current_directory(char *buffer, int32_t max);
static void execute_in_dir(char *dir, char *str, char *args);
2016-09-04 20:41:48 +00:00
2016-10-28 21:25:16 +00:00
static void make_folder_if_missing(char *dir, char *folder);
static void clear_folder(char *folder);
2016-10-28 21:25:16 +00:00
static void copy_file(char *path, char *file, char *folder1, char *folder2, char *newname);
static void copy_all(char *source, char *tag, char *folder);
static void zip(char *parent, char *folder, char *dest);
typedef struct Temp_Dir{
char dir[512];
} Temp_Dir;
static Temp_Dir pushdir(char *dir);
static void popdir(Temp_Dir temp);
#if defined(IS_WINDOWS)
2016-08-28 15:42:12 +00:00
typedef uint32_t DWORD;
typedef int32_t LONG;
typedef int64_t LONGLONG;
typedef char* LPTSTR;
typedef char* LPCTSTR;
typedef int32_t BOOL;
typedef void* LPSECURITY_ATTRIBUTES;
typedef union _LARGE_INTEGER {
2016-08-28 15:42:12 +00:00
struct {
DWORD LowPart;
LONG HighPart;
};
struct {
DWORD LowPart;
LONG HighPart;
} u;
LONGLONG QuadPart;
} LARGE_INTEGER, *PLARGE_INTEGER;
#if defined(IS_64BIT)
# define WINAPI
#endif
extern "C"{
DWORD WINAPI GetCurrentDirectoryA(_In_ DWORD nBufferLength, _Out_ LPTSTR lpBuffer);
BOOL WINAPI SetCurrentDirectoryA(_In_ LPCTSTR lpPathName);
BOOL WINAPI QueryPerformanceCounter(_Out_ LARGE_INTEGER *lpPerformanceCount);
BOOL WINAPI QueryPerformanceFrequency(_Out_ LARGE_INTEGER *lpFrequency);
BOOL WINAPI CreateDirectoryA(_In_ LPCTSTR lpPathName, _In_opt_ LPSECURITY_ATTRIBUTES lpSecurityAttributes);
BOOL WINAPI CopyFileA(_In_ LPCTSTR lpExistingFileName, _In_ LPCTSTR lpNewFileName, _In_ BOOL bFailIfExists);
}
2016-08-28 15:42:12 +00:00
static uint64_t perf_frequency;
static Temp_Dir
pushdir(char *dir){
Temp_Dir temp = {0};
GetCurrentDirectoryA(sizeof(temp.dir), temp.dir);
SetCurrentDirectoryA(dir);
return(temp);
}
static void
popdir(Temp_Dir temp){
SetCurrentDirectoryA(temp.dir);
}
2016-08-28 15:42:12 +00:00
static void
init_time_system(){
LARGE_INTEGER lint;
if (QueryPerformanceFrequency(&lint)){
perf_frequency = lint.QuadPart;
}
}
static uint64_t
get_time(){
uint64_t time = 0;
LARGE_INTEGER lint;
if (QueryPerformanceCounter(&lint)){
time = lint.QuadPart;
time = (time * 1000000) / perf_frequency;
}
return(time);
}
static int32_t
get_current_directory(char *buffer, int32_t max){
int32_t result = GetCurrentDirectoryA(max, buffer);
return(result);
}
static void
execute_in_dir(char *dir, char *str, char *args){
if (dir){
Temp_Dir temp = pushdir(dir);
2016-11-14 06:39:03 +00:00
if (args){
systemf("call \"%s\" %s", str, args);
2016-11-14 06:39:03 +00:00
}
else{
systemf("call \"%s\"", str);
2016-11-14 06:39:03 +00:00
}
popdir(temp);
}
else{
2016-11-14 06:39:03 +00:00
if (args){
systemf("call \"%s\" %s", str, args);
}
else{
systemf("call \"%s\"", str);
}
}
}
2016-09-05 01:27:37 +00:00
static void
slash_fix(char *path){
2016-10-29 17:58:28 +00:00
if (path){
for (int32_t i = 0; path[i]; ++i){
if (path[i] == '/') path[i] = '\\';
}
2016-09-05 01:27:37 +00:00
}
}
static void
2016-10-28 21:25:16 +00:00
make_folder_if_missing(char *dir, char *folder){
char space[1024];
String path = make_fixed_width_string(space);
append_sc(&path, dir);
if (folder){
append_sc(&path, "\\");
append_sc(&path, folder);
2016-10-28 21:25:16 +00:00
}
terminate_with_null(&path);
2016-09-05 01:27:37 +00:00
2016-10-28 21:25:16 +00:00
char *p = path.str;
2016-09-05 01:27:37 +00:00
for (; *p; ++p){
if (*p == '\\'){
*p = 0;
2016-10-29 17:58:28 +00:00
CreateDirectoryA(path.str, 0);
2016-09-05 01:27:37 +00:00
*p = '\\';
}
}
2016-10-29 17:58:28 +00:00
CreateDirectoryA(path.str, 0);
2016-09-05 01:27:37 +00:00
}
static void
clear_folder(char *folder){
systemf("del /S /Q /F %s\\* & rmdir /S /Q %s & mkdir %s",
folder, folder, folder);
2016-09-05 01:27:37 +00:00
}
static void
2016-10-28 21:25:16 +00:00
copy_file(char *path, char *file, char *folder1, char *folder2, char *newname){
2016-09-05 01:27:37 +00:00
char src[256], dst[256];
String b = make_fixed_width_string(src);
if (path){
append_sc(&b, path);
append_sc(&b, "\\");
}
2016-09-05 01:27:37 +00:00
append_sc(&b, file);
terminate_with_null(&b);
b = make_fixed_width_string(dst);
2016-10-28 21:25:16 +00:00
append_sc(&b, folder1);
2016-09-05 01:27:37 +00:00
append_sc(&b, "\\");
2016-10-28 21:25:16 +00:00
if (folder2){
append_sc(&b, folder2);
append_sc(&b, "\\");
}
if (newname){
append_sc(&b, newname);
}
else{
append_sc(&b, file);
}
2016-09-05 01:27:37 +00:00
terminate_with_null(&b);
CopyFileA(src, dst, 0);
2016-09-05 01:27:37 +00:00
}
static void
2016-10-28 21:25:16 +00:00
copy_all(char *source, char *tag, char *folder){
if (source){
systemf("copy %s\\%s %s\\*", source, tag, folder);
2016-10-28 21:25:16 +00:00
}
else{
systemf("copy %s %s\\*", tag, folder);
}
2016-09-05 01:27:37 +00:00
}
static void
zip(char *parent, char *folder, char *dest){
2016-09-05 01:27:37 +00:00
char cdir[512];
get_current_directory(cdir, sizeof(cdir));
Temp_Dir temp = pushdir(parent);
systemf("%s\\zip %s\\4tech_gobble.zip", cdir, cdir);
popdir(temp);
systemf("copy %s\\4tech_gobble.zip %s & del %s\\4tech_gobble.zip", cdir, dest, cdir);
2016-09-05 01:27:37 +00:00
}
2016-09-04 20:41:48 +00:00
#elif defined(IS_LINUX)
#include <time.h>
#include <unistd.h>
static Temp_Dir
pushdir(char *dir){
2016-09-04 20:41:48 +00:00
Temp_Dir temp;
char *result = getcwd(temp.dir, sizeof(temp.dir));
int32_t chresult = chdir(dir);
if (result == 0 || chresult != 0){
printf("trying pushdir %s\n", dir);
2016-09-04 20:41:48 +00:00
assert(result != 0);
assert(chresult == 0);
}
return(temp);
}
static void
popdir(Temp_Dir temp){
2016-09-04 20:41:48 +00:00
chdir(temp.dir);
}
static void
init_time_system(){
// NOTE(allen): do nothing
}
static uint64_t
get_time(){
struct timespec spec;
uint64_t result;
clock_gettime(CLOCK_MONOTONIC, &spec);
result = (spec.tv_sec * (uint64_t)(1000000)) + (spec.tv_nsec / (uint64_t)(1000));
return(result);
}
static int32_t
get_current_directory(char *buffer, int32_t max){
int32_t result = 0;
char *d = getcwd(buffer, max);
if (d == buffer){
result = strlen(buffer);
}
return(result);
}
static void
execute_in_dir(char *dir, char *str, char *args){
2016-09-04 20:41:48 +00:00
if (dir){
2016-11-14 06:39:03 +00:00
if (args){
Temp_Dir temp = pushdir(dir);
systemf("%s %s", str, args);
popdir(temp);
2016-11-14 06:39:03 +00:00
}
else{
Temp_Dir temp = pushdir(dir);
2016-11-14 06:39:03 +00:00
systemf("%s", str);
popdir(temp);
2016-11-14 06:39:03 +00:00
}
2016-09-04 20:41:48 +00:00
}
else{
2016-11-14 06:39:03 +00:00
if (args){
systemf("%s %s", str, args);
2016-11-14 06:39:03 +00:00
}
else{
systemf("%s", str);
}
2016-09-04 20:41:48 +00:00
}
}
2016-09-05 01:27:37 +00:00
static void
slash_fix(char *path){}
static void
2016-10-28 21:25:16 +00:00
make_folder_if_missing(char *dir, char *folder){
if (folder){
systemf("mkdir -p %s/%s", dir, folder);
2016-10-28 21:25:16 +00:00
}
else{
systemf("mkdir -p %s", dir);
}
}
static void
clear_folder(char *folder){
systemf("rm -rf %s*", folder);
}
static void
2016-10-28 21:25:16 +00:00
copy_file(char *path, char *file, char *folder1, char *folder2, char *newname){
if (!newname){
newname = file;
}
if (path){
2016-10-28 21:25:16 +00:00
if (folder2){
systemf("cp %s/%s %s/%s/%s", path, file, folder1, folder2, newname);
2016-10-28 21:25:16 +00:00
}
else{
systemf("cp %s/%s %s/%s", path, file, folder1, newname);
}
}
else{
2016-10-28 21:25:16 +00:00
if (folder2){
systemf("cp %s %s/%s/%s", file, folder1, folder2, newname);
}
else{
systemf("cp %s %s/%s", file, folder1, newname);
}
}
}
static void
2016-10-28 21:25:16 +00:00
copy_all(char *source, char *tag, char *folder){
if (source){
systemf("cp -rf %s/%s %s", source, tag, folder);
2016-10-28 21:25:16 +00:00
}
else{
systemf("cp -rf %s %s", tag, folder);
}
}
static void
zip(char *parent, char *folder, char *file){
Temp_Dir temp = pushdir(parent);
systemf("zip -r %s %s", file, folder);
popdir(temp);
}
#else
#error This OS is not supported yet
#endif
#define BEGIN_TIME_SECTION() uint64_t start = get_time()
#define END_TIME_SECTION(n) uint64_t total = get_time() - start; printf("%-20s: %.2lu.%.6lu\n", (n), total/1000000, total%1000000);
2016-08-28 15:42:12 +00:00
//
// 4coder specific
//
#if defined(IS_WINDOWS)
#define EXE ".exe"
#elif defined(IS_LINUX)
#define EXE ""
#else
#error No EXE format specified for this OS
#endif
#if defined(IS_WINDOWS)
#define PDB ".pdb"
#elif defined(IS_LINUX)
#define PDB ""
#else
#error No EXE format specified for this OS
#endif
#if defined(IS_WINDOWS)
#define DLL ".dll"
#elif defined(IS_LINUX)
#define DLL ".so"
#else
#error No EXE format specified for this OS
#endif
#if defined(IS_WINDOWS)
#define BAT ".bat"
#elif defined(IS_LINUX)
#define BAT ".sh"
#else
#error No EXE format specified for this OS
#endif
static void
2016-09-04 20:41:48 +00:00
swap_ptr(char **A, char **B){
char *a = *A;
char *b = *B;
*A = b;
*B = a;
}
enum{
OPTS = 0x1,
INCLUDES = 0x2,
LIBS = 0x4,
ICON = 0x8,
SHARED_CODE = 0x10,
DEBUG_INFO = 0x20,
SUPER = 0x40,
INTERNAL = 0x80,
OPTIMIZATION = 0x100,
2016-11-14 04:29:00 +00:00
KEEP_ASSERT = 0x200,
SITE_INCLUDES = 0x400,
};
2016-09-04 20:41:48 +00:00
#define BUILD_LINE_MAX 4096
typedef struct Build_Line{
char build_optionsA[BUILD_LINE_MAX];
char build_optionsB[BUILD_LINE_MAX];
char *build_options;
char *build_options_prev;
int32_t build_max;
} Build_Line;
static void
init_build_line(Build_Line *line){
line->build_options = line->build_optionsA;
line->build_options_prev = line->build_optionsB;
line->build_optionsA[0] = 0;
line->build_optionsB[0] = 0;
line->build_max = BUILD_LINE_MAX;
}
#if defined(IS_CL)
#define build_ap(line, str, ...) do{ \
snprintf(line.build_options, \
line.build_max, "%s "str, \
line.build_options_prev, __VA_ARGS__); \
swap_ptr(&line.build_options, \
&line.build_options_prev); \
}while(0)
#elif defined(IS_GCC)
#define build_ap(line, str, ...) do{ \
snprintf(line.build_options, \
line.build_max, "%s "str, \
line.build_options_prev, ##__VA_ARGS__);\
swap_ptr(&line.build_options, \
&line.build_options_prev); \
}while(0)
#endif
#define CL_OPTS \
"/W4 /wd4310 /wd4100 /wd4201 /wd4505 /wd4996 " \
"/wd4127 /wd4510 /wd4512 /wd4610 /wd4390 /WX " \
"/GR- /EHa- /nologo /FC"
#define CL_INCLUDES "/I..\\foreign /I..\\foreign\\freetype2"
2016-09-04 20:41:48 +00:00
2016-11-28 19:13:53 +00:00
#define CL_SITE_INCLUDES "/I..\\..\\foreign /I..\\..\\code"
2016-11-14 04:29:00 +00:00
2016-09-04 20:41:48 +00:00
#define CL_LIBS \
"user32.lib winmm.lib gdi32.lib opengl32.lib " \
"..\\foreign\\freetype.lib"
#define CL_ICON "..\\res\\icon.res"
2016-09-04 20:41:48 +00:00
static void
2016-11-14 04:29:00 +00:00
build_cl(uint32_t flags, char *code_path, char *code_file, char *out_path, char *out_file, char *exports){
2016-09-04 20:41:48 +00:00
Build_Line line;
init_build_line(&line);
if (flags & OPTS){
build_ap(line, CL_OPTS);
}
if (flags & INCLUDES){
build_ap(line, CL_INCLUDES);
}
2016-11-14 04:29:00 +00:00
if (flags & SITE_INCLUDES){
build_ap(line, CL_SITE_INCLUDES);
}
2016-09-04 20:41:48 +00:00
if (flags & LIBS){
build_ap(line, CL_LIBS);
}
if (flags & ICON){
build_ap(line, CL_ICON);
}
if (flags & DEBUG_INFO){
build_ap(line, "/Zi");
}
if (flags & OPTIMIZATION){
build_ap(line, "/O2");
}
if (flags & SHARED_CODE){
build_ap(line, "/LD");
}
if (flags & SUPER){
build_ap(line, "/DFRED_SUPER");
}
if (flags & INTERNAL){
build_ap(line, "/DFRED_INTERNAL");
}
if (flags & KEEP_ASSERT){
build_ap(line, "/DFRED_KEEP_ASSERT");
}
swap_ptr(&line.build_options, &line.build_options_prev);
char link_options[1024];
if (flags & SHARED_CODE){
assert(exports);
snprintf(link_options, sizeof(link_options), "/OPT:REF %s", exports);
}
else{
snprintf(link_options, sizeof(link_options), "/NODEFAULTLIB:library");
}
Temp_Dir temp = pushdir(out_path);
systemf("cl %s %s\\%s /Fe%s /link /DEBUG /INCREMENTAL:NO %s", line.build_options, code_path, code_file, out_file, link_options);
popdir(temp);
2016-09-04 20:41:48 +00:00
}
#define GCC_OPTS \
"-Wno-write-strings -D_GNU_SOURCE -fPIC " \
2016-11-14 04:29:00 +00:00
"-fno-threadsafe-statics -pthread"
2016-09-04 20:41:48 +00:00
#define GCC_INCLUDES "-I../foreign -I../code"
2016-09-04 20:41:48 +00:00
2016-11-28 19:13:53 +00:00
#define GCC_SITE_INCLUDES "-I../../foreign -I../../code"
2016-11-14 04:29:00 +00:00
2016-09-04 20:41:48 +00:00
#define GCC_LIBS \
"-L/usr/local/lib -lX11 -lpthread -lm -lrt " \
"-lGL -ldl -lXfixes -lfreetype -lfontconfig"
static void
2016-11-14 04:29:00 +00:00
build_gcc(uint32_t flags, char *code_path, char *code_file, char *out_path, char *out_file, char *exports){
2016-09-04 20:41:48 +00:00
Build_Line line;
init_build_line(&line);
if (flags & OPTS){
2016-09-04 20:41:48 +00:00
build_ap(line, GCC_OPTS);
}
if (flags & INCLUDES){
2016-09-05 01:27:37 +00:00
// TODO(allen): Abstract this out.
2016-09-05 03:32:26 +00:00
#if defined(IS_LINUX)
2016-09-04 20:41:48 +00:00
int32_t size = 0;
char freetype_include[512];
FILE *file = popen("pkg-config --cflags freetype2", "r");
if (file != 0){
fgets(freetype_include, sizeof(freetype_include), file);
size = strlen(freetype_include);
freetype_include[size-1] = 0;
pclose(file);
}
build_ap(line, GCC_INCLUDES" %s", freetype_include);
2016-09-05 01:27:37 +00:00
#endif
}
2016-11-14 04:29:00 +00:00
if (flags & SITE_INCLUDES){
build_ap(line, GCC_SITE_INCLUDES);
}
if (flags & DEBUG_INFO){
2016-09-04 20:41:48 +00:00
build_ap(line, "-g -O0");
}
if (flags & OPTIMIZATION){
2016-09-04 20:41:48 +00:00
build_ap(line, "-O3");
}
if (flags & SHARED_CODE){
2016-09-04 20:41:48 +00:00
build_ap(line, "-shared");
}
if (flags & SUPER){
2016-09-04 20:41:48 +00:00
build_ap(line, "-DFRED_SUPER");
}
if (flags & INTERNAL){
2016-09-04 20:41:48 +00:00
build_ap(line, "-DFRED_INTERNAL");
}
if (flags & KEEP_ASSERT){
2016-09-04 20:41:48 +00:00
build_ap(line, "-DFRED_KEEP_ASSERT");
}
2016-09-04 20:41:48 +00:00
build_ap(line, "%s/%s", code_path, code_file);
2016-09-04 20:41:48 +00:00
if (flags & LIBS){
build_ap(line, GCC_LIBS);
}
swap_ptr(&line.build_options, &line.build_options_prev);
Temp_Dir temp = pushdir(out_path);
2016-09-04 20:41:48 +00:00
systemf("g++ %s -o %s", line.build_options, out_file);
popdir(temp);
}
static void
2016-11-14 04:29:00 +00:00
build(uint32_t flags, char *code_path, char *code_file, char *out_path, char *out_file, char *exports){
#if defined(IS_CL)
build_cl(flags, code_path, code_file, out_path, out_file, exports);
2016-09-04 20:41:48 +00:00
#elif defined(IS_GCC)
build_gcc(flags, code_path, code_file, out_path, out_file, exports);
#else
#error The build rule for this compiler is not ready
#endif
}
static void
2016-08-28 15:42:12 +00:00
buildsuper(char *code_path, char *out_path, char *filename){
Temp_Dir temp = pushdir(out_path);
#if defined(IS_CL)
systemf("call \"%s\\buildsuper.bat\" %s", code_path, filename);
2016-09-04 20:41:48 +00:00
#elif defined(IS_GCC)
systemf("\"%s/buildsuper.sh\" %s", code_path, filename);
2016-09-04 20:41:48 +00:00
#else
#error The build rule for this compiler is not ready
#endif
popdir(temp);
}
#define META_DIR "../meta"
#define BUILD_DIR "../build"
2016-10-28 21:25:16 +00:00
#define SITE_DIR "../site"
#define PACK_DIR "../distributions"
#define PACK_DATA_DIR "../data/dist_files"
#define DATA_DIR "../data/test"
#define PACK_ALPHA_PAR_DIR "../current_dist"
#define PACK_SUPER_PAR_DIR "../current_dist_super"
#define PACK_POWER_PAR_DIR "../current_dist_power"
#define PACK_ALPHA_DIR PACK_ALPHA_PAR_DIR"/4coder"
#define PACK_SUPER_DIR PACK_SUPER_PAR_DIR"/4coder"
#define PACK_POWER_DIR PACK_POWER_PAR_DIR"/power"
2016-09-04 20:41:48 +00:00
#if defined(IS_WINDOWS)
#define PLAT_LAYER "win32_4ed.cpp"
#elif defined(IS_LINUX)
#define PLAT_LAYER "linux_4ed.cpp"
#else
#error No platform layer defined for this OS.
#endif
#define DECL_STR(n,s) char n[] = s; slash_fix(n)
static void
fsm_generator(char *cdir){
2016-08-29 01:03:26 +00:00
{
DECL_STR(file, "meta/fsm_table_generator.cpp");
DECL_STR(dir, META_DIR);
2016-08-29 01:03:26 +00:00
BEGIN_TIME_SECTION();
build(OPTS | DEBUG_INFO, cdir, file, dir, "fsmgen", 0);
2016-08-29 01:03:26 +00:00
END_TIME_SECTION("build fsm generator");
}
2016-08-30 21:23:34 +00:00
if (prev_error == 0){
DECL_STR(cmd, META_DIR"/fsmgen");
2016-08-29 01:03:26 +00:00
BEGIN_TIME_SECTION();
execute_in_dir(cdir, cmd, 0);
2016-08-29 01:03:26 +00:00
END_TIME_SECTION("run fsm generator");
}
}
static void
metagen(char *cdir){
{
DECL_STR(file, "meta/4ed_metagen.cpp");
DECL_STR(dir, META_DIR);
BEGIN_TIME_SECTION();
build(OPTS | INCLUDES | DEBUG_INFO, cdir, file, dir, "metagen", 0);
END_TIME_SECTION("build metagen");
}
if (prev_error == 0){
DECL_STR(cmd, META_DIR"/metagen");
BEGIN_TIME_SECTION();
execute_in_dir(cdir, cmd, 0);
END_TIME_SECTION("run metagen");
}
}
2016-12-14 16:09:54 +00:00
enum{
Custom_Default,
Custom_Experiments,
Custom_Casey,
Custom_ChronalVim,
Custom_COUNT
2016-12-14 16:09:54 +00:00
};
static void
2016-12-14 16:09:54 +00:00
do_buildsuper(char *cdir, int32_t custom_option){
2016-10-28 21:25:16 +00:00
char space[1024];
String str = make_fixed_width_string(space);
2016-09-09 13:04:51 +00:00
BEGIN_TIME_SECTION();
2016-12-14 16:09:54 +00:00
switch (custom_option){
case Custom_Default:
{
copy_sc(&str, "../code/4coder_default_bindings.cpp");
}break;
2016-12-14 16:09:54 +00:00
case Custom_Experiments:
{
2016-09-05 01:27:37 +00:00
#if defined(IS_WINDOWS)
copy_sc(&str, "../code/internal_4coder_tests.cpp");
2016-09-04 20:41:48 +00:00
#else
copy_sc(&str, "../code/power/4coder_experiments.cpp");
2016-09-04 20:41:48 +00:00
#endif
}break;
2016-12-14 16:09:54 +00:00
case Custom_Casey:
2016-12-14 16:09:54 +00:00
{
copy_sc(&str, "../code/power/4coder_casey.cpp");
}break;
case Custom_ChronalVim:
{
copy_sc(&str, "../4vim/4coder_chronal.cpp");
}break;
}
terminate_with_null(&str);
DECL_STR(dir, BUILD_DIR);
buildsuper(cdir, dir, str.str);
2016-09-09 13:04:51 +00:00
END_TIME_SECTION("build custom");
}
static void
build_main(char *cdir, uint32_t flags){
DECL_STR(dir, BUILD_DIR);
{
DECL_STR(file, "4ed_app_target.cpp");
BEGIN_TIME_SECTION();
build(OPTS | INCLUDES | SHARED_CODE | flags, cdir, file, dir, "4ed_app"DLL, "/EXPORT:app_get_functions");
END_TIME_SECTION("build 4ed_app");
}
{
BEGIN_TIME_SECTION();
build(OPTS | INCLUDES | LIBS | ICON | flags, cdir, PLAT_LAYER, dir, "4ed", 0);
END_TIME_SECTION("build 4ed");
}
}
static void
standard_build(char *cdir, uint32_t flags){
fsm_generator(cdir);
metagen(cdir);
2016-12-14 16:09:54 +00:00
do_buildsuper(cdir, Custom_Experiments);
//do_buildsuper(cdir, Custom_ChronalVim);
build_main(cdir, flags);
}
2016-11-14 04:29:00 +00:00
static void
site_build(char *cdir, uint32_t flags){
2016-11-14 06:39:03 +00:00
{
DECL_STR(file, "site/sitegen.cpp");
DECL_STR(dir, BUILD_DIR"/site");
BEGIN_TIME_SECTION();
build(OPTS | SITE_INCLUDES | flags, cdir, file, dir, "sitegen", 0);
END_TIME_SECTION("build sitegen");
2016-11-14 06:39:03 +00:00
}
{
BEGIN_TIME_SECTION();
DECL_STR(cmd, "../build/site/sitegen . ../site_resources site/source_material ../site");
systemf(cmd);
2016-11-14 06:39:03 +00:00
2016-11-22 18:26:58 +00:00
END_TIME_SECTION("run sitegen");
2016-11-14 06:39:03 +00:00
}
2016-11-14 04:29:00 +00:00
}
static void
get_4coder_dist_name(String *zip_file, int32_t OS_specific, char *tier, char *ext){
zip_file->size = 0;
append_sc(zip_file, PACK_DIR"/");
append_sc(zip_file, tier);
append_sc(zip_file, "/4coder-");
if (OS_specific){
#if defined(IS_WINDOWS)
append_sc(zip_file, "win-");
#elif defined(IS_LINUX) && defined(IS_64BIT)
append_sc(zip_file, "linux-64-");
#else
#error No OS string for zips on this OS
#endif
}
append_sc (zip_file, "alpha");
append_sc (zip_file, "-");
append_int_to_str (zip_file, MAJOR);
append_sc (zip_file, "-");
append_int_to_str (zip_file, MINOR);
append_sc (zip_file, "-");
append_int_to_str (zip_file, PATCH);
if (!match_cc(tier, "alpha")){
append_sc (zip_file, "-");
append_sc (zip_file, tier);
}
append_sc (zip_file, ".");
append_sc (zip_file, ext);
terminate_with_null(zip_file);
}
static void
package(char *cdir){
char str_space[1024];
String str = make_fixed_width_string(str_space), str2 = {0};
// NOTE(allen): meta
fsm_generator(cdir);
metagen(cdir);
// NOTE(allen): alpha
build_main(cdir, OPTIMIZATION | KEEP_ASSERT | DEBUG_INFO);
DECL_STR(build_dir, BUILD_DIR);
DECL_STR(site_dir, SITE_DIR);
DECL_STR(pack_dir, PACK_DIR);
DECL_STR(pack_data_dir, PACK_DATA_DIR);
DECL_STR(data_dir, DATA_DIR);
DECL_STR(pack_alpha_par_dir, PACK_ALPHA_PAR_DIR);
DECL_STR(pack_super_par_dir, PACK_SUPER_PAR_DIR);
DECL_STR(pack_power_par_dir, PACK_POWER_PAR_DIR);
DECL_STR(pack_alpha_dir, PACK_ALPHA_DIR);
DECL_STR(pack_super_dir, PACK_SUPER_DIR);
DECL_STR(pack_power_dir, PACK_POWER_DIR);
clear_folder(pack_alpha_par_dir);
make_folder_if_missing(pack_alpha_dir, "3rdparty");
make_folder_if_missing(pack_dir, "alpha");
copy_file(build_dir, "4ed"EXE, pack_alpha_dir, 0, 0);
ONLY_WINDOWS(copy_file(build_dir, "4ed"PDB, pack_alpha_dir, 0, 0));
copy_file(build_dir, "4ed_app"DLL, pack_alpha_dir, 0, 0);
ONLY_WINDOWS(copy_file(build_dir, "4ed_app"PDB, pack_alpha_dir, 0, 0));
copy_all (pack_data_dir, "*", pack_alpha_dir);
copy_file(0, "README.txt", pack_alpha_dir, 0, 0);
copy_file(0, "TODO.txt", pack_alpha_dir, 0, 0);
copy_file(DATA_DIR, "release-config.4coder", pack_alpha_dir, 0, "config.4coder");
get_4coder_dist_name(&str, 1, "alpha", "zip");
zip(pack_alpha_par_dir, "4coder", str.str);
// NOTE(allen): super
build_main(cdir, OPTIMIZATION | KEEP_ASSERT | DEBUG_INFO | SUPER);
2016-12-14 16:09:54 +00:00
do_buildsuper(cdir, Custom_Default);
clear_folder(pack_super_par_dir);
make_folder_if_missing(pack_super_dir, "3rdparty");
make_folder_if_missing(pack_dir, "super");
make_folder_if_missing(pack_dir, "super-docs");
2016-12-14 16:09:54 +00:00
copy_file(build_dir, "4ed"EXE, pack_super_dir, 0, 0);
ONLY_WINDOWS(copy_file(build_dir, "4ed"PDB, pack_super_dir, 0, 0));
copy_file(build_dir, "4ed_app"DLL, pack_super_dir, 0, 0);
ONLY_WINDOWS(copy_file(build_dir, "4ed_app"PDB, pack_super_dir, 0, 0));
copy_file(build_dir, "4coder_custom"DLL, pack_super_dir, 0, 0);
2016-12-14 16:09:54 +00:00
copy_all (pack_data_dir, "*", pack_super_dir);
copy_file(0, "README.txt", pack_super_dir, 0, 0);
copy_file(0, "TODO.txt", pack_super_dir, 0, 0);
copy_file(data_dir, "release-config.4coder", pack_super_dir, 0, "config.4coder");
2016-10-28 21:25:16 +00:00
copy_all (0, "4coder_*.h", pack_super_dir);
copy_all (0, "4coder_*.cpp", pack_super_dir);
copy_all (0, "4cpp_*.h", pack_super_dir);
copy_all (0, "4cpp_*.c", pack_super_dir);
copy_file(0, "buildsuper"BAT, pack_super_dir, 0, 0);
get_4coder_dist_name(&str, 0, "API", "html");
str2 = front_of_directory(str);
copy_file(site_dir, "custom_docs.html", pack_dir, "super-docs", str2.str);
get_4coder_dist_name(&str, 1, "super", "zip");
zip(pack_super_par_dir, "4coder", str.str);
// NOTE(allen): power
clear_folder(pack_power_par_dir);
make_folder_if_missing(pack_power_dir, 0);
make_folder_if_missing(pack_dir, "power");
copy_all("power", "*", pack_power_dir);
get_4coder_dist_name(&str, 0, "power", "zip");
zip(pack_power_par_dir, "power", str.str);
}
2016-09-04 20:41:48 +00:00
#if defined(DEV_BUILD)
int main(int argc, char **argv){
init_time_system();
char cdir[256];
BEGIN_TIME_SECTION();
int32_t n = get_current_directory(cdir, sizeof(cdir));
assert(n < sizeof(cdir));
END_TIME_SECTION("current directory");
standard_build(cdir, DEBUG_INFO | SUPER | INTERNAL);
return(error_state);
}
#elif defined(PACKAGE)
int main(int argc, char **argv){
init_time_system();
2016-10-28 21:25:16 +00:00
init_global_strings();
char cdir[256];
BEGIN_TIME_SECTION();
int32_t n = get_current_directory(cdir, sizeof(cdir));
assert(n < sizeof(cdir));
END_TIME_SECTION("current directory");
package(cdir);
return(error_state);
}
2016-11-14 04:29:00 +00:00
#elif defined(SITE_BUILD)
int main(int argc, char **argv){
init_time_system();
char cdir[256];
BEGIN_TIME_SECTION();
int32_t n = get_current_directory(cdir, sizeof(cdir));
assert(n < sizeof(cdir));
END_TIME_SECTION("current directory");
site_build(cdir, DEBUG_INFO);
return(error_state);
}
#else
#error No build type specified
#endif
2016-08-28 15:42:12 +00:00
// BOTTOM