X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=sys.h;h=91eeb2c03fb6c830ebe27e750cb2a850a3a872e5;hb=4b08159c59c67950fccf0fc9a1d038d53ecb0203;hp=0df1b9b66dbc4ef54e4d55b3867586a1357bae25;hpb=d7035ef4229a2462ad59a67160494593fbd8f2e0;p=xonotic%2Fdarkplaces.git diff --git a/sys.h b/sys.h index 0df1b9b6..91eeb2c0 100644 --- a/sys.h +++ b/sys.h @@ -19,44 +19,48 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ // sys.h -- non-portable functions -// -// file IO -// - -// returns the file size -// return -1 if file is not present -// the file should be in BINARY mode for stupid OSs that care -int Sys_FileOpenRead (char *path, int *hndl); +#ifndef SYS_H +#define SYS_H -int Sys_FileOpenWrite (char *path); -void Sys_FileClose (int handle); -void Sys_FileSeek (int handle, int position); -int Sys_FileRead (int handle, void *dest, int count); -int Sys_FileWrite (int handle, void *data, int count); -int Sys_FileTime (char *path); -void Sys_mkdir (char *path); // -// memory protection +// DLL management // -#if NOTUSED -void Sys_MakeCodeWriteable (unsigned long startaddr, unsigned long length); + +// Win32 specific +#ifdef WIN32 +# include +typedef HMODULE dllhandle_t; + +// Other platforms +#else + typedef void* dllhandle_t; #endif +typedef struct +{ + const char *name; + void **funcvariable; +} +dllfunction_t; + +dllhandle_t Sys_LoadLibrary (const char* name); +void Sys_UnloadLibrary (dllhandle_t handle); +void* Sys_GetProcAddress (dllhandle_t handle, const char* name); + + // // system IO // -void Sys_DebugLog(char *file, char *fmt, ...); - -void Sys_Error (char *error, ...); +void Sys_Error (const char *error, ...); // an error will cause the entire program to exit -void Sys_Printf (char *fmt, ...); +void Sys_Printf (const char *fmt, ...); // send text to the console void Sys_Quit (void); -double Sys_FloatTime (void); +double Sys_DoubleTime (void); char *Sys_ConsoleInput (void); @@ -67,3 +71,10 @@ void Sys_Sleep (void); void Sys_SendKeyEvents (void); // Perform Key_Event () callbacks until the input que is empty +// called after Com_InitArgv +void Sys_Shared_EarlyInit (void); +// called after Host_init +void Sys_Shared_LateInit (void); + +#endif +