mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-10 11:00:46 +00:00
306 lines
7.6 KiB
C
306 lines
7.6 KiB
C
// On-screen display (ie. console)
|
|
// for the Build Engine
|
|
// by Jonathon Fowler (jf@jonof.id.au)
|
|
|
|
#ifndef osd_h_
|
|
#define osd_h_
|
|
|
|
#include "vfs.h"
|
|
|
|
#include "mutex.h"
|
|
|
|
typedef struct {
|
|
int32_t numparms;
|
|
const char *name;
|
|
const char **parms;
|
|
const char *raw;
|
|
} osdfuncparm_t;
|
|
|
|
using osdcmdptr_t = osdfuncparm_t const * const;
|
|
|
|
const char *OSD_StripColors(char *outBuf, const char *inBuf);
|
|
|
|
#define OSDDEFAULTMAXLINES 128
|
|
#define OSDEDITLENGTH 512
|
|
#define OSDMINHISTORYDEPTH 32
|
|
#define OSDMAXHISTORYDEPTH 256
|
|
#define OSDBUFFERSIZE 32768
|
|
#define OSDDEFAULTROWS 20
|
|
#define OSDDEFAULTCOLS 60
|
|
#define OSDLOGCUTOFF 131072
|
|
#define OSDMAXSYMBOLS 512
|
|
|
|
enum cvartype_t
|
|
{
|
|
CVAR_FLOAT = 0x00000001,
|
|
CVAR_INT = 0x00000002,
|
|
CVAR_UINT = 0x00000004,
|
|
CVAR_BOOL = 0x00000008,
|
|
CVAR_STRING = 0x00000010,
|
|
CVAR_DOUBLE = 0x00000020,
|
|
CVAR_READONLY = 0x00000040,
|
|
CVAR_MULTI = 0x00000080,
|
|
CVAR_NOSAVE = 0x00000100,
|
|
CVAR_FUNCPTR = 0x00000200,
|
|
CVAR_RESTARTVID = 0x00000400,
|
|
CVAR_INVALIDATEALL = 0x00000800,
|
|
CVAR_INVALIDATEART = 0x00001000,
|
|
CVAR_MODIFIED = 0x00002000,
|
|
|
|
CVAR_TYPEMASK = CVAR_FLOAT | CVAR_DOUBLE | CVAR_INT | CVAR_UINT | CVAR_BOOL | CVAR_STRING
|
|
};
|
|
|
|
typedef struct _symbol
|
|
{
|
|
const char *name;
|
|
struct _symbol *next;
|
|
|
|
const char *help;
|
|
int32_t(*func)(osdcmdptr_t);
|
|
} osdsymbol_t;
|
|
|
|
typedef struct
|
|
{
|
|
const char *name;
|
|
const char *desc;
|
|
|
|
union
|
|
{
|
|
void * ptr;
|
|
int32_t * i32;
|
|
uint32_t * u32;
|
|
float * f;
|
|
double * d;
|
|
char *const string;
|
|
};
|
|
|
|
uint32_t flags; // see cvartype_t
|
|
int32_t const min;
|
|
int32_t const max; // for string, is the length
|
|
} osdcvardata_t;
|
|
|
|
typedef struct
|
|
{
|
|
osdcvardata_t *pData;
|
|
|
|
// default value for cvar, assigned when var is registered
|
|
union
|
|
{
|
|
int32_t i32;
|
|
uint32_t u32;
|
|
float f;
|
|
double d;
|
|
} defaultValue;
|
|
|
|
} osdcvar_t;
|
|
|
|
// version string
|
|
typedef struct
|
|
{
|
|
char *buf;
|
|
|
|
uint8_t len;
|
|
uint8_t shade;
|
|
uint8_t pal;
|
|
} osdstr_t;
|
|
|
|
// command prompt editing
|
|
typedef struct
|
|
{
|
|
char *buf; // [OSDEDITLENGTH+1]; // editing buffer
|
|
char *tmp; // [OSDEDITLENGTH+1]; // editing buffer temporary workspace
|
|
|
|
int16_t len, pos; // length of characters and position of cursor in buffer
|
|
int16_t start, end;
|
|
} osdedit_t;
|
|
|
|
// main text buffer
|
|
typedef struct
|
|
{
|
|
// each character in the buffer also has a format byte containing shade and color
|
|
char *buf;
|
|
char *fmt;
|
|
|
|
int32_t pos; // position next character will be written at
|
|
int32_t lines; // total number of lines in buffer
|
|
int32_t maxlines; // max lines in buffer
|
|
} osdtext_t;
|
|
|
|
// history display
|
|
typedef struct
|
|
{
|
|
char *buf[OSDMAXHISTORYDEPTH];
|
|
|
|
int32_t maxlines; // max entries in buffer, ranges from OSDMINHISTORYDEPTH to OSDMAXHISTORYDEPTH
|
|
int32_t pos; // current buffer position
|
|
int32_t lines; // entries currently in buffer
|
|
int32_t total; // total number of entries
|
|
int32_t exec; // number of lines from the head of the history buffer to execute
|
|
} osdhist_t;
|
|
|
|
// active display parameters
|
|
typedef struct
|
|
{
|
|
char const *errorfmt;
|
|
char const *highlight;
|
|
|
|
int32_t promptshade, promptpal;
|
|
int32_t editshade, editpal;
|
|
int32_t textshade, textpal;
|
|
int32_t mode;
|
|
int32_t rows; // # lines of the buffer that are visible
|
|
int32_t cols; // width of onscreen display in text columns
|
|
uint16_t head; // topmost visible line number
|
|
int8_t scrolling;
|
|
} osddraw_t;
|
|
|
|
typedef struct
|
|
{
|
|
buildvfs_FILE fp;
|
|
int32_t cutoff;
|
|
int32_t errors;
|
|
int32_t lines;
|
|
} osdlog_t;
|
|
|
|
typedef struct
|
|
{
|
|
osdtext_t text;
|
|
osdedit_t editor;
|
|
osdhist_t history;
|
|
osddraw_t draw;
|
|
osdstr_t version;
|
|
|
|
uint32_t flags; // controls initialization, etc
|
|
osdcvar_t *cvars;
|
|
int32_t numcvars;
|
|
|
|
osdsymbol_t *symbols;
|
|
osdsymbol_t *symbptrs[OSDMAXSYMBOLS];
|
|
|
|
int32_t numsymbols;
|
|
int32_t execdepth; // keeps track of nested execution
|
|
mutex_t mutex;
|
|
int32_t keycode;
|
|
|
|
osdlog_t log;
|
|
} osdmain_t;
|
|
|
|
extern osdmain_t *osd;
|
|
|
|
extern buildvfs_FILE osdlog;
|
|
extern const char* osdlogfn;
|
|
|
|
enum osdflags_t
|
|
{
|
|
// OSD_INITIALIZED = 0x00000001,
|
|
OSD_DRAW = 0x00000002,
|
|
OSD_CAPTURE = 0x00000004,
|
|
OSD_OVERTYPE = 0x00000008,
|
|
OSD_SHIFT = 0x00000010,
|
|
OSD_CTRL = 0x00000020,
|
|
OSD_CAPS = 0x00000040,
|
|
OSD_PROTECTED = 0x00000080,
|
|
};
|
|
|
|
#define OSD_ALIAS (int (*)(osdcmdptr_t))0x1337
|
|
#define OSD_UNALIASED (int (*)(osdcmdptr_t))0xDEAD
|
|
|
|
#define OSDCMD_OK 0
|
|
#define OSDCMD_SHOWHELP 1
|
|
|
|
int OSD_ParsingScript(void);
|
|
|
|
int OSD_OSDKey(void);
|
|
int OSD_GetTextMode(void);
|
|
void OSD_SetTextMode(int mode);
|
|
|
|
int OSD_Exec(const char *szScript);
|
|
|
|
// Get shade and pal index from the OSD format buffer.
|
|
void OSD_GetShadePal(const char *ch, int *shd, int *pal);
|
|
|
|
int OSD_GetCols(void);
|
|
int OSD_IsMoving(void);
|
|
int OSD_GetRowsCur(void);
|
|
|
|
// initializes things
|
|
void OSD_Init(void);
|
|
|
|
// cleans things up. these comments are retarded.
|
|
void OSD_Cleanup(void);
|
|
|
|
// sets the file to echo output to
|
|
void OSD_SetLogFile(const char *fn);
|
|
|
|
// sets the functions the OSD will call to interrogate the environment
|
|
void OSD_SetFunctions(void (*drawchar)(int, int, char, int, int),
|
|
void (*drawstr)(int, int, const char *, int, int, int),
|
|
void (*drawcursor)(int, int, int, int),
|
|
int (*colwidth)(int),
|
|
int (*rowheight)(int),
|
|
void (*clearbg)(int, int),
|
|
int32_t (*gtime)(void),
|
|
void (*showosd)(int));
|
|
|
|
// sets the parameters for presenting the text
|
|
void OSD_SetParameters(int promptShade, int promptPal, int editShade, int editPal, int textShade, int textPal,
|
|
char const *errorStr, char const *highlight, uint32_t flags);
|
|
|
|
// sets the scancode for the key which activates the onscreen display
|
|
void OSD_CaptureKey(uint8_t scanCode);
|
|
|
|
// handles keyboard input when capturing input. returns 0 if key was handled
|
|
// or the scancode if it should be handled by the game.
|
|
int OSD_HandleScanCode(uint8_t scanCode, int keyDown);
|
|
int OSD_HandleChar(char ch);
|
|
|
|
// handles the readjustment when screen resolution changes
|
|
void OSD_ResizeDisplay(int w,int h);
|
|
|
|
// captures and frees osd input
|
|
void OSD_CaptureInput(int cap);
|
|
|
|
// sets the console version string
|
|
void OSD_SetVersion(const char *pszVersion, int osdShade, int osdPal);
|
|
|
|
// shows or hides the onscreen display
|
|
void OSD_ShowDisplay(int onf);
|
|
|
|
// draw the osd to the screen
|
|
void OSD_Draw(void);
|
|
|
|
// just like printf
|
|
void OSD_Printf(const char *fmt, ...) ATTRIBUTE((format(printf,1,2)));
|
|
|
|
// just like puts
|
|
void OSD_Puts(const char *str);
|
|
|
|
// executes buffered commands
|
|
void OSD_DispatchQueued(void);
|
|
|
|
// executes a string
|
|
void OSD_Dispatch(const char *cmd);
|
|
|
|
// registers a function
|
|
// name = name of the function
|
|
// help = a short help string
|
|
// func = the entry point to the function
|
|
int OSD_RegisterFunction(const char *pszName, const char *pszDesc, int (*func)(osdcmdptr_t));
|
|
|
|
int osdcmd_cvar_set(osdcmdptr_t parm);
|
|
void OSD_RegisterCvar(osdcvardata_t * cvar, int (*func)(osdcmdptr_t));
|
|
void OSD_WriteAliases(buildvfs_FILE fp);
|
|
void OSD_WriteCvars(buildvfs_FILE fp);
|
|
|
|
static inline void OSD_SetHistory(int idx, const char *src)
|
|
{
|
|
osd->history.buf[idx] = (char *)Xmalloc(OSDEDITLENGTH);
|
|
Bstrncpyz(osd->history.buf[idx], src, OSDEDITLENGTH);
|
|
}
|
|
|
|
extern int osdcmd_restartvid(osdcmdptr_t parm);
|
|
|
|
extern void M32RunScript(const char *s);
|
|
|
|
#endif // osd_h_
|
|
|