Some Windows integration

This commit is contained in:
David Gonzalez Martin 2024-09-20 09:36:44 -06:00 committed by David
parent 9d67aa3189
commit 71e2e4b695
2 changed files with 20 additions and 1 deletions

View File

@ -1,16 +1,21 @@
#include <stdint.h>
#include <stdarg.h>
#include <stddef.h>
#include <sys/time.h>
#if defined(__x86_64__)
#include <immintrin.h>
#endif
#ifdef _WIN32
#define WIN32_LEAN_AND_MEAN 1
#include <Windows.h>
#else
#include <fcntl.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/mman.h>
#include <sys/wait.h>
#include <sys/time.h>
#endif
#ifdef NDEBUG
#define _DEBUG 0
@ -98,13 +103,22 @@ FOR_N(_i, 0, ((set)->arr.capacity + 63) / 64) FOR_BIT(it, _i*64, (set)->arr.poin
} while (0)
fn
#if _WIN32
u64
#else
#if LINK_LIBC
struct timespec
#else
u64
#endif
#endif
timestamp()
{
#ifdef _WIN32
LARGE_INTEGER li;
QueryPerformanceCounter(&li);
return (u64)li.QuadPart;
#else
#if LINK_LIBC
struct timespec ts;
clock_gettime(CLOCK_MONOTONIC, &ts);
@ -116,6 +130,7 @@ timestamp()
return 0;
#endif
#endif
#endif
}
#if LINK_LIBC
@ -441,6 +456,9 @@ may_be_unused fn s32 cast_s64_to_s32(s64 source, const char* name, int line)
#define unreachable() __builtin_unreachable()
#endif
#ifdef static_assert
#undef static_assert
#endif
#define static_assert(x) _Static_assert((x), "Static assert failed!")
#define alignof(x) _Alignof(x)
#define auto __auto_type

1
project.bat Normal file
View File

@ -0,0 +1 @@
clang -o build/build bootstrap/build.c -g -march=native -std=gnu2x -Wall -Wextra -Wpedantic -Wno-nested-anon-types -Wno-keyword-macro -Wno-gnu-auto-type -Wno-auto-decl-extensions -Wno-gnu-empty-initializer -Wno-fixed-enum-extension -pedantic -fno-exceptions -fno-stack-protector