X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=blobdiff_plain;f=sys.h;h=9dfdf620c91c9899d26a139272cdc038f86f1b58;hp=2644d074311baf99ad68fc21285a967ec007eb1c;hb=85a33377d64ae8438e6582a7b8472f5a4bd41942;hpb=40a6f67c7fc621ac5a0e531856e11a1ca8c40a96 diff --git a/sys.h b/sys.h index 2644d074..9dfdf620 100644 --- a/sys.h +++ b/sys.h @@ -22,6 +22,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #ifndef SYS_H #define SYS_H +extern cvar_t sys_usenoclockbutbenchmark; // // DLL management @@ -37,53 +38,85 @@ typedef HMODULE dllhandle_t; typedef void* dllhandle_t; #endif -typedef struct +typedef struct dllfunction_s { const char *name; void **funcvariable; } dllfunction_t; -qboolean Sys_LoadLibrary (const char* dllname, dllhandle_t* handle, const dllfunction_t *fcts); +/*! Loads a library. + * \param dllnames a NULL terminated array of possible names for the DLL you want to load. + * \param handle + * \param fcts + */ +qboolean Sys_LoadLibrary (const char** dllnames, dllhandle_t* handle, const dllfunction_t *fcts); void Sys_UnloadLibrary (dllhandle_t* handle); void* Sys_GetProcAddress (dllhandle_t handle, const char* name); -void Sys_Print(const char *msg); -void Sys_Printf(const char *fmt, ...); -// send text to the quake console (and possibly to terminal) +/// called early in Host_Init +void Sys_InitConsole (void); +/// called after command system is initialized but before first Con_Print +void Sys_Init_Commands (void); -// called after Com_InitArgv -void Sys_Shared_EarlyInit (void); -// called after Host_init -void Sys_Shared_LateInit (void); -// returns current timestamp +/// \returns current timestamp char *Sys_TimeString(const char *timeformat); // // system IO interface (these are the sys functions that need to be implemented in a new driver atm) // -void Sys_Error (const char *error, ...); -// an error will cause the entire program to exit +/// an error will cause the entire program to exit +void Sys_Error (const char *error, ...) DP_FUNC_PRINTF(1) DP_FUNC_NORETURN; + +/// (may) output text to terminal which launched program void Sys_PrintToTerminal(const char *text); -// (may) output text to terminal which launched program +void Sys_PrintfToTerminal(const char *fmt, ...); + +/// INFO: This is only called by Host_Shutdown so we dont need testing for recursion +void Sys_Shutdown (void); +void Sys_Quit (int returnvalue); + +/*! on some build/platform combinations (such as Linux gcc with the -pg + * profiling option) this can turn on/off profiling, used primarily to limit + * profiling to certain areas of the code, such as ingame performance without + * regard for loading/shutdown performance (-profilegameonly on commandline) + */ +#ifdef __cplusplus +extern "C" +#endif +void Sys_AllowProfiling (qboolean enable); -void Sys_Shutdown (void); //INFO: This is only called by Host_Shutdown so we dont need testing for recursion -void Sys_Quit (void); +typedef struct sys_cleantime_s +{ + double dirtytime; // last value gotten from Sys_DirtyTime() + double cleantime; // sanitized linearly increasing time since app start +} +sys_cleantime_t; -double Sys_DoubleTime (void); +double Sys_DirtyTime(void); + +void Sys_ProvideSelfFD (void); char *Sys_ConsoleInput (void); -void Sys_Sleep(int milliseconds); -// called to yield for a little bit so as -// not to hog cpu when paused or debugging +/// called to yield for a little bit so as not to hog cpu when paused or debugging +void Sys_Sleep(int microseconds); +/// Perform Key_Event () callbacks until the input que is empty void Sys_SendKeyEvents (void); -// Perform Key_Event () callbacks until the input que is empty char *Sys_GetClipboardData (void); +extern qboolean sys_supportsdlgetticks; +unsigned int Sys_SDL_GetTicks (void); // wrapper to call SDL_GetTicks +void Sys_SDL_Delay (unsigned int milliseconds); // wrapper to call SDL_Delay + +/// called to set process priority for dedicated servers +void Sys_InitProcessNice (void); +void Sys_MakeProcessNice (void); +void Sys_MakeProcessMean (void); + #endif