2006-04-13 20:47:06 +00:00
|
|
|
// On-screen display (ie. console)
|
|
|
|
// for the Build Engine
|
|
|
|
// by Jonathon Fowler (jonof@edgenetwk.com)
|
|
|
|
|
|
|
|
#ifndef __osd_h__
|
|
|
|
#define __osd_h__
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t numparms;
|
2006-04-13 20:47:06 +00:00
|
|
|
const char *name;
|
|
|
|
const char **parms;
|
|
|
|
const char *raw;
|
|
|
|
} osdfuncparm_t;
|
|
|
|
|
2008-06-30 00:18:59 +00:00
|
|
|
typedef struct _symbol
|
|
|
|
{
|
|
|
|
const char *name;
|
|
|
|
struct _symbol *next;
|
|
|
|
|
|
|
|
const char *help;
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t (*func)(const osdfuncparm_t *);
|
2008-06-30 00:18:59 +00:00
|
|
|
} symbol_t;
|
|
|
|
|
2008-06-30 07:30:48 +00:00
|
|
|
symbol_t *symbols;
|
2009-04-29 06:20:07 +00:00
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
const char *OSD_StripColors(char *out, const char *in);
|
2008-06-30 00:18:59 +00:00
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
enum cvartype_t
|
2009-04-29 06:20:07 +00:00
|
|
|
{
|
2010-05-02 23:27:30 +00:00
|
|
|
CVAR_FLOAT = 0x00000001,
|
|
|
|
CVAR_INT = 0x00000002,
|
|
|
|
CVAR_UINT = 0x00000004,
|
|
|
|
CVAR_BOOL = 0x00000008,
|
|
|
|
CVAR_STRING = 0x00000010,
|
|
|
|
CVAR_DOUBLE = 0x00000020,
|
|
|
|
CVAR_NOMULTI = 0x00000040,
|
|
|
|
CVAR_MULTI = 0x00000080,
|
|
|
|
CVAR_NOSAVE = 0x00000100,
|
|
|
|
CVAR_FUNCPTR = 0x00000200,
|
2009-04-29 06:20:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
char *name;
|
|
|
|
char *helpstr;
|
|
|
|
void *var;
|
2010-06-07 09:03:16 +00:00
|
|
|
int32_t type; // see cvartype_t
|
2009-04-29 06:20:07 +00:00
|
|
|
int32_t min;
|
2010-06-07 09:03:16 +00:00
|
|
|
int32_t max; // for string, is the length
|
2009-04-29 06:20:07 +00:00
|
|
|
} cvar_t;
|
|
|
|
|
2010-06-07 09:03:16 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
char *name;
|
|
|
|
char *helpstr;
|
|
|
|
void *var;
|
|
|
|
int32_t type; // see cvartype_t
|
|
|
|
int32_t min;
|
|
|
|
int32_t max; // for string, is the length
|
|
|
|
|
|
|
|
// everything before this point needs to match cvar_t
|
|
|
|
|
|
|
|
// default value for cvar, assigned when var is registered
|
|
|
|
union
|
|
|
|
{
|
|
|
|
int32_t i;
|
|
|
|
uint32_t uint;
|
|
|
|
float f;
|
|
|
|
double d;
|
|
|
|
} dval;
|
|
|
|
} osdcvar_t;
|
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
enum osdflags_t
|
|
|
|
{
|
|
|
|
OSD_INITIALIZED = 0x00000001,
|
|
|
|
OSD_DRAW = 0x00000002,
|
|
|
|
OSD_CAPTURE = 0x00000004,
|
|
|
|
OSD_OVERTYPE = 0x00000008,
|
|
|
|
OSD_SHIFT = 0x00000010,
|
|
|
|
OSD_CTRL = 0x00000020,
|
|
|
|
OSD_CAPS = 0x00000040
|
|
|
|
};
|
2009-04-29 06:20:07 +00:00
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
#define OSD_ALIAS (void *)0x1337
|
|
|
|
#define OSD_UNALIASED (void *)0xDEAD
|
2008-06-30 00:18:59 +00:00
|
|
|
|
2006-04-13 20:47:06 +00:00
|
|
|
#define OSDCMD_OK 0
|
|
|
|
#define OSDCMD_SHOWHELP 1
|
|
|
|
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_ParsingScript(void);
|
2008-07-18 23:29:20 +00:00
|
|
|
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_OSDKey(void);
|
|
|
|
int32_t OSD_GetTextMode(void);
|
|
|
|
void OSD_SetTextMode(int32_t mode);
|
2008-07-18 23:29:20 +00:00
|
|
|
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_Exec(const char *szScript);
|
2008-07-18 23:29:20 +00:00
|
|
|
|
|
|
|
char *OSD_GetFmt(char *ptr);
|
2008-07-18 09:50:44 +00:00
|
|
|
char *OSD_GetTextPtr(void);
|
|
|
|
char *OSD_GetFmtPtr(void);
|
2008-06-30 07:30:48 +00:00
|
|
|
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_GetCols(void);
|
2010-05-18 05:14:17 +00:00
|
|
|
int32_t OSD_IsMoving(void);
|
2008-08-17 11:07:28 +00:00
|
|
|
|
2006-04-13 20:47:06 +00:00
|
|
|
// initializes things
|
|
|
|
void OSD_Init(void);
|
|
|
|
|
|
|
|
// sets the file to echo output to
|
|
|
|
void OSD_SetLogFile(char *fn);
|
|
|
|
|
|
|
|
// sets the functions the OSD will call to interrogate the environment
|
|
|
|
void OSD_SetFunctions(
|
2009-01-09 09:29:17 +00:00
|
|
|
void (*drawchar)(int32_t,int32_t,char,int32_t,int32_t),
|
|
|
|
void (*drawstr)(int32_t,int32_t,char*,int32_t,int32_t,int32_t),
|
|
|
|
void (*drawcursor)(int32_t,int32_t,int32_t,int32_t),
|
|
|
|
int32_t (*colwidth)(int32_t),
|
|
|
|
int32_t (*rowheight)(int32_t),
|
|
|
|
void (*clearbg)(int32_t,int32_t),
|
|
|
|
int32_t (*gettime)(void),
|
|
|
|
void (*onshow)(int32_t)
|
2006-04-13 20:47:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
// sets the parameters for presenting the text
|
|
|
|
void OSD_SetParameters(
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t promptshade, int32_t promptpal,
|
|
|
|
int32_t editshade, int32_t editpal,
|
|
|
|
int32_t textshade, int32_t textpal
|
2006-04-13 20:47:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
// sets the scancode for the key which activates the onscreen display
|
2009-01-09 09:29:17 +00:00
|
|
|
void OSD_CaptureKey(int32_t sc);
|
2006-04-13 20:47:06 +00:00
|
|
|
|
|
|
|
// handles keyboard input when capturing input. returns 0 if key was handled
|
|
|
|
// or the scancode if it should be handled by the game.
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_HandleScanCode(int32_t sc, int32_t press);
|
|
|
|
int32_t OSD_HandleChar(char ch);
|
2006-04-13 20:47:06 +00:00
|
|
|
|
|
|
|
// handles the readjustment when screen resolution changes
|
2009-01-09 09:29:17 +00:00
|
|
|
void OSD_ResizeDisplay(int32_t w,int32_t h);
|
2006-04-13 20:47:06 +00:00
|
|
|
|
2006-12-11 03:32:43 +00:00
|
|
|
// captures and frees osd input
|
2009-01-09 09:29:17 +00:00
|
|
|
void OSD_CaptureInput(int32_t cap);
|
2006-12-11 03:32:43 +00:00
|
|
|
|
2006-12-11 04:38:10 +00:00
|
|
|
// sets the console version string
|
2010-05-02 23:27:30 +00:00
|
|
|
void OSD_SetVersion(const char *version, int32_t shade, int32_t pal);
|
2006-12-11 04:38:10 +00:00
|
|
|
|
2006-04-13 20:47:06 +00:00
|
|
|
// shows or hides the onscreen display
|
2009-01-09 09:29:17 +00:00
|
|
|
void OSD_ShowDisplay(int32_t onf);
|
2006-04-13 20:47:06 +00:00
|
|
|
|
|
|
|
// draw the osd to the screen
|
|
|
|
void OSD_Draw(void);
|
|
|
|
|
|
|
|
// just like printf
|
|
|
|
void OSD_Printf(const char *fmt, ...);
|
|
|
|
|
|
|
|
// executes buffered commands
|
|
|
|
void OSD_DispatchQueued(void);
|
|
|
|
|
|
|
|
// executes a string
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_Dispatch(const char *cmd);
|
2006-04-13 20:47:06 +00:00
|
|
|
|
|
|
|
// registers a function
|
|
|
|
// name = name of the function
|
|
|
|
// help = a short help string
|
|
|
|
// func = the entry point to the function
|
2009-01-09 09:29:17 +00:00
|
|
|
int32_t OSD_RegisterFunction(const char *name, const char *help, int32_t (*func)(const osdfuncparm_t*));
|
2006-04-13 20:47:06 +00:00
|
|
|
|
2009-04-29 06:20:07 +00:00
|
|
|
int32_t osdcmd_cvar_set(const osdfuncparm_t *parm);
|
|
|
|
int32_t OSD_RegisterCvar(const cvar_t *cvar);
|
2009-04-30 21:09:44 +00:00
|
|
|
void OSD_WriteCvars(FILE *fp);
|
2009-04-29 06:20:07 +00:00
|
|
|
|
2008-07-18 09:50:44 +00:00
|
|
|
// these correspond to the Duke palettes, so they shouldn't really be here
|
|
|
|
// ...but I don't care
|
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
#define OSDTEXT_BLUE "^00"
|
|
|
|
#define OSDTEXT_GOLD "^07"
|
|
|
|
#define OSDTEXT_DARKRED "^10"
|
|
|
|
#define OSDTEXT_GREEN "^11"
|
|
|
|
#define OSDTEXT_GRAY "^12"
|
|
|
|
#define OSDTEXT_DARKGRAY "^13"
|
2008-07-18 09:50:44 +00:00
|
|
|
#define OSDTEXT_DARKGREEN "^14"
|
2010-05-02 23:27:30 +00:00
|
|
|
#define OSDTEXT_BROWN "^15"
|
|
|
|
#define OSDTEXT_DARKBLUE "^16"
|
|
|
|
#define OSDTEXT_RED "^21"
|
|
|
|
#define OSDTEXT_YELLOW "^23"
|
2008-08-06 11:50:34 +00:00
|
|
|
|
2010-05-02 23:27:30 +00:00
|
|
|
#define OSDTEXT_BRIGHT "^S0"
|
2008-07-18 13:18:12 +00:00
|
|
|
|
2008-07-27 01:22:17 +00:00
|
|
|
#define OSD_ERROR OSDTEXT_DARKRED OSDTEXT_BRIGHT
|
2008-07-18 13:18:12 +00:00
|
|
|
#define TEXTSIZE 32768
|
2008-07-18 09:50:44 +00:00
|
|
|
|
2006-04-13 20:47:06 +00:00
|
|
|
#endif // __osd_h__
|
|
|
|
|