2023-04-01 19:21:46 -07:00
|
|
|
/*
|
|
|
|
BLOAT.
|
|
|
|
|
2023-04-03 23:04:19 -07:00
|
|
|
This contians all definitions not directly related to the project.
|
|
|
|
*/
|
2023-04-05 23:21:23 -07:00
|
|
|
#pragma once
|
2023-04-01 19:21:46 -07:00
|
|
|
|
|
|
|
#ifdef BLOAT_IMPL
|
|
|
|
# define ZPL_IMPLEMENTATION
|
|
|
|
#endif
|
|
|
|
|
2023-04-09 10:59:39 -07:00
|
|
|
// TODO: This will be removed when making the library have zero dependencies.
|
2023-04-01 19:21:46 -07:00
|
|
|
#pragma region ZPL INCLUDE
|
|
|
|
#if __clang__
|
2023-04-05 23:21:23 -07:00
|
|
|
# pragma clang diagnostic push
|
2023-04-01 19:21:46 -07:00
|
|
|
# pragma clang diagnostic ignored "-Wmissing-braces"
|
|
|
|
# pragma clang diagnostic ignored "-Wbraced-scalar-init"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// # define ZPL_HEAP_ANALYSIS
|
2023-04-09 10:59:39 -07:00
|
|
|
# define ZPL_WRAP_IN_NAMESPACE
|
2023-04-01 19:21:46 -07:00
|
|
|
# define ZPL_NO_MATH_H
|
|
|
|
# define ZPL_CUSTOM_MODULES
|
|
|
|
# define ZPL_MODULE_ESSENTIALS
|
|
|
|
# define ZPL_MODULE_CORE
|
|
|
|
# define ZPL_MODULE_TIMER
|
2023-04-03 00:55:28 -07:00
|
|
|
# define ZPL_MODULE_HASHING
|
2023-04-03 23:04:19 -07:00
|
|
|
// # define ZPL_MODULE_REGEX
|
|
|
|
// # define ZPL_MODULE_EVENT
|
|
|
|
// # define ZPL_MODULE_DLL
|
|
|
|
// # define ZPL_MODULE_OPTS
|
|
|
|
// # define ZPL_MODULE_PROCESS
|
|
|
|
// # define ZPL_MODULE_MAT
|
|
|
|
// # define ZPL_MODULE_THREADING
|
|
|
|
// # define ZPL_MODULE_JOBS
|
|
|
|
// # define ZPL_MODULE_PARSER
|
2023-04-01 19:21:46 -07:00
|
|
|
#include "zpl.h"
|
|
|
|
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::s8;
|
|
|
|
using zpl::s16;
|
|
|
|
using zpl::s32;
|
|
|
|
using zpl::s64;
|
|
|
|
using zpl::u8;
|
|
|
|
using zpl::u32;
|
|
|
|
using zpl::u64;
|
|
|
|
using zpl::uw;
|
|
|
|
using zpl::sw;
|
|
|
|
|
|
|
|
using zpl::Arena;
|
|
|
|
using zpl::AllocatorInfo;
|
|
|
|
using zpl::ArrayHeader;
|
|
|
|
using zpl::FileInfo;
|
|
|
|
using zpl::FileError;
|
|
|
|
using zpl::Pool;
|
|
|
|
using zpl::String;
|
|
|
|
|
|
|
|
using zpl::EFileMode_WRITE;
|
|
|
|
using zpl::EFileError_NONE;
|
|
|
|
|
2023-04-09 21:38:47 -07:00
|
|
|
using zpl::alloc;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::arena_allocator;
|
|
|
|
using zpl::arena_init_from_memory;
|
|
|
|
using zpl::arena_free;
|
2023-04-10 18:33:06 -07:00
|
|
|
using zpl::bprintf;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::char_is_alpha;
|
2023-04-11 22:24:43 -07:00
|
|
|
using zpl::char_is_alphanumeric;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::char_is_space;
|
|
|
|
using zpl::crc32;
|
2023-04-10 18:33:06 -07:00
|
|
|
using zpl::free_all;
|
2023-04-11 22:24:43 -07:00
|
|
|
using zpl::memcopy;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::memset;
|
2023-04-09 21:38:47 -07:00
|
|
|
using zpl::pool_allocator;
|
|
|
|
using zpl::pool_init;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::pool_free;
|
|
|
|
using zpl::printf_va;
|
|
|
|
using zpl::printf_err_va;
|
2023-04-11 22:24:43 -07:00
|
|
|
using zpl::str_compare;
|
2023-04-09 10:59:39 -07:00
|
|
|
using zpl::snprintf_va;
|
|
|
|
using zpl::string_appendc;
|
|
|
|
using zpl::string_append_fmt;
|
|
|
|
using zpl::string_append_length;
|
|
|
|
using zpl::string_length;
|
|
|
|
using zpl::string_make;
|
|
|
|
using zpl::strnlen;
|
2023-04-09 21:38:47 -07:00
|
|
|
using zpl::exit;
|
2023-04-09 10:59:39 -07:00
|
|
|
|
|
|
|
|
2023-04-01 19:21:46 -07:00
|
|
|
#if __clang__
|
|
|
|
# pragma clang diagnostic pop
|
|
|
|
#endif
|
|
|
|
#pragma endregion ZPL INCLUDE
|
|
|
|
|
|
|
|
|
|
|
|
#if __clang__
|
|
|
|
# pragma clang diagnostic ignored "-Wunused-const-variable"
|
|
|
|
# pragma clang diagnostic ignored "-Wswitch"
|
|
|
|
# pragma clang diagnostic ignored "-Wunused-variable"
|
|
|
|
# pragma clang diagnostic ignored "-Wunknown-pragmas"
|
2023-04-05 23:21:23 -07:00
|
|
|
# pragma clang diagnostic ignored "-Wvarargs"
|
2023-04-01 19:21:46 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2023-04-05 23:21:23 -07:00
|
|
|
#if defined(__GNUC__) || defined(__clang__) || true
|
|
|
|
// Supports 0-10 arguments
|
|
|
|
#define macro_num_args_impl( _0, \
|
|
|
|
_1, _2, _3, _4, _5, _6, _7, _8, _9, _10, \
|
|
|
|
_11, _12, _13, _14, _15, _16, _17, _18, _19, _20, \
|
|
|
|
N, ... \
|
|
|
|
) N
|
|
|
|
// _21, _22, _23, _24, _25, _26, _27, _28, _29, _30, \
|
|
|
|
// _31, _32, _33, _34, _35, _36, _37, _38, _39, _40, \
|
|
|
|
// _41, _42, _43, _44, _45, _46, _47, _48, _49, _50,
|
|
|
|
|
|
|
|
// ## deletes preceding comma if _VA_ARGS__ is empty (GCC, Clang)
|
|
|
|
#define macro_num_args(...) \
|
|
|
|
macro_num_args_impl(_, ## __VA_ARGS__, \
|
|
|
|
20, 19, 18, 17, 16, 15, 14, 13, 12, 11, \
|
|
|
|
10, 9, 8, 7, 6, 5, 4, 3, 2, 1, \
|
|
|
|
0 \
|
|
|
|
)
|
|
|
|
// 50, 49, 48, 47, 46, 45, 44, 43, 42, 41, \
|
|
|
|
// 40, 39, 38, 37, 36, 35, 34, 33, 32, 31, \
|
|
|
|
// 30, 29, 28, 27, 26, 25, 24, 23, 22, 21,
|
2023-04-03 23:04:19 -07:00
|
|
|
#else
|
2023-04-05 23:21:23 -07:00
|
|
|
// Supports 1-10 arguments
|
|
|
|
#define macro_num_args_impl( \
|
|
|
|
_1, _2, _3, _4, _5, _6, _7, _8, _9, _10, \
|
|
|
|
_11, _12, _13, _14, _15, _16, _17, _18, _19, _20, \
|
|
|
|
N, ... \
|
|
|
|
) N
|
|
|
|
|
|
|
|
#define macro_num_args(...) \
|
|
|
|
macro_num_args_impl( __VA_ARGS__, \
|
|
|
|
20, 19, 18, 17, 16, 15, 14, 13, 12, 11, \
|
|
|
|
10, 9, 8, 7, 6, 5, 4, 3, 2, 1 \
|
|
|
|
)
|
2023-04-03 23:04:19 -07:00
|
|
|
#endif
|
2023-04-01 19:21:46 -07:00
|
|
|
|
2023-04-05 23:21:23 -07:00
|
|
|
#define macro_expand( Expanded_ ) Expanded_
|
|
|
|
|
2023-04-01 19:21:46 -07:00
|
|
|
#define bit( Value_ ) ( 1 << Value_ )
|
2023-04-05 00:03:56 -07:00
|
|
|
#define bitfield_is_equal( Field_, Mask_ ) ( ( (Mask_) & (Field_) ) == (Mask_) )
|
2023-04-01 19:21:46 -07:00
|
|
|
#define ct constexpr
|
|
|
|
#define forceinline ZPL_ALWAYS_INLINE
|
|
|
|
#define print_nl( _) zpl_printf("\n")
|
2023-04-05 00:03:56 -07:00
|
|
|
#define ccast( Type_, Value_ ) * const_cast< Type_* >( & (Value_) )
|
2023-04-01 19:21:46 -07:00
|
|
|
#define scast( Type_, Value_ ) static_cast< Type_ >( Value_ )
|
|
|
|
#define rcast( Type_, Value_ ) reinterpret_cast< Type_ >( Value_ )
|
2023-04-05 00:03:56 -07:00
|
|
|
#define pcast( Type_, Value_ ) ( * (Type_*)( & (Value_) ) )
|
2023-04-03 23:04:19 -07:00
|
|
|
#define txt_impl( Value_ ) #Value_
|
|
|
|
#define txt( Value_ ) txt_impl( Value_ )
|
2023-04-05 23:21:23 -07:00
|
|
|
#define txt_n_len( Value_ ) sizeof( txt_impl( Value_ ) ), txt_impl( Value_ )
|
2023-04-01 19:21:46 -07:00
|
|
|
#define do_once() \
|
|
|
|
do \
|
|
|
|
{ \
|
|
|
|
static \
|
|
|
|
bool Done = false; \
|
|
|
|
if ( Done ) \
|
|
|
|
return; \
|
|
|
|
Done = true; \
|
|
|
|
} \
|
2023-04-03 23:04:19 -07:00
|
|
|
while(0)
|
2023-04-01 19:21:46 -07:00
|
|
|
|
2023-04-02 09:35:14 -07:00
|
|
|
#define do_once_start \
|
|
|
|
do \
|
|
|
|
{ \
|
|
|
|
static \
|
|
|
|
bool Done = false; \
|
|
|
|
if ( Done ) \
|
|
|
|
break; \
|
|
|
|
Done = true;
|
|
|
|
|
|
|
|
#define do_once_end \
|
|
|
|
} \
|
|
|
|
while(0);
|
|
|
|
|
2023-04-01 19:21:46 -07:00
|
|
|
ct char const* Msg_Invalid_Value = "INVALID VALUE PROVIDED";
|
|
|
|
|
|
|
|
namespace Global
|
|
|
|
{
|
|
|
|
extern bool ShouldShowDebug;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace Memory
|
|
|
|
{
|
2023-04-01 22:07:44 -07:00
|
|
|
ct uw Initial_Reserve = megabytes(10);
|
2023-04-01 19:21:46 -07:00
|
|
|
|
2023-04-09 10:59:39 -07:00
|
|
|
extern Arena Global_Arena;
|
2023-04-02 08:53:15 -07:00
|
|
|
// #define g_allocator arena_allocator( & Memory::Global_Arena)
|
2023-04-03 23:04:19 -07:00
|
|
|
|
|
|
|
// Heap allocator is being used for now to isolate errors from being memory related (tech debt till ready to address)
|
2023-04-02 08:53:15 -07:00
|
|
|
#define g_allocator heap()
|
2023-04-01 19:21:46 -07:00
|
|
|
|
|
|
|
void setup();
|
|
|
|
void resize( uw new_size );
|
|
|
|
void cleanup();
|
|
|
|
}
|
|
|
|
|
2023-04-05 00:03:56 -07:00
|
|
|
sw token_fmt_va( char* buf, uw buf_size, char const* fmt, s32 num_tokens, va_list va );
|
|
|
|
|
2023-04-03 23:04:19 -07:00
|
|
|
inline
|
|
|
|
char const* token_fmt( char const* fmt, sw num_tokens, ... )
|
|
|
|
{
|
2023-04-05 23:21:23 -07:00
|
|
|
local_persist thread_local
|
2023-04-03 23:04:19 -07:00
|
|
|
char buf[ZPL_PRINTF_MAXLEN] = { 0 };
|
|
|
|
|
|
|
|
va_list va;
|
|
|
|
va_start(va, fmt);
|
|
|
|
token_fmt_va(buf, ZPL_PRINTF_MAXLEN, fmt, num_tokens, va);
|
|
|
|
va_end(va);
|
2023-04-01 19:21:46 -07:00
|
|
|
|
2023-04-03 23:04:19 -07:00
|
|
|
return buf;
|
|
|
|
}
|
2023-04-01 19:21:46 -07:00
|
|
|
|
|
|
|
inline
|
2023-04-05 23:21:23 -07:00
|
|
|
sw log_fmt(char const *fmt, ...)
|
2023-04-01 19:21:46 -07:00
|
|
|
{
|
|
|
|
if ( Global::ShouldShowDebug == false )
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
sw res;
|
|
|
|
va_list va;
|
2023-04-05 23:21:23 -07:00
|
|
|
|
2023-04-01 19:21:46 -07:00
|
|
|
va_start(va, fmt);
|
2023-04-09 10:59:39 -07:00
|
|
|
res = printf_va(fmt, va);
|
2023-04-01 19:21:46 -07:00
|
|
|
va_end(va);
|
2023-04-05 23:21:23 -07:00
|
|
|
|
2023-04-01 19:21:46 -07:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline
|
2023-04-05 23:21:23 -07:00
|
|
|
sw fatal(char const *fmt, ...)
|
2023-04-01 19:21:46 -07:00
|
|
|
{
|
2023-04-05 23:21:23 -07:00
|
|
|
local_persist thread_local
|
2023-04-01 19:21:46 -07:00
|
|
|
char buf[ZPL_PRINTF_MAXLEN] = { 0 };
|
|
|
|
|
|
|
|
va_list va;
|
|
|
|
|
|
|
|
#if Build_Debug
|
|
|
|
va_start(va, fmt);
|
2023-04-09 10:59:39 -07:00
|
|
|
zpl::snprintf_va(buf, ZPL_PRINTF_MAXLEN, fmt, va);
|
2023-04-01 19:21:46 -07:00
|
|
|
va_end(va);
|
|
|
|
|
|
|
|
assert_crash(buf);
|
2023-04-03 23:04:19 -07:00
|
|
|
return -1;
|
2023-04-01 19:21:46 -07:00
|
|
|
#else
|
|
|
|
va_start(va, fmt);
|
2023-04-09 10:59:39 -07:00
|
|
|
printf_err_va( fmt, va);
|
2023-04-01 19:21:46 -07:00
|
|
|
va_end(va);
|
|
|
|
|
2023-04-09 10:59:39 -07:00
|
|
|
exit(1);
|
2023-04-03 23:04:19 -07:00
|
|
|
return -1;
|
2023-04-01 19:21:46 -07:00
|
|
|
#endif
|
|
|
|
}
|
2023-04-05 00:03:56 -07:00
|
|
|
|