From 5afdd9863a0fc1d8d1d42dd2128c9978f54e12ca Mon Sep 17 00:00:00 2001 From: Katherine Kiefer Date: Wed, 3 Apr 2024 14:49:45 +1100 Subject: [PATCH] turn into lf --- .../byondapi-sys/headers/515-1609/byondapi.h | 552 ++++---- .../byondapi-sys/headers/515-1610/byondapi.h | 558 ++++---- .../byondapi-sys/headers/515-1611/byondapi.h | 592 ++++---- .../byondapi-sys/headers/515-1617/byondapi.h | 598 ++++---- .../byondapi-sys/headers/515-1620/byondapi.h | 1196 ++++++++-------- .../byondapi-sys/headers/515-1621/byondapi.h | 1218 ++++++++--------- 6 files changed, 2357 insertions(+), 2357 deletions(-) diff --git a/crates/byondapi-sys/headers/515-1609/byondapi.h b/crates/byondapi-sys/headers/515-1609/byondapi.h index 9375f4d..9b6bdf0 100644 --- a/crates/byondapi-sys/headers/515-1609/byondapi.h +++ b/crates/byondapi-sys/headers/515-1609/byondapi.h @@ -1,276 +1,276 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1609 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -DUNGPUB char const *Byond_LastError(); -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; - float num; - char *str; -}; - -/* - You MUST call one of the ByondValue_Init routines before using this - structure. - - You SHOULD call ByondValue_Free() to clean this structure up, but it's - only technically needed to clean up strings. For safety's sake, just be - sure to clean it up. - */ -struct CByondValue { - ByondValueType type; - u1c junk1, junk2, junk3; // padding - ByondValueData data; -}; - -DUNGPUB void ByondValue_Init(CByondValue *v); -DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); -DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); -DUNGPUB void ByondValue_Free(CByondValue *v); - -DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value -DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value - -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -/* - You MUST call one of the ByondValueList_Init routines before using this - structure, and you MUST call ByoundValueList_Free() to free it. - - Routines will return false if allocation fails. - */ -struct CByondValueList { - CByondValue *items; - u4c count, capacity; -}; - -DUNGPUB void ByondValueList_Init(CByondValueList *list); -DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); -DUNGPUB void ByondValueList_Free(CByondValueList *list); - -DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); -DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); - -DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); -DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); -DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list -DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list -DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - - Thread safety: - - Anything that requires reading will block if called outside of the main - thread. Write operations on the wrong thread will not block, but they will - schedule for later, return immediately, and not report failure. - */ - -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match - -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! - -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); - -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - - If called in the wrong thread, it will spawn() the proc and return null. - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1609 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +DUNGPUB char const *Byond_LastError(); +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; + float num; + char *str; +}; + +/* + You MUST call one of the ByondValue_Init routines before using this + structure. + + You SHOULD call ByondValue_Free() to clean this structure up, but it's + only technically needed to clean up strings. For safety's sake, just be + sure to clean it up. + */ +struct CByondValue { + ByondValueType type; + u1c junk1, junk2, junk3; // padding + ByondValueData data; +}; + +DUNGPUB void ByondValue_Init(CByondValue *v); +DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); +DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); +DUNGPUB void ByondValue_Free(CByondValue *v); + +DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value +DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value + +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +/* + You MUST call one of the ByondValueList_Init routines before using this + structure, and you MUST call ByoundValueList_Free() to free it. + + Routines will return false if allocation fails. + */ +struct CByondValueList { + CByondValue *items; + u4c count, capacity; +}; + +DUNGPUB void ByondValueList_Init(CByondValueList *list); +DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); +DUNGPUB void ByondValueList_Free(CByondValueList *list); + +DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); +DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); + +DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); +DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); +DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list +DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list +DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + + Thread safety: + + Anything that requires reading will block if called outside of the main + thread. Write operations on the wrong thread will not block, but they will + schedule for later, return immediately, and not report failure. + */ + +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match + +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! + +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); + +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + + If called in the wrong thread, it will spawn() the proc and return null. + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H diff --git a/crates/byondapi-sys/headers/515-1610/byondapi.h b/crates/byondapi-sys/headers/515-1610/byondapi.h index b6098b0..d277d34 100644 --- a/crates/byondapi-sys/headers/515-1610/byondapi.h +++ b/crates/byondapi-sys/headers/515-1610/byondapi.h @@ -1,279 +1,279 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1609 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -DUNGPUB char const *Byond_LastError(); -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; - float num; - char *str; -}; - -/* - You MUST call one of the ByondValue_Init routines before using this - structure. - - You SHOULD call ByondValue_Free() to clean this structure up, but it's - only technically needed to clean up strings. For safety's sake, just be - sure to clean it up. - */ -struct CByondValue { - ByondValueType type; - u1c junk1, junk2, junk3; // padding - ByondValueData data; -}; - -DUNGPUB void ByondValue_Init(CByondValue *v); -DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); -DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); -DUNGPUB void ByondValue_Free(CByondValue *v); - -DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value -DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value - -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -/* - You MUST call one of the ByondValueList_Init routines before using this - structure, and you MUST call ByoundValueList_Free() to free it. - - Routines will return false if allocation fails. - */ -struct CByondValueList { - CByondValue *items; - u4c count, capacity; -}; - -DUNGPUB void ByondValueList_Init(CByondValueList *list); -DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); -DUNGPUB void ByondValueList_Free(CByondValueList *list); - -DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); -DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); - -DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); -DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); -DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list -DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list -DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - - Thread safety: - - Anything that requires reading will block if called outside of the main - thread. Write operations on the wrong thread will not block, but they will - schedule for later, return immediately, and not report failure. - */ - -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match - -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! - -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); - -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - - If called in the wrong thread, it will spawn() the proc and return null. - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -// Use BYOND's internal value-to-text conversion -DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1609 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +DUNGPUB char const *Byond_LastError(); +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; + float num; + char *str; +}; + +/* + You MUST call one of the ByondValue_Init routines before using this + structure. + + You SHOULD call ByondValue_Free() to clean this structure up, but it's + only technically needed to clean up strings. For safety's sake, just be + sure to clean it up. + */ +struct CByondValue { + ByondValueType type; + u1c junk1, junk2, junk3; // padding + ByondValueData data; +}; + +DUNGPUB void ByondValue_Init(CByondValue *v); +DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); +DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); +DUNGPUB void ByondValue_Free(CByondValue *v); + +DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value +DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value + +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +/* + You MUST call one of the ByondValueList_Init routines before using this + structure, and you MUST call ByoundValueList_Free() to free it. + + Routines will return false if allocation fails. + */ +struct CByondValueList { + CByondValue *items; + u4c count, capacity; +}; + +DUNGPUB void ByondValueList_Init(CByondValueList *list); +DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); +DUNGPUB void ByondValueList_Free(CByondValueList *list); + +DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); +DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); + +DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); +DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); +DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list +DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list +DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + + Thread safety: + + Anything that requires reading will block if called outside of the main + thread. Write operations on the wrong thread will not block, but they will + schedule for later, return immediately, and not report failure. + */ + +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match + +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! + +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); + +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + + If called in the wrong thread, it will spawn() the proc and return null. + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +// Use BYOND's internal value-to-text conversion +DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H diff --git a/crates/byondapi-sys/headers/515-1611/byondapi.h b/crates/byondapi-sys/headers/515-1611/byondapi.h index c925c13..42bc7bc 100644 --- a/crates/byondapi-sys/headers/515-1611/byondapi.h +++ b/crates/byondapi-sys/headers/515-1611/byondapi.h @@ -1,296 +1,296 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1609 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -DUNGPUB char const *Byond_LastError(); -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; - float num; - char *str; -}; - -/* - You MUST call one of the ByondValue_Init routines before using this - structure. - - You SHOULD call ByondValue_Free() to clean this structure up, but it's - only technically needed to clean up strings. For safety's sake, just be - sure to clean it up. - */ -struct CByondValue { - ByondValueType type; - u1c junk1, junk2, junk3; // padding - ByondValueData data; -}; - -DUNGPUB void ByondValue_Init(CByondValue *v); -DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); -DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); -DUNGPUB void ByondValue_Free(CByondValue *v); - -DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value -DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value - -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -/* - You MUST call one of the ByondValueList_Init routines before using this - structure, and you MUST call ByoundValueList_Free() to free it. - - Routines will return false if allocation fails. - */ -struct CByondValueList { - CByondValue *items; - u4c count, capacity; -}; - -DUNGPUB void ByondValueList_Init(CByondValueList *list); -DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); -DUNGPUB void ByondValueList_Free(CByondValueList *list); - -DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); -DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); - -DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); // will grow capacity if needed, preferring 25% increase -DUNGPUB bool ByondValueList_SetCapacity(CByondValueList *list, u4c capacity); -DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); -DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list -DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list -DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items - -// Other useful structs - -struct CByondXYZ { - s2c x, y, z, junk; -}; - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - - Thread safety: - - Anything that requires reading will block if called outside of the main - thread. Write operations on the wrong thread will not block, but they will - schedule for later, return immediately, and not report failure. - */ - -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match - -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! - -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); - -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - - If called in the wrong thread, it will spawn() the proc and return null. - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -// Use BYOND's internal value-to-text conversion -DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! - -// Other builtins -DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValueList *result); // result MUST be initialized first! -DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); // result MUST be initialized first!; list may be a null pointer -DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_Refcount(CByondValue const *type, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1609 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +DUNGPUB char const *Byond_LastError(); +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; + float num; + char *str; +}; + +/* + You MUST call one of the ByondValue_Init routines before using this + structure. + + You SHOULD call ByondValue_Free() to clean this structure up, but it's + only technically needed to clean up strings. For safety's sake, just be + sure to clean it up. + */ +struct CByondValue { + ByondValueType type; + u1c junk1, junk2, junk3; // padding + ByondValueData data; +}; + +DUNGPUB void ByondValue_Init(CByondValue *v); +DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); +DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); +DUNGPUB void ByondValue_Free(CByondValue *v); + +DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value +DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value + +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +/* + You MUST call one of the ByondValueList_Init routines before using this + structure, and you MUST call ByoundValueList_Free() to free it. + + Routines will return false if allocation fails. + */ +struct CByondValueList { + CByondValue *items; + u4c count, capacity; +}; + +DUNGPUB void ByondValueList_Init(CByondValueList *list); +DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); +DUNGPUB void ByondValueList_Free(CByondValueList *list); + +DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); +DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); + +DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); // will grow capacity if needed, preferring 25% increase +DUNGPUB bool ByondValueList_SetCapacity(CByondValueList *list, u4c capacity); +DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); +DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list +DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list +DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items + +// Other useful structs + +struct CByondXYZ { + s2c x, y, z, junk; +}; + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + + Thread safety: + + Anything that requires reading will block if called outside of the main + thread. Write operations on the wrong thread will not block, but they will + schedule for later, return immediately, and not report failure. + */ + +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match + +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! + +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); + +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + + If called in the wrong thread, it will spawn() the proc and return null. + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +// Use BYOND's internal value-to-text conversion +DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! + +// Other builtins +DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValueList *result); // result MUST be initialized first! +DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); // result MUST be initialized first!; list may be a null pointer +DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_Refcount(CByondValue const *type, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H diff --git a/crates/byondapi-sys/headers/515-1617/byondapi.h b/crates/byondapi-sys/headers/515-1617/byondapi.h index a4b3d80..c17fa7b 100644 --- a/crates/byondapi-sys/headers/515-1617/byondapi.h +++ b/crates/byondapi-sys/headers/515-1617/byondapi.h @@ -1,299 +1,299 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1609 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -DUNGPUB char const *Byond_LastError(); -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; - float num; - char *str; -}; - -/* - You MUST call one of the ByondValue_Init routines before using this - structure. - - You SHOULD call ByondValue_Free() to clean this structure up, but it's - only technically needed to clean up strings. For safety's sake, just be - sure to clean it up. - */ -struct CByondValue { - ByondValueType type; - u1c junk1, junk2, junk3; // padding - ByondValueData data; -}; - -DUNGPUB void ByondValue_Init(CByondValue *v); -DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); -DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); -DUNGPUB void ByondValue_Free(CByondValue *v); - -DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value -DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value - -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -/* - You MUST call one of the ByondValueList_Init routines before using this - structure, and you MUST call ByoundValueList_Free() to free it. - - Routines will return false if allocation fails. - */ -struct CByondValueList { - CByondValue *items; - u4c count, capacity; -}; - -DUNGPUB void ByondValueList_Init(CByondValueList *list); -DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); -DUNGPUB void ByondValueList_Free(CByondValueList *list); - -DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); -DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); - -DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); // will grow capacity if needed, preferring 25% increase -DUNGPUB bool ByondValueList_SetCapacity(CByondValueList *list, u4c capacity); -DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); -DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list -DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list -DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items - -// Other useful structs - -struct CByondXYZ { - s2c x, y, z, junk; -}; - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - - Thread safety: - - Anything that requires reading will block if called outside of the main - thread. Write operations on the wrong thread will not block, but they will - schedule for later, return immediately, and not report failure. - */ - -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match - -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! - -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); - -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - - If called in the wrong thread, it will spawn() the proc and return null. - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -// Use BYOND's internal value-to-text conversion -DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! - -// Other builtins -DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValueList *result); // result MUST be initialized first! -DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); // result MUST be initialized first!; list may be a null pointer -DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_Refcount(CByondValue const *type, CByondValue *result); // result MUST be initialized first! -DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1609 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +DUNGPUB char const *Byond_LastError(); +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; + float num; + char *str; +}; + +/* + You MUST call one of the ByondValue_Init routines before using this + structure. + + You SHOULD call ByondValue_Free() to clean this structure up, but it's + only technically needed to clean up strings. For safety's sake, just be + sure to clean it up. + */ +struct CByondValue { + ByondValueType type; + u1c junk1, junk2, junk3; // padding + ByondValueData data; +}; + +DUNGPUB void ByondValue_Init(CByondValue *v); +DUNGPUB void ByondValue_InitNum(CByondValue *v, float num); +DUNGPUB bool ByondValue_InitStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_InitRef(CByondValue *v, ByondValueType type, u4c ref); +DUNGPUB void ByondValue_Free(CByondValue *v); + +DUNGPUB void ByondValue_CopyFrom(CByondValue *dst, CByondValue const *src); // frees dst's old value +DUNGPUB void ByondValue_MoveFrom(CByondValue *dst, CByondValue *src); // frees src after copy, and frees dst's old value + +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +DUNGPUB char const *ByondValue_GetStr(CByondValue const *v); +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +DUNGPUB bool ByondValue_SetStr(CByondValue *v, char const *str); +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +/* + You MUST call one of the ByondValueList_Init routines before using this + structure, and you MUST call ByoundValueList_Free() to free it. + + Routines will return false if allocation fails. + */ +struct CByondValueList { + CByondValue *items; + u4c count, capacity; +}; + +DUNGPUB void ByondValueList_Init(CByondValueList *list); +DUNGPUB bool ByondValueList_InitCount(CByondValueList *list, u4c count); +DUNGPUB void ByondValueList_Free(CByondValueList *list); + +DUNGPUB bool ByondValueList_CopyFrom(CByondValueList *dst, CByondValueList const *src); +DUNGPUB void ByondValueList_MoveFrom(CByondValueList *dst, CByondValueList *src); + +DUNGPUB bool ByondValueList_SetCount(CByondValueList *list, u4c count); // will grow capacity if needed, preferring 25% increase +DUNGPUB bool ByondValueList_SetCapacity(CByondValueList *list, u4c capacity); +DUNGPUB bool ByondValueList_Add(CByondValueList *list, CByondValue const *v); +DUNGPUB bool ByondValueList_InsertAt(CByondValueList *list, int idx, CByondValue const *v); // idx < 0 means end of list +DUNGPUB bool ByondValueList_Splice(CByondValueList *list, int idx, u4c delete_count, CByondValue const *v=0, u4c insert_count=0); // idx < 0 means end of list +DUNGPUB u4c ByondValueList_RemoveAt(CByondValueList *list, u4c idx, u4c n=1); // returns # of removed items + +// Other useful structs + +struct CByondXYZ { + s2c x, y, z, junk; +}; + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + + Thread safety: + + Anything that requires reading will block if called outside of the main + thread. Write operations on the wrong thread will not block, but they will + schedule for later, return immediately, and not report failure. + */ + +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match + +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +DUNGPUB bool Byond_CreateList(CByondValue *result); // result MUST be initialized first! + +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValueList *list); // list MUST be initialized first! +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValueList const *list); + +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + + If called in the wrong thread, it will spawn() the proc and return null. + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +// Use BYOND's internal value-to-text conversion +DUNGPUB bool Byond_ToString(CByondValue const *src, CByondValue *result); // result MUST be initialized first! + +// Other builtins +DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValueList *result); // result MUST be initialized first! +DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); // result MUST be initialized first!; list may be a null pointer +DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_Refcount(CByondValue const *type, CByondValue *result); // result MUST be initialized first! +DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H diff --git a/crates/byondapi-sys/headers/515-1620/byondapi.h b/crates/byondapi-sys/headers/515-1620/byondapi.h index 6d09582..894eb2d 100644 --- a/crates/byondapi-sys/headers/515-1620/byondapi.h +++ b/crates/byondapi-sys/headers/515-1620/byondapi.h @@ -1,598 +1,598 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1620 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -#ifdef WIN32 -#define THREAD_VAR __declspec(thread) -#else -#define THREAD_VAR __thread -#endif - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -/** - * Gets the last error from a failed call - * The result is a static string that does not need to be freed. - * @return Error message - */ -DUNGPUB char const *Byond_LastError(); - -/** - * Gets the current BYOND version - * @param Pointer to the major version number - * @param Pointer to the build number - */ -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -/** - * Gets the DMB version - * @return Version number the .dmb was built with - */ -DUNGPUB u4c Byond_GetDMBVersion(); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; //!< 4-byte reference ID - float num; //!< floating-point number -}; - -struct CByondValue { - ByondValueType type; //!< 1-byte intrinsic data type - u1c junk1, junk2, junk3; //!< padding - ByondValueData data; //!< 4-byte reference ID or floating point number -}; - -/** - * Fills a CByondValue struct with a null value. - * @param Pointer to CByondValue - */ -DUNGPUB void ByondValue_Clear(CByondValue *v); - -/** - * Reads CByondVale's 1-byte data type - * @param Pointer to CByondValue - * @return Type of value - */ -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); - -/** - * @param Pointer to CByondValue - * @return True if value is null - */ -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -/** - * @param Pointer to CByondValue - * @return True if value is a numeric type - */ -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -/** - * @param Pointer to CByondValue - * @return True if value is a string - */ -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -/** - * @param Pointer to CByondValue - * @return True if value is a list (any list type, not just user-defined) - */ -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -/** - * Determines if a value is logically true or false - * - * @param Pointer to CByondValue - * @return Truthiness of value - */ -//bool ByondValue_IsTrue(CByondValue const *v); - -/** - * @param Pointer to CByondValue - * @return Floating point number for v, or 0 if not numeric - */ -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -/** - * @param Pointer to CByondValue - * @return Reference ID if value is a reference type, or 0 otherwise - */ -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -/** - * Fills a CByondValue struct with a floating point number. - * @param Pointer to CByondValue - * @param Floating point number - */ -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -/** - * Creates a string and sets CByondValue to a temporary reference to that string. - * Blocks if not on the main thread. If string creation fails, the struct is set to null. - * @param Pointer to CByondValue - * @param Null-terminated UTF-8 string - * @see Byond_AddGetStrId() - */ -DUNGPUB void ByondValue_SetStr(CByondValue *v, char const *str); -/** - * Fills a CByondValue struct with a reference (object) type. Does not validate. - * @param Pointer to CByondValue - * @param 1-byte teference type - * @param 4-byte reference ID; for most types, an ID of NONE is invalid - * @see Byond_TestRef() - */ -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -/** - * Compares two values for equality - * @param Pointer to CByondValue - * @param Pointer to CByondValue - * @return True if values are equal - */ -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -// Other useful structs - -struct CByondXYZ { - s2c x, y, z; //!< signed 2-byte integer coordinates - s2c junk; //!< padding -}; - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - Thread safety: - - Anything called outside of the main thread will block, unless otherwise - noted. - */ - -typedef CByondValue (*ByondCallback)(void *); -/** - * Runs a function as a callback on the main thread (or right away if already there) - * Blocks until function is completed. - * @param Function pointer to u4c function(void*) - * @param Void pointer (argument to function) - * @param True if this call should wait for the callback to finish and use the result; false if not - * @return User-defined 4-byte integer; returns 0 if non-blocking and not on the main thread - */ -DUNGPUB CByondValue Byond_ThreadSync(ByondCallback callback, void *data, bool block=false); - -/** - * Returns a reference to an existing string ID, but does not create a new string ID. - * Blocks if not on the main thread. - * @param Null-terminated string - * @return ID of string; NONE if string does not exist - */ -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match -/** - * Returns a reference to an existing string ID or creates a new string ID with a temporary reference. - * Blocks if not on the main thread. - * @param Null-terminated string - * @return ID of string; NONE if string creation failed - */ -DUNGPUB u4c Byond_AddGetStrId(char const *str); // adds a string to the tree if not found - -/** - * Reads an object variable by name. - * Blocks if not on the main thread. - * @param Object that owns the var - * @param Var name as null-terminated string - * @param Pointer to result - * @return True on success - */ -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); -/** - * Reads an object variable by the string ID of its var name. - * ID can be cached ahead of time for performance. - * Blocks if not on the main thread. - * @param Object that owns the var - * @param Var name as string ID - * @param Pointer to result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); -/** - * Writes an object variable by name. - * Blocks if not on the main thread. - * @param Object that owns the var - * @param Var name as null-terminated string - * @param New value - * @return True on success - */ -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -/** - * Writes an object variable by the string ID of its var name. - * ID can be cached ahead of time for performance. - * Blocks if not on the main thread. - * @param Object that owns the var - * @param Var name as string ID - * @param New value - * @return True on success - */ -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -/** - * Creates an empty list with a temporary reference. Equivalent to list(). - * Blocks if not on the main thread. - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_CreateList(CByondValue *result); - -/** - * Reads items from a list. - * Blocks if not on the main thread. - * @param The list - * @param CByondValue array, allocated by caller (can be null if querying length) - * @param Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValue *list, u4c *len); - -/** - * Writes items to a list, in place of old contents. - * Blocks if not on the main thread. - * @param The list - * @param CByondValue array - * @param Number of items to write - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValue const *list, u4c len); - -/** - * Reads an item from a list. - * Blocks if not on the main thread. - * @param The list - * @param The index in the list (may be a number, or a non-number if using associative lists) - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); -/** - * Writes an item to a list. - * Blocks if not on the main thread. - * @param The list - * @param The index in the list (may be a number, or a non-number if using associative lists) - * @param New value - * @return True on success - */ -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -/** - * Reads from a BYOND pointer - * Blocks if not on the main thread. - * @param The pointer - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); -/** - * Writes to a BYOND pointer - * Blocks if not on the main thread. - * @param The pointer - * @param New value - * @return True on success - */ -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - */ - -/** - * Calls an object proc by name. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param The object that owns the proc - * @param Proc name as null-terminated string - * @param Array of arguments - * @param Number of arguments - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); -/** - * Calls an object proc by name, where the name is a string ID. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param The object that owns the proc - * @param Proc name as string ID - * @param Array of arguments - * @param Number of arguments - * @param Result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); - -/** - * Calls a global proc by name. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param Proc name as null-terminated string - * @param Array of arguments - * @param Number of arguments - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -/** - * Calls a global proc by name, where the name is a string ID. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param Proc name as string ID - * @param Array of arguments - * @param Number of arguments - * @param Result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -/** - * Uses BYOND's internals to represent a value as text - * Blocks if not on the main thread. - * @param The value to convert to text - * @param char array, allocated by caller (can be null if querying length) - * @param Pointer to length of array in bytes; receives the string length (including trailing null) on success, or required length of array if not big enough - * @return True on success; false with *buflen=0 for failure; false with *buflen=required size if array is not big enough - */ -DUNGPUB bool Byond_ToString(CByondValue const *src, char *buf, u4c *buflen); - -// Other builtins - -/** - * Equivalent to calling block(x1,y1,z1, x2,y2,z2). - * Blocks if not on the main thread. - * @param One corner of the block - * @param Another corner of the block - * @param CByondValue array, allocated by caller (can be null if querying length) - * @param Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValue *list, u4c *len); - -/** - * Equivalent to calling length(value). - * Blocks if not on the main thread. - * @param The value - * @param Result, as a CByondValue (intended for future possible override of length) - * @return True on success - */ -DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); - -/** - * Equivalent to calling locate(type), or locate(type) in list. - * Blocks if not on the main thread. - * @param The type to locate - * @param The list to locate in; can be a null pointer instead of a CByondValue to locate(type) without a list - * @param Result; can be null if nothing is found - * @return True on success (including if nothing is found); false on error - */ -DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); - -/** - * Equivalent to calling locate(x,y,z) - * Blocks if not on the main thread. - * @param The x,y,z coords - * @param Result; can be null if coords are invalid - * @return True (always) - */ -DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); - -/** - * Equivalent to calling new type(...) - * Blocks if not on the main thread. - * @param The type to create (type path or string) - * @param Array of arguments - * @param Number of arguments - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); - -/** - * Equivalent to calling new type(arglist) - * Blocks if not on the main thread. - * @param The type to create (type path or string) - * @param Arguments, as a reference to an arglist - * @param Result - * @return True on success - */ -DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! - -/** - * Equivalent to calling refcount(value) - * Blocks if not on the main thread. - * @param The object to refcount - * @param Pointer to store result - * @return True on success - */ -DUNGPUB bool Byond_Refcount(CByondValue const *src, u4c *result); // result MUST be initialized first! - -/** - * Get x,y,z coords of an atom - * Blocks if not on the main thread. - * @param The object to read - * @param ointer to CByondXYZ result - * @return True on success - */ -DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ - -/** - * Mark a reference as in use by Byondapi - * This should be done for any temporary references returned from other calls, if they need to be saved awhile. - * Blocks if not on the main thread. - * @param The object to incref - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); - -/** - * Mark a reference as no longer in use by Byondapi - * This can be used for temporary references to let them go immediately. - * Blocks if not on the main thread. - * @param The object to decref - */ -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -/** - * Test if a reference-type CByondValue is valid - * Blocks if not on the main thread. - * @param Pointer to the reference to test; will be filled with null if the reference is invalid - * @return True if ref is valid; false if not - */ -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1620 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +#ifdef WIN32 +#define THREAD_VAR __declspec(thread) +#else +#define THREAD_VAR __thread +#endif + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +/** + * Gets the last error from a failed call + * The result is a static string that does not need to be freed. + * @return Error message + */ +DUNGPUB char const *Byond_LastError(); + +/** + * Gets the current BYOND version + * @param Pointer to the major version number + * @param Pointer to the build number + */ +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +/** + * Gets the DMB version + * @return Version number the .dmb was built with + */ +DUNGPUB u4c Byond_GetDMBVersion(); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; //!< 4-byte reference ID + float num; //!< floating-point number +}; + +struct CByondValue { + ByondValueType type; //!< 1-byte intrinsic data type + u1c junk1, junk2, junk3; //!< padding + ByondValueData data; //!< 4-byte reference ID or floating point number +}; + +/** + * Fills a CByondValue struct with a null value. + * @param Pointer to CByondValue + */ +DUNGPUB void ByondValue_Clear(CByondValue *v); + +/** + * Reads CByondVale's 1-byte data type + * @param Pointer to CByondValue + * @return Type of value + */ +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); + +/** + * @param Pointer to CByondValue + * @return True if value is null + */ +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +/** + * @param Pointer to CByondValue + * @return True if value is a numeric type + */ +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +/** + * @param Pointer to CByondValue + * @return True if value is a string + */ +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +/** + * @param Pointer to CByondValue + * @return True if value is a list (any list type, not just user-defined) + */ +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +/** + * Determines if a value is logically true or false + * + * @param Pointer to CByondValue + * @return Truthiness of value + */ +//bool ByondValue_IsTrue(CByondValue const *v); + +/** + * @param Pointer to CByondValue + * @return Floating point number for v, or 0 if not numeric + */ +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +/** + * @param Pointer to CByondValue + * @return Reference ID if value is a reference type, or 0 otherwise + */ +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +/** + * Fills a CByondValue struct with a floating point number. + * @param Pointer to CByondValue + * @param Floating point number + */ +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +/** + * Creates a string and sets CByondValue to a temporary reference to that string. + * Blocks if not on the main thread. If string creation fails, the struct is set to null. + * @param Pointer to CByondValue + * @param Null-terminated UTF-8 string + * @see Byond_AddGetStrId() + */ +DUNGPUB void ByondValue_SetStr(CByondValue *v, char const *str); +/** + * Fills a CByondValue struct with a reference (object) type. Does not validate. + * @param Pointer to CByondValue + * @param 1-byte teference type + * @param 4-byte reference ID; for most types, an ID of NONE is invalid + * @see Byond_TestRef() + */ +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +/** + * Compares two values for equality + * @param Pointer to CByondValue + * @param Pointer to CByondValue + * @return True if values are equal + */ +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +// Other useful structs + +struct CByondXYZ { + s2c x, y, z; //!< signed 2-byte integer coordinates + s2c junk; //!< padding +}; + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + Thread safety: + + Anything called outside of the main thread will block, unless otherwise + noted. + */ + +typedef CByondValue (*ByondCallback)(void *); +/** + * Runs a function as a callback on the main thread (or right away if already there) + * Blocks until function is completed. + * @param Function pointer to u4c function(void*) + * @param Void pointer (argument to function) + * @param True if this call should wait for the callback to finish and use the result; false if not + * @return User-defined 4-byte integer; returns 0 if non-blocking and not on the main thread + */ +DUNGPUB CByondValue Byond_ThreadSync(ByondCallback callback, void *data, bool block=false); + +/** + * Returns a reference to an existing string ID, but does not create a new string ID. + * Blocks if not on the main thread. + * @param Null-terminated string + * @return ID of string; NONE if string does not exist + */ +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match +/** + * Returns a reference to an existing string ID or creates a new string ID with a temporary reference. + * Blocks if not on the main thread. + * @param Null-terminated string + * @return ID of string; NONE if string creation failed + */ +DUNGPUB u4c Byond_AddGetStrId(char const *str); // adds a string to the tree if not found + +/** + * Reads an object variable by name. + * Blocks if not on the main thread. + * @param Object that owns the var + * @param Var name as null-terminated string + * @param Pointer to result + * @return True on success + */ +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); +/** + * Reads an object variable by the string ID of its var name. + * ID can be cached ahead of time for performance. + * Blocks if not on the main thread. + * @param Object that owns the var + * @param Var name as string ID + * @param Pointer to result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); +/** + * Writes an object variable by name. + * Blocks if not on the main thread. + * @param Object that owns the var + * @param Var name as null-terminated string + * @param New value + * @return True on success + */ +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +/** + * Writes an object variable by the string ID of its var name. + * ID can be cached ahead of time for performance. + * Blocks if not on the main thread. + * @param Object that owns the var + * @param Var name as string ID + * @param New value + * @return True on success + */ +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +/** + * Creates an empty list with a temporary reference. Equivalent to list(). + * Blocks if not on the main thread. + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_CreateList(CByondValue *result); + +/** + * Reads items from a list. + * Blocks if not on the main thread. + * @param The list + * @param CByondValue array, allocated by caller (can be null if querying length) + * @param Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValue *list, u4c *len); + +/** + * Writes items to a list, in place of old contents. + * Blocks if not on the main thread. + * @param The list + * @param CByondValue array + * @param Number of items to write + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValue const *list, u4c len); + +/** + * Reads an item from a list. + * Blocks if not on the main thread. + * @param The list + * @param The index in the list (may be a number, or a non-number if using associative lists) + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); +/** + * Writes an item to a list. + * Blocks if not on the main thread. + * @param The list + * @param The index in the list (may be a number, or a non-number if using associative lists) + * @param New value + * @return True on success + */ +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +/** + * Reads from a BYOND pointer + * Blocks if not on the main thread. + * @param The pointer + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); +/** + * Writes to a BYOND pointer + * Blocks if not on the main thread. + * @param The pointer + * @param New value + * @return True on success + */ +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + */ + +/** + * Calls an object proc by name. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param The object that owns the proc + * @param Proc name as null-terminated string + * @param Array of arguments + * @param Number of arguments + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); +/** + * Calls an object proc by name, where the name is a string ID. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param The object that owns the proc + * @param Proc name as string ID + * @param Array of arguments + * @param Number of arguments + * @param Result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); + +/** + * Calls a global proc by name. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param Proc name as null-terminated string + * @param Array of arguments + * @param Number of arguments + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +/** + * Calls a global proc by name, where the name is a string ID. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param Proc name as string ID + * @param Array of arguments + * @param Number of arguments + * @param Result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +/** + * Uses BYOND's internals to represent a value as text + * Blocks if not on the main thread. + * @param The value to convert to text + * @param char array, allocated by caller (can be null if querying length) + * @param Pointer to length of array in bytes; receives the string length (including trailing null) on success, or required length of array if not big enough + * @return True on success; false with *buflen=0 for failure; false with *buflen=required size if array is not big enough + */ +DUNGPUB bool Byond_ToString(CByondValue const *src, char *buf, u4c *buflen); + +// Other builtins + +/** + * Equivalent to calling block(x1,y1,z1, x2,y2,z2). + * Blocks if not on the main thread. + * @param One corner of the block + * @param Another corner of the block + * @param CByondValue array, allocated by caller (can be null if querying length) + * @param Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValue *list, u4c *len); + +/** + * Equivalent to calling length(value). + * Blocks if not on the main thread. + * @param The value + * @param Result, as a CByondValue (intended for future possible override of length) + * @return True on success + */ +DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); + +/** + * Equivalent to calling locate(type), or locate(type) in list. + * Blocks if not on the main thread. + * @param The type to locate + * @param The list to locate in; can be a null pointer instead of a CByondValue to locate(type) without a list + * @param Result; can be null if nothing is found + * @return True on success (including if nothing is found); false on error + */ +DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); + +/** + * Equivalent to calling locate(x,y,z) + * Blocks if not on the main thread. + * @param The x,y,z coords + * @param Result; can be null if coords are invalid + * @return True (always) + */ +DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); + +/** + * Equivalent to calling new type(...) + * Blocks if not on the main thread. + * @param The type to create (type path or string) + * @param Array of arguments + * @param Number of arguments + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *argA, u4c argS, CByondValue *result); + +/** + * Equivalent to calling new type(arglist) + * Blocks if not on the main thread. + * @param The type to create (type path or string) + * @param Arguments, as a reference to an arglist + * @param Result + * @return True on success + */ +DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! + +/** + * Equivalent to calling refcount(value) + * Blocks if not on the main thread. + * @param The object to refcount + * @param Pointer to store result + * @return True on success + */ +DUNGPUB bool Byond_Refcount(CByondValue const *src, u4c *result); // result MUST be initialized first! + +/** + * Get x,y,z coords of an atom + * Blocks if not on the main thread. + * @param The object to read + * @param ointer to CByondXYZ result + * @return True on success + */ +DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ + +/** + * Mark a reference as in use by Byondapi + * This should be done for any temporary references returned from other calls, if they need to be saved awhile. + * Blocks if not on the main thread. + * @param The object to incref + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); + +/** + * Mark a reference as no longer in use by Byondapi + * This can be used for temporary references to let them go immediately. + * Blocks if not on the main thread. + * @param The object to decref + */ +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +/** + * Test if a reference-type CByondValue is valid + * Blocks if not on the main thread. + * @param Pointer to the reference to test; will be filled with null if the reference is invalid + * @return True if ref is valid; false if not + */ +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H diff --git a/crates/byondapi-sys/headers/515-1621/byondapi.h b/crates/byondapi-sys/headers/515-1621/byondapi.h index 4e76454..2cc5420 100644 --- a/crates/byondapi-sys/headers/515-1621/byondapi.h +++ b/crates/byondapi-sys/headers/515-1621/byondapi.h @@ -1,609 +1,609 @@ -#ifndef BYONDAPI_H -#define BYONDAPI_H - -/* - BYOND public API version 515.1621 - - Because for some reason nobody can get their ducks in a row, all of the - exported functions from byondcore.dll/libbyond.so are limited to C - conventions only. A header and source file for C++ wrappers is available - for inclusion in your projects. - */ - -#if defined(WIN32) || defined(WIN64) -#define IS_WINDOWS -#else -#define IS_LINUX -#endif - - -// See https://github.com/cpredef/predef/blob/master/Architectures.md -#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) -#define _X86 -#define _X86ORX64 -#define DM_32BIT -#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) -#define _X64 -#define _X86ORX64 -#define DM_64BIT -#elif defined(__arm__) || defined(_M_ARM) -#define _ARM -#if defined(__LP64__) || defined(_LP64) -#define DM_64BIT -#else -#define DM_32BIT -#endif -#endif - - - -/*types*/ -typedef unsigned char u1c; -typedef signed char s1c; -typedef unsigned short u2c; -typedef signed short s2c; -#ifdef DM_64BIT -typedef unsigned int u4c; -typedef signed int s4c; -#else -typedef unsigned long u4c; -typedef signed long s4c; -#endif - -#if defined(_MSC_VER) || defined(__BORLANDC__) - typedef __int64 s8c; - typedef unsigned __int64 u8c; -#else - typedef long long int s8c; - typedef unsigned long long int u8c; -#endif - -union u4cOrPointer { - u4c num; - void *ptr; -}; - -#ifdef __GNUC__ -#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) -#else -#define GCC_VERSION 0 -#endif - - -// determine if move-constructor and move-assignment are supported -#if defined(_MSC_VER) && _MSC_VER >= 1800 -#define _SUPPORT_MOVES -#elif defined(__GNUC__) && GCC_VERSION >= 50000 -#define _SUPPORT_MOVES -#endif - - -#define u1cMASK ((u1c)0xff) -#define u2cMASK ((u2c)0xffff) -#define u3cMASK ((u4c)0xffffffL) -#define u4cMASK ((u4c)0xffffffffL) - -#define u1cMAX u1cMASK -#define u2cMAX u2cMASK -#define u3cMAX u3cMASK -#define u4cMAX u4cMASK - -#define s1cMAX 0x7f -#define s1cMIN (-0x7f) -#define s2cMAX 0x7fff -#define s2cMIN (-0x7fff) -#define s4cMAX 0x7fffffffL -#define s4cMIN (-0x7fffffffL) - -#define NONE u2cMAX -#define NOCH u1cMAX - -#ifdef WIN32 -#define THREAD_VAR __declspec(thread) -#else -#define THREAD_VAR __thread -#endif - -/* dll export stuff */ -#ifdef WIN32 -#define DUNGPUB __declspec(dllimport) -#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() -#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols -#define DUNGPUB -#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() -#endif - - -// ByondValue - -/* - Many of the routines in this library return a bool value. If true, the - operation succeeded. If false, it failed and calling Byond_LastError() will - return an error string. - - The C++ wrappers change this true/false behavior to raise exceptions instead. - This would be preferable across the board but throwing exceptions across - module boundaries is bad juju. - */ - -extern "C" { - -/** - * Gets the last error from a failed call - * The result is a static string that does not need to be freed. - * @return Error message - */ -DUNGPUB char const *Byond_LastError(); - -/** - * Gets the current BYOND version - * @param version Pointer to the major version number - * @param build Pointer to the build number - */ -DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); - -/** - * Gets the DMB version - * @return Version number the .dmb was built with - */ -DUNGPUB u4c Byond_GetDMBVersion(); - -typedef u1c ByondValueType; -union ByondValueData { - u4c ref; //!< 4-byte reference ID - float num; //!< floating-point number -}; - -struct CByondValue { - ByondValueType type; //!< 1-byte intrinsic data type - u1c junk1, junk2, junk3; //!< padding - ByondValueData data; //!< 4-byte reference ID or floating point number -}; - -/** - * Fills a CByondValue struct with a null value. - * @param v Pointer to CByondValue - */ -DUNGPUB void ByondValue_Clear(CByondValue *v); - -/** - * Reads CByondVale's 1-byte data type - * @param v Pointer to CByondValue - * @return Type of value - */ -DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); - -/** - * @param v Pointer to CByondValue - * @return True if value is null - */ -DUNGPUB bool ByondValue_IsNull(CByondValue const *v); -/** - * @param v Pointer to CByondValue - * @return True if value is a numeric type - */ -DUNGPUB bool ByondValue_IsNum(CByondValue const *v); -/** - * @param v Pointer to CByondValue - * @return True if value is a string - */ -DUNGPUB bool ByondValue_IsStr(CByondValue const *v); -/** - * @param v Pointer to CByondValue - * @return True if value is a list (any list type, not just user-defined) - */ -DUNGPUB bool ByondValue_IsList(CByondValue const *v); - -/** - * Determines if a value is logically true or false - * - * @param v Pointer to CByondValue - * @return Truthiness of value - */ -DUNGPUB bool ByondValue_IsTrue(CByondValue const *v); - -/** - * @param v Pointer to CByondValue - * @return Floating point number for v, or 0 if not numeric - */ -DUNGPUB float ByondValue_GetNum(CByondValue const *v); -/** - * @param v Pointer to CByondValue - * @return Reference ID if value is a reference type, or 0 otherwise - */ -DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); - -/** - * Fills a CByondValue struct with a floating point number. - * @param v Pointer to CByondValue - * @param f Floating point number - */ -DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); -/** - * Creates a string and sets CByondValue to a temporary reference to that string. - * Blocks if not on the main thread. If string creation fails, the struct is set to null. - * @param v Pointer to CByondValue - * @param str Null-terminated UTF-8 string - * @see Byond_AddGetStrId() - */ -DUNGPUB void ByondValue_SetStr(CByondValue *v, char const *str); -/** - * Fills a CByondValue struct with a reference (object) type. Does not validate. - * @param v Pointer to CByondValue - * @param type 1-byte teference type - * @param ref 4-byte reference ID; for most types, an ID of NONE is invalid - * @see Byond_TestRef() - */ -DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); - -/** - * Compares two values for equality - * @param a Pointer to CByondValue - * @param b Pointer to CByondValue - * @return True if values are equal - */ -DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); - -// Other useful structs - -struct CByondXYZ { - s2c x, y, z; //!< signed 2-byte integer coordinates - s2c junk; //!< padding -}; - -/* - In the following functions, anything that fills a result value (e.g., - ReadVar, CallProc) will create a temporary reference to the value. So if - the result is an object or list or such, it will remain valid until the - end of the current tick unless something explicitly deletes it. You can - also let go of the temporary reference early by calling Byond_DecRef(). - - If the validity of a reference is ever in doubt, call Byond_TestRef(). - - Thread safety: - - Anything called outside of the main thread will block, unless otherwise - noted. - */ - -typedef CByondValue (*ByondCallback)(void *); -/** - * Runs a function as a callback on the main thread (or right away if already there) - * Blocking is optional. If already on the main thread, the block parameter is meaningless. - * @param callback Function pointer to CByondValue function(void*) - * @param data Void pointer (argument to function) - * @param block True if this call should block while waiting for the callback to finish; false if not - * @return CByondValue returned by the function (if it blocked; null if not) - */ -DUNGPUB CByondValue Byond_ThreadSync(ByondCallback callback, void *data, bool block=false); - -/** - * Returns a reference to an existing string ID, but does not create a new string ID. - * Blocks if not on the main thread. - * @param str Null-terminated string - * @return ID of string; NONE if string does not exist - */ -DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match -/** - * Returns a reference to an existing string ID or creates a new string ID with a temporary reference. - * Blocks if not on the main thread. - * @param str Null-terminated string - * @return ID of string; NONE if string creation failed - */ -DUNGPUB u4c Byond_AddGetStrId(char const *str); // adds a string to the tree if not found - -/** - * Reads an object variable by name. - * Blocks if not on the main thread. - * @param loc Object that owns the var - * @param varname Var name as null-terminated string - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); -/** - * Reads an object variable by the string ID of its var name. - * ID can be cached ahead of time for performance. - * Blocks if not on the main thread. - * @param loc Object that owns the var - * @param varname Var name as string ID - * @param result Pointer to accept result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); -/** - * Writes an object variable by name. - * Blocks if not on the main thread. - * @param loc Object that owns the var - * @param varname Var name as null-terminated string - * @param val New value - * @return True on success - */ -DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); -/** - * Writes an object variable by the string ID of its var name. - * ID can be cached ahead of time for performance. - * Blocks if not on the main thread. - * @param loc Object that owns the var - * @param varname Var name as string ID - * @param val New value - * @return True on success - */ -DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); - -/** - * Creates an empty list with a temporary reference. Equivalent to list(). - * Blocks if not on the main thread. - * @param result Result - * @return True on success - */ -DUNGPUB bool Byond_CreateList(CByondValue *result); - -/** - * Reads items from a list. - * Blocks if not on the main thread. - * @param loc The list to read - * @param list CByondValue array, allocated by caller (can be null if querying length) - * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValue *list, u4c *len); - -/** - * Writes items to a list, in place of old contents. - * Blocks if not on the main thread. - * @param loc The list to fill - * @param list CByondValue array of items to write - * @param len Number of items to write - * @return True on success - */ -DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValue const *list, u4c len); - -/** - * Reads items as key,value pairs from an associative list, storing them sequentially as key1, value1, key2, value2, etc. - * Blocks if not on the main thread. - * @param loc The list to read - * @param list CByondValue array, allocated by caller (can be null if querying length) - * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_ReadListAssoc(CByondValue const *loc, CByondValue *list, u4c *len); - -/** - * Reads an item from a list. - * Blocks if not on the main thread. - * @param loc The list - * @param idx The index in the list (may be a number, or a non-number if using associative lists) - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); -/** - * Writes an item to a list. - * Blocks if not on the main thread. - * @param loc The list - * @param idx The index in the list (may be a number, or a non-number if using associative lists) - * @param val New value - * @return True on success - */ -DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); - -/** - * Reads from a BYOND pointer - * Blocks if not on the main thread. - * @param ptr The BYOND pointer - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); -/** - * Writes to a BYOND pointer - * Blocks if not on the main thread. - * @param ptr The BYOND pointer - * @param val New value - * @return True on success - */ -DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); - -/* - Proc calls: - - arg is an array of arguments; can be null arg_count is 0. - - The call is implicitly a waitfor=0 call; if the callee sleeps it will return - immediately and finish later. - */ - -/** - * Calls an object proc by name. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param src The object that owns the proc - * @param name Proc name as null-terminated string - * @param arg Array of arguments - * @param arg_count Number of arguments - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); -/** - * Calls an object proc by name, where the name is a string ID. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param src The object that owns the proc - * @param name Proc name as string ID - * @param arg Array of arguments - * @param arg_count Number of arguments - * @param result Pointer to accept result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); - -/** - * Calls a global proc by name. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param name Proc name as null-terminated string - * @param arg Array of arguments - * @param arg_count Number of arguments - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! -/** - * Calls a global proc by name, where the name is a string ID. - * The proc call is treated as waitfor=0 and will return immediately on sleep. - * Blocks if not on the main thread. - * @param name Proc name as string ID - * @param arg Array of arguments - * @param arg_count Number of arguments - * @param result Pointer to accept result - * @return True on success - * @see Byond_GetStrId() - */ -DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! - -/** - * Uses BYOND's internals to represent a value as text - * Blocks if not on the main thread. - * @param src The value to convert to text - * @param buf char array, allocated by caller (can be null if querying length) - * @param buflen Pointer to length of array in bytes; receives the string length (including trailing null) on success, or required length of array if not big enough - * @return True on success; false with *buflen=0 for failure; false with *buflen=required size if array is not big enough - */ -DUNGPUB bool Byond_ToString(CByondValue const *src, char *buf, u4c *buflen); - -// Other builtins - -/** - * Equivalent to calling block(x1,y1,z1, x2,y2,z2). - * Blocks if not on the main thread. - * @param corner1 One corner of the block - * @param corner2 Another corner of the block - * @param list CByondValue array, allocated by caller (can be null if querying length) - * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough - * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough - */ -DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValue *list, u4c *len); - -/** - * Equivalent to calling length(value). - * Blocks if not on the main thread. - * @param src The value - * @param result Pointer to accept result as a CByondValue (intended for future possible override of length) - * @return True on success - */ -DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); - -/** - * Equivalent to calling locate(type), or locate(type) in list. - * Blocks if not on the main thread. - * @param type The type to locate - * @param list The list to locate in; can be a null pointer instead of a CByondValue to locate(type) without a list - * @param result Pointer to accept result; can be null if nothing is found - * @return True on success (including if nothing is found); false on error - */ -DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); - -/** - * Equivalent to calling locate(x,y,z) - * Blocks if not on the main thread. - * Result is null if coords are invalid. - * @param xyz The x,y,z coords - * @param result Pointer to accept result - * @return True (always) - */ -DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); - -/** - * Equivalent to calling new type(...) - * Blocks if not on the main thread. - * @param type The type to create (type path or string) - * @param arg Array of arguments - * @param arg_count Number of arguments - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *arg, u4c arg_count, CByondValue *result); - -/** - * Equivalent to calling new type(arglist) - * Blocks if not on the main thread. - * @param type The type to create (type path or string) - * @param arglist Arguments, as a reference to an arglist - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! - -/** - * Equivalent to calling refcount(value) - * Blocks if not on the main thread. - * @param src The object to refcount - * @param result Pointer to accept result - * @return True on success - */ -DUNGPUB bool Byond_Refcount(CByondValue const *src, u4c *result); // result MUST be initialized first! - -/** - * Get x,y,z coords of an atom - * Blocks if not on the main thread. - * @param src The object to read - * @param xyz Pointer to accept CByondXYZ result - * @return True on success - */ -DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 - -/* - Generally you don't want to mess with inc/decref calls, except that for - temporary references you can use Byond_DecRef() to let go of the temporary - reference. - - Call ByondValue_IncRef() to create a permanent reference to an object - within Byondapi. It will exist until ByondValue_DecRef() removes it or the - object is hard-deleted. - - ByondValue_DecRef() will remove a permanent reference created by Byondapi. - If there is no permanent reference, it will remove any temporary - reference that was set to expire when the tick ends. If Byondapi has no - references to the object, the call will be ignored. - - These only apply to ref types, not null/num/string. Any runtime errors - caused by decref (if the object is deleted or another object ends up - getting deleted as an indirect result) are ignored. - */ - -/** - * Mark a reference as in use by Byondapi - * This should be done for any temporary references returned from other calls, if they need to be saved awhile. - * Blocks if not on the main thread. - * @param src The object to incref - */ -DUNGPUB void ByondValue_IncRef(CByondValue const *src); - -/** - * Mark a reference as no longer in use by Byondapi - * This can be used for temporary references to let them go immediately. - * Blocks if not on the main thread. - * @param src The object to decref - */ -DUNGPUB void ByondValue_DecRef(CByondValue const *src); - -/** - * Test if a reference-type CByondValue is valid - * Blocks if not on the main thread. - * @param src Pointer to the reference to test; will be filled with null if the reference is invalid - * @return True if ref is valid; false if not - */ -// Returns true if the ref is valid. -// Returns false if the ref was not valid and had to be changed to null. -// This only applies to ref types, not null/num/string which are always valid. -DUNGPUB bool Byond_TestRef(CByondValue *src); - -}; // extern "C" - - - -#endif // BYONDAPI_H +#ifndef BYONDAPI_H +#define BYONDAPI_H + +/* + BYOND public API version 515.1621 + + Because for some reason nobody can get their ducks in a row, all of the + exported functions from byondcore.dll/libbyond.so are limited to C + conventions only. A header and source file for C++ wrappers is available + for inclusion in your projects. + */ + +#if defined(WIN32) || defined(WIN64) +#define IS_WINDOWS +#else +#define IS_LINUX +#endif + + +// See https://github.com/cpredef/predef/blob/master/Architectures.md +#if defined(i386) || defined(__i386) || defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__X86__) +#define _X86 +#define _X86ORX64 +#define DM_32BIT +#elif defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || defined(_M_X64) || defined(_WIN64) || defined(WIN64) +#define _X64 +#define _X86ORX64 +#define DM_64BIT +#elif defined(__arm__) || defined(_M_ARM) +#define _ARM +#if defined(__LP64__) || defined(_LP64) +#define DM_64BIT +#else +#define DM_32BIT +#endif +#endif + + + +/*types*/ +typedef unsigned char u1c; +typedef signed char s1c; +typedef unsigned short u2c; +typedef signed short s2c; +#ifdef DM_64BIT +typedef unsigned int u4c; +typedef signed int s4c; +#else +typedef unsigned long u4c; +typedef signed long s4c; +#endif + +#if defined(_MSC_VER) || defined(__BORLANDC__) + typedef __int64 s8c; + typedef unsigned __int64 u8c; +#else + typedef long long int s8c; + typedef unsigned long long int u8c; +#endif + +union u4cOrPointer { + u4c num; + void *ptr; +}; + +#ifdef __GNUC__ +#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) +#else +#define GCC_VERSION 0 +#endif + + +// determine if move-constructor and move-assignment are supported +#if defined(_MSC_VER) && _MSC_VER >= 1800 +#define _SUPPORT_MOVES +#elif defined(__GNUC__) && GCC_VERSION >= 50000 +#define _SUPPORT_MOVES +#endif + + +#define u1cMASK ((u1c)0xff) +#define u2cMASK ((u2c)0xffff) +#define u3cMASK ((u4c)0xffffffL) +#define u4cMASK ((u4c)0xffffffffL) + +#define u1cMAX u1cMASK +#define u2cMAX u2cMASK +#define u3cMAX u3cMASK +#define u4cMAX u4cMASK + +#define s1cMAX 0x7f +#define s1cMIN (-0x7f) +#define s2cMAX 0x7fff +#define s2cMIN (-0x7fff) +#define s4cMAX 0x7fffffffL +#define s4cMIN (-0x7fffffffL) + +#define NONE u2cMAX +#define NOCH u1cMAX + +#ifdef WIN32 +#define THREAD_VAR __declspec(thread) +#else +#define THREAD_VAR __thread +#endif + +/* dll export stuff */ +#ifdef WIN32 +#define DUNGPUB __declspec(dllimport) +#define BYOND_EXPORT __declspec(dllexport) // for functions in user-defined DLLs for use with call_ext() +#else // unix/g++, combine with -fvisibility=hidden to hide non-exported symbols +#define DUNGPUB +#define BYOND_EXPORT __attribute__ ((visibility("default"))) // for functions in user-defined .so libraries for use with call_ext() +#endif + + +// ByondValue + +/* + Many of the routines in this library return a bool value. If true, the + operation succeeded. If false, it failed and calling Byond_LastError() will + return an error string. + + The C++ wrappers change this true/false behavior to raise exceptions instead. + This would be preferable across the board but throwing exceptions across + module boundaries is bad juju. + */ + +extern "C" { + +/** + * Gets the last error from a failed call + * The result is a static string that does not need to be freed. + * @return Error message + */ +DUNGPUB char const *Byond_LastError(); + +/** + * Gets the current BYOND version + * @param version Pointer to the major version number + * @param build Pointer to the build number + */ +DUNGPUB void Byond_GetVersion(u4c *version, u4c *build); + +/** + * Gets the DMB version + * @return Version number the .dmb was built with + */ +DUNGPUB u4c Byond_GetDMBVersion(); + +typedef u1c ByondValueType; +union ByondValueData { + u4c ref; //!< 4-byte reference ID + float num; //!< floating-point number +}; + +struct CByondValue { + ByondValueType type; //!< 1-byte intrinsic data type + u1c junk1, junk2, junk3; //!< padding + ByondValueData data; //!< 4-byte reference ID or floating point number +}; + +/** + * Fills a CByondValue struct with a null value. + * @param v Pointer to CByondValue + */ +DUNGPUB void ByondValue_Clear(CByondValue *v); + +/** + * Reads CByondVale's 1-byte data type + * @param v Pointer to CByondValue + * @return Type of value + */ +DUNGPUB ByondValueType ByondValue_Type(CByondValue const *v); + +/** + * @param v Pointer to CByondValue + * @return True if value is null + */ +DUNGPUB bool ByondValue_IsNull(CByondValue const *v); +/** + * @param v Pointer to CByondValue + * @return True if value is a numeric type + */ +DUNGPUB bool ByondValue_IsNum(CByondValue const *v); +/** + * @param v Pointer to CByondValue + * @return True if value is a string + */ +DUNGPUB bool ByondValue_IsStr(CByondValue const *v); +/** + * @param v Pointer to CByondValue + * @return True if value is a list (any list type, not just user-defined) + */ +DUNGPUB bool ByondValue_IsList(CByondValue const *v); + +/** + * Determines if a value is logically true or false + * + * @param v Pointer to CByondValue + * @return Truthiness of value + */ +DUNGPUB bool ByondValue_IsTrue(CByondValue const *v); + +/** + * @param v Pointer to CByondValue + * @return Floating point number for v, or 0 if not numeric + */ +DUNGPUB float ByondValue_GetNum(CByondValue const *v); +/** + * @param v Pointer to CByondValue + * @return Reference ID if value is a reference type, or 0 otherwise + */ +DUNGPUB u4c ByondValue_GetRef(CByondValue const *v); + +/** + * Fills a CByondValue struct with a floating point number. + * @param v Pointer to CByondValue + * @param f Floating point number + */ +DUNGPUB void ByondValue_SetNum(CByondValue *v, float f); +/** + * Creates a string and sets CByondValue to a temporary reference to that string. + * Blocks if not on the main thread. If string creation fails, the struct is set to null. + * @param v Pointer to CByondValue + * @param str Null-terminated UTF-8 string + * @see Byond_AddGetStrId() + */ +DUNGPUB void ByondValue_SetStr(CByondValue *v, char const *str); +/** + * Fills a CByondValue struct with a reference (object) type. Does not validate. + * @param v Pointer to CByondValue + * @param type 1-byte teference type + * @param ref 4-byte reference ID; for most types, an ID of NONE is invalid + * @see Byond_TestRef() + */ +DUNGPUB void ByondValue_SetRef(CByondValue *v, ByondValueType type, u4c ref); + +/** + * Compares two values for equality + * @param a Pointer to CByondValue + * @param b Pointer to CByondValue + * @return True if values are equal + */ +DUNGPUB bool ByondValue_Equals(CByondValue const *a, CByondValue const *b); + +// Other useful structs + +struct CByondXYZ { + s2c x, y, z; //!< signed 2-byte integer coordinates + s2c junk; //!< padding +}; + +/* + In the following functions, anything that fills a result value (e.g., + ReadVar, CallProc) will create a temporary reference to the value. So if + the result is an object or list or such, it will remain valid until the + end of the current tick unless something explicitly deletes it. You can + also let go of the temporary reference early by calling Byond_DecRef(). + + If the validity of a reference is ever in doubt, call Byond_TestRef(). + + Thread safety: + + Anything called outside of the main thread will block, unless otherwise + noted. + */ + +typedef CByondValue (*ByondCallback)(void *); +/** + * Runs a function as a callback on the main thread (or right away if already there) + * Blocking is optional. If already on the main thread, the block parameter is meaningless. + * @param callback Function pointer to CByondValue function(void*) + * @param data Void pointer (argument to function) + * @param block True if this call should block while waiting for the callback to finish; false if not + * @return CByondValue returned by the function (if it blocked; null if not) + */ +DUNGPUB CByondValue Byond_ThreadSync(ByondCallback callback, void *data, bool block=false); + +/** + * Returns a reference to an existing string ID, but does not create a new string ID. + * Blocks if not on the main thread. + * @param str Null-terminated string + * @return ID of string; NONE if string does not exist + */ +DUNGPUB u4c Byond_GetStrId(char const *str); // does not add a string to the tree if not found; returns NONE if no string match +/** + * Returns a reference to an existing string ID or creates a new string ID with a temporary reference. + * Blocks if not on the main thread. + * @param str Null-terminated string + * @return ID of string; NONE if string creation failed + */ +DUNGPUB u4c Byond_AddGetStrId(char const *str); // adds a string to the tree if not found + +/** + * Reads an object variable by name. + * Blocks if not on the main thread. + * @param loc Object that owns the var + * @param varname Var name as null-terminated string + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_ReadVar(CByondValue const *loc, char const *varname, CByondValue *result); +/** + * Reads an object variable by the string ID of its var name. + * ID can be cached ahead of time for performance. + * Blocks if not on the main thread. + * @param loc Object that owns the var + * @param varname Var name as string ID + * @param result Pointer to accept result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_ReadVarByStrId(CByondValue const *loc, u4c varname, CByondValue *result); +/** + * Writes an object variable by name. + * Blocks if not on the main thread. + * @param loc Object that owns the var + * @param varname Var name as null-terminated string + * @param val New value + * @return True on success + */ +DUNGPUB bool Byond_WriteVar(CByondValue const *loc, char const *varname, CByondValue const *val); +/** + * Writes an object variable by the string ID of its var name. + * ID can be cached ahead of time for performance. + * Blocks if not on the main thread. + * @param loc Object that owns the var + * @param varname Var name as string ID + * @param val New value + * @return True on success + */ +DUNGPUB bool Byond_WriteVarByStrId(CByondValue const *loc, u4c varname, CByondValue const *val); + +/** + * Creates an empty list with a temporary reference. Equivalent to list(). + * Blocks if not on the main thread. + * @param result Result + * @return True on success + */ +DUNGPUB bool Byond_CreateList(CByondValue *result); + +/** + * Reads items from a list. + * Blocks if not on the main thread. + * @param loc The list to read + * @param list CByondValue array, allocated by caller (can be null if querying length) + * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_ReadList(CByondValue const *loc, CByondValue *list, u4c *len); + +/** + * Writes items to a list, in place of old contents. + * Blocks if not on the main thread. + * @param loc The list to fill + * @param list CByondValue array of items to write + * @param len Number of items to write + * @return True on success + */ +DUNGPUB bool Byond_WriteList(CByondValue const *loc, CByondValue const *list, u4c len); + +/** + * Reads items as key,value pairs from an associative list, storing them sequentially as key1, value1, key2, value2, etc. + * Blocks if not on the main thread. + * @param loc The list to read + * @param list CByondValue array, allocated by caller (can be null if querying length) + * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_ReadListAssoc(CByondValue const *loc, CByondValue *list, u4c *len); + +/** + * Reads an item from a list. + * Blocks if not on the main thread. + * @param loc The list + * @param idx The index in the list (may be a number, or a non-number if using associative lists) + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_ReadListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue *result); +/** + * Writes an item to a list. + * Blocks if not on the main thread. + * @param loc The list + * @param idx The index in the list (may be a number, or a non-number if using associative lists) + * @param val New value + * @return True on success + */ +DUNGPUB bool Byond_WriteListIndex(CByondValue const *loc, CByondValue const *idx, CByondValue const *val); + +/** + * Reads from a BYOND pointer + * Blocks if not on the main thread. + * @param ptr The BYOND pointer + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_ReadPointer(CByondValue const *ptr, CByondValue *result); +/** + * Writes to a BYOND pointer + * Blocks if not on the main thread. + * @param ptr The BYOND pointer + * @param val New value + * @return True on success + */ +DUNGPUB bool Byond_WritePointer(CByondValue const *ptr, CByondValue const *val); + +/* + Proc calls: + + arg is an array of arguments; can be null arg_count is 0. + + The call is implicitly a waitfor=0 call; if the callee sleeps it will return + immediately and finish later. + */ + +/** + * Calls an object proc by name. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param src The object that owns the proc + * @param name Proc name as null-terminated string + * @param arg Array of arguments + * @param arg_count Number of arguments + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_CallProc(CByondValue const *src, char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); +/** + * Calls an object proc by name, where the name is a string ID. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param src The object that owns the proc + * @param name Proc name as string ID + * @param arg Array of arguments + * @param arg_count Number of arguments + * @param result Pointer to accept result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_CallProcByStrId(CByondValue const *src, u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); + +/** + * Calls a global proc by name. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param name Proc name as null-terminated string + * @param arg Array of arguments + * @param arg_count Number of arguments + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_CallGlobalProc(char const *name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! +/** + * Calls a global proc by name, where the name is a string ID. + * The proc call is treated as waitfor=0 and will return immediately on sleep. + * Blocks if not on the main thread. + * @param name Proc name as string ID + * @param arg Array of arguments + * @param arg_count Number of arguments + * @param result Pointer to accept result + * @return True on success + * @see Byond_GetStrId() + */ +DUNGPUB bool Byond_CallGlobalProcByStrId(u4c name, CByondValue const *arg, u4c arg_count, CByondValue *result); // result MUST be initialized first! + +/** + * Uses BYOND's internals to represent a value as text + * Blocks if not on the main thread. + * @param src The value to convert to text + * @param buf char array, allocated by caller (can be null if querying length) + * @param buflen Pointer to length of array in bytes; receives the string length (including trailing null) on success, or required length of array if not big enough + * @return True on success; false with *buflen=0 for failure; false with *buflen=required size if array is not big enough + */ +DUNGPUB bool Byond_ToString(CByondValue const *src, char *buf, u4c *buflen); + +// Other builtins + +/** + * Equivalent to calling block(x1,y1,z1, x2,y2,z2). + * Blocks if not on the main thread. + * @param corner1 One corner of the block + * @param corner2 Another corner of the block + * @param list CByondValue array, allocated by caller (can be null if querying length) + * @param len Pointer to length of array (in items); receives the number of items read on success, or required length of array if not big enough + * @return True on success; false with *len=0 for failure; false with *len=required size if array is not big enough + */ +DUNGPUB bool Byond_Block(CByondXYZ const *corner1, CByondXYZ const *corner2, CByondValue *list, u4c *len); + +/** + * Equivalent to calling length(value). + * Blocks if not on the main thread. + * @param src The value + * @param result Pointer to accept result as a CByondValue (intended for future possible override of length) + * @return True on success + */ +DUNGPUB bool Byond_Length(CByondValue const *src, CByondValue *result); + +/** + * Equivalent to calling locate(type), or locate(type) in list. + * Blocks if not on the main thread. + * @param type The type to locate + * @param list The list to locate in; can be a null pointer instead of a CByondValue to locate(type) without a list + * @param result Pointer to accept result; can be null if nothing is found + * @return True on success (including if nothing is found); false on error + */ +DUNGPUB bool Byond_LocateIn(CByondValue const *type, CByondValue const *list, CByondValue *result); + +/** + * Equivalent to calling locate(x,y,z) + * Blocks if not on the main thread. + * Result is null if coords are invalid. + * @param xyz The x,y,z coords + * @param result Pointer to accept result + * @return True (always) + */ +DUNGPUB bool Byond_LocateXYZ(CByondXYZ const *xyz, CByondValue *result); + +/** + * Equivalent to calling new type(...) + * Blocks if not on the main thread. + * @param type The type to create (type path or string) + * @param arg Array of arguments + * @param arg_count Number of arguments + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_New(CByondValue const *type, CByondValue const *arg, u4c arg_count, CByondValue *result); + +/** + * Equivalent to calling new type(arglist) + * Blocks if not on the main thread. + * @param type The type to create (type path or string) + * @param arglist Arguments, as a reference to an arglist + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_NewArglist(CByondValue const *type, CByondValue const *arglist, CByondValue *result); // result MUST be initialized first! + +/** + * Equivalent to calling refcount(value) + * Blocks if not on the main thread. + * @param src The object to refcount + * @param result Pointer to accept result + * @return True on success + */ +DUNGPUB bool Byond_Refcount(CByondValue const *src, u4c *result); // result MUST be initialized first! + +/** + * Get x,y,z coords of an atom + * Blocks if not on the main thread. + * @param src The object to read + * @param xyz Pointer to accept CByondXYZ result + * @return True on success + */ +DUNGPUB bool Byond_XYZ(CByondValue const *src, CByondXYZ *xyz); // still returns true if the atom is off-map, but xyz will be 0,0,0 + +/* + Generally you don't want to mess with inc/decref calls, except that for + temporary references you can use Byond_DecRef() to let go of the temporary + reference. + + Call ByondValue_IncRef() to create a permanent reference to an object + within Byondapi. It will exist until ByondValue_DecRef() removes it or the + object is hard-deleted. + + ByondValue_DecRef() will remove a permanent reference created by Byondapi. + If there is no permanent reference, it will remove any temporary + reference that was set to expire when the tick ends. If Byondapi has no + references to the object, the call will be ignored. + + These only apply to ref types, not null/num/string. Any runtime errors + caused by decref (if the object is deleted or another object ends up + getting deleted as an indirect result) are ignored. + */ + +/** + * Mark a reference as in use by Byondapi + * This should be done for any temporary references returned from other calls, if they need to be saved awhile. + * Blocks if not on the main thread. + * @param src The object to incref + */ +DUNGPUB void ByondValue_IncRef(CByondValue const *src); + +/** + * Mark a reference as no longer in use by Byondapi + * This can be used for temporary references to let them go immediately. + * Blocks if not on the main thread. + * @param src The object to decref + */ +DUNGPUB void ByondValue_DecRef(CByondValue const *src); + +/** + * Test if a reference-type CByondValue is valid + * Blocks if not on the main thread. + * @param src Pointer to the reference to test; will be filled with null if the reference is invalid + * @return True if ref is valid; false if not + */ +// Returns true if the ref is valid. +// Returns false if the ref was not valid and had to be changed to null. +// This only applies to ref types, not null/num/string which are always valid. +DUNGPUB bool Byond_TestRef(CByondValue *src); + +}; // extern "C" + + + +#endif // BYONDAPI_H