Patch from hunter_rus.

Adds:
 - maximal log line count and OSD variable "logcutoff"
 - ability to define different models for each palette
 - "bind" OSD command to bind keys so that they run command batch files

git-svn-id: https://svn.eduke32.com/eduke32@591 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
plagman 2008-01-04 01:04:35 +00:00
parent cfa399998a
commit a8a675634e
5 changed files with 200 additions and 23 deletions

View file

@ -201,8 +201,13 @@ static tile2model_t tile2model[MAXTILES+EXTRATILES];
int addtileP(int model,int tile,int pallet) int addtileP(int model,int tile,int pallet)
{ {
if (curextra==MAXTILES+EXTRATILES-2)return curextra; if (curextra==MAXTILES+EXTRATILES-2)return curextra;
if (tile2model[tile].modelid==-1)return tile; if (tile2model[tile].modelid==-1){tile2model[tile].pal=pallet;return tile;}
while (tile2model[tile].next!=-1)tile=tile2model[tile].next; if (tile2model[tile].pal==pallet)return tile;
while(tile2model[tile].next!=-1)
{
tile=tile2model[tile].next;
if(tile2model[tile].pal==pallet)return tile;
}
tile2model[tile].next=curextra; tile2model[tile].next=curextra;
tile2model[curextra].pal=pallet; tile2model[curextra].pal=pallet;
return curextra++; return curextra++;

View file

@ -88,6 +88,10 @@ static int osdhistorysize=0; // number of entries in history
// the execution buffer works from the command history // the execution buffer works from the command history
static int osdexeccount=0; // number of lines from the head of the history buffer to execute static int osdexeccount=0; // number of lines from the head of the history buffer to execute
// maximal log line count
int logcutoff=120000;
int linecnt;
// presentation parameters // presentation parameters
static int osdpromptshade=0; static int osdpromptshade=0;
static int osdpromptpal=0; static int osdpromptpal=0;
@ -210,7 +214,14 @@ static int _internal_osdfunc_vars(const osdfuncparm_t *parm)
osdrows = atoi(parm->parms[0]); osdrows = atoi(parm->parms[0]);
if (osdrows < 1) osdrows = 1; if (osdrows < 1) osdrows = 1;
else if (osdrows > osdmaxrows) osdrows = osdmaxrows; else if (osdrows > osdmaxrows) osdrows = osdmaxrows;
osdrowscur = osdrows; if(osdrowscur!=-1)osdrowscur = osdrows;
return OSDCMD_OK;
}
} else
if (!Bstrcasecmp(parm->name, "logcutoff")) {
if (showval) { OSD_Printf("logcutoff is %d\n", logcutoff); return OSDCMD_OK; }
else {
logcutoff = atoi(parm->parms[0]);
return OSDCMD_OK; return OSDCMD_OK;
} }
} }
@ -289,6 +300,7 @@ void OSD_Init(void)
OSD_RegisterFunction("listsymbols","listsymbols: lists all the recognized symbols",_internal_osdfunc_listsymbols); OSD_RegisterFunction("listsymbols","listsymbols: lists all the recognized symbols",_internal_osdfunc_listsymbols);
OSD_RegisterFunction("help","help: displays help on the named symbol",_internal_osdfunc_help); OSD_RegisterFunction("help","help: displays help on the named symbol",_internal_osdfunc_help);
OSD_RegisterFunction("osdrows","osdrows: sets the number of visible lines of the OSD",_internal_osdfunc_vars); OSD_RegisterFunction("osdrows","osdrows: sets the number of visible lines of the OSD",_internal_osdfunc_vars);
OSD_RegisterFunction("logcutoff","logcutoff: sets the maximal line count of the log file",_internal_osdfunc_vars);
OSD_RegisterFunction("clear","clear: clears the console text buffer",_internal_osdfunc_clear); OSD_RegisterFunction("clear","clear: clears the console text buffer",_internal_osdfunc_clear);
atexit(OSD_Cleanup); atexit(OSD_Cleanup);
@ -861,7 +873,7 @@ void OSD_Draw(void)
while (j > -1) while (j > -1)
{ {
osdrowscur++; osdrowscur++;
j -= 10; j -= 200/osdrows;
if (osdrowscur > osdrows-1) if (osdrowscur > osdrows-1)
break; break;
} }
@ -872,7 +884,7 @@ void OSD_Draw(void)
while (j > -1) while (j > -1)
{ {
osdrowscur--; osdrowscur--;
j -= 10; j -= 200/osdrows;
if (osdrowscur < 1) if (osdrowscur < 1)
break; break;
} }
@ -937,7 +949,17 @@ void OSD_Printf(const char *fmt, ...)
Bvsnprintf(tmpstr, 1024, fmt, va); Bvsnprintf(tmpstr, 1024, fmt, va);
va_end(va); va_end(va);
if (osdlog) Bfputs(tmpstr, osdlog); if(linecnt<logcutoff)
{
if (osdlog&&(!logcutoff||linecnt<logcutoff))
Bfputs(tmpstr, osdlog);
}
else if(linecnt==logcutoff)
{
Bfputs("\nMaximal log size reached. Logging stopped.\nSet the \"logcutoff\" console variable to a higher value if you need a longer log.\n", osdlog);
linecnt=logcutoff+1;
}
for (chp = tmpstr; *chp; chp++) for (chp = tmpstr; *chp; chp++)
{ {
@ -945,6 +967,7 @@ void OSD_Printf(const char *fmt, ...)
else if (*chp == '\n') else if (*chp == '\n')
{ {
osdpos=0; osdpos=0;
linecnt++;
linefeed(); linefeed();
} }
else else

View file

@ -989,6 +989,24 @@ extern playerspawn_t g_PlayerSpawnPoints[MAXPLAYERS];
extern playerdata_t g_player[MAXPLAYERS]; extern playerdata_t g_player[MAXPLAYERS];
#include "funct.h" #include "funct.h"
// key bindings stuff
#define MAXSCRIPTFILENAMELENGTH 32
#define MAXBOUNDKEYS 256
typedef struct {
char *name;
int id;
} keydef;
extern keydef keynames[];
typedef struct binding {
char name[MAXSCRIPTFILENAMELENGTH];
char *key;
} keybind;
extern keybind boundkeys[MAXBOUNDKEYS];
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View file

@ -147,6 +147,104 @@ static char recbuf[180];
extern void computergetinput(int snum, input *syn); extern void computergetinput(int snum, input *syn);
keydef keynames[]=
{
{"COMMA", sc_Comma},
{"PERIOD", sc_Period},
{"ENTER", sc_Enter},
{"ESCAPE", sc_Escape},
{"SPACE", sc_Space},
{"BACKSPACE", sc_BackSpace},
{"TAB", sc_Tab},
{"LEFTALT", sc_LeftAlt},
{"LEFTCONTROL", sc_LeftControl},
{"CAPSLOCK", sc_CapsLock},
{"LEFTSHIFT", sc_LeftShift},
{"RIGHTSHIFT", sc_RightShift},
{"F1", sc_F1},
{"F2", sc_F2},
{"F3", sc_F3},
{"F4", sc_F4},
{"F5", sc_F5},
{"F6", sc_F6},
{"F7", sc_F7},
{"F8", sc_F8},
{"F9", sc_F9},
{"F10", sc_F10},
{"F11", sc_F11},
{"F12", sc_F12},
{"KPAD_STAR", sc_Kpad_Star},
{"PAUSE", sc_Pause},
{"SCROLLLOCK", sc_ScrollLock},
{"NUMLOCK", sc_NumLock},
{"SLASH", sc_Slash},
{"SEMICOLON", sc_SemiColon},
{"QUOTE", sc_Quote},
{"TILDE", sc_Tilde},
{"BACKSLASH", sc_BackSlash},
{"OPENBRACKET", sc_OpenBracket},
{"CLOSEBRACKET",sc_CloseBracket},
{"1", sc_1},
{"2", sc_2},
{"3", sc_3},
{"4", sc_4},
{"5", sc_5},
{"6", sc_6},
{"7", sc_7},
{"8", sc_8},
{"9", sc_9},
{"0", sc_0},
{"MINUS", sc_Minus},
{"EQUALS", sc_Equals},
{"PLUS", sc_Plus},
{"KPAD_1", sc_kpad_1},
{"KPAD_2", sc_kpad_2},
{"KPAD_3", sc_kpad_3},
{"KPAD_4", sc_kpad_4},
{"KPAD_5", sc_kpad_5},
{"KPAD_6", sc_kpad_6},
{"KPAD_7", sc_kpad_7},
{"KPAD_8", sc_kpad_8},
{"KPAD_9", sc_kpad_9},
{"KPAD_0", sc_kpad_0},
{"KPAD_MINUS", sc_kpad_Minus},
{"KPAD_PLUS", sc_kpad_Plus},
{"KPAD_PERIOD", sc_kpad_Period},
{"A", sc_A},
{"B", sc_B},
{"C", sc_C},
{"D", sc_D},
{"E", sc_E},
{"F", sc_F},
{"G", sc_G},
{"H", sc_H},
{"I", sc_I},
{"J", sc_J},
{"K", sc_K},
{"L", sc_L},
{"M", sc_M},
{"N", sc_N},
{"O", sc_O},
{"P", sc_P},
{"Q", sc_Q},
{"R", sc_R},
{"S", sc_S},
{"T", sc_T},
{"U", sc_U},
{"V", sc_V},
{"W", sc_W},
{"X", sc_X},
{"Y", sc_Y},
{"Z", sc_Z},
{0,0}
};
keybind boundkeys[MAXBOUNDKEYS];
enum enum
{ {
T_EOF = -2, T_EOF = -2,
@ -7671,11 +7769,34 @@ FOUNDCHEAT:
} }
} }
int load_script(const char *szScript)
{
FILE* fp = fopenfrompath(szScript, "r");
if (fp != NULL)
{
char line[255];
OSD_Printf("Executing \"%s\"\n", szScript);
while (fgets(line ,sizeof(line)-1, fp) != NULL)
OSD_Dispatch(strtok(line,"\r\n"));
fclose(fp);
return 0;
}
return 1;
}
static void nonsharedkeys(void) static void nonsharedkeys(void)
{ {
int i,ch; int i,ch;
int j; int j;
for(i=0;i<256;i++)
if (*boundkeys[i].name&&KB_KeyPressed(i))
{
load_script(boundkeys[i].name);
KB_ClearKeyDown(i);
}
if (ud.recstat == 2) if (ud.recstat == 2)
{ {
ControlInfo noshareinfo; ControlInfo noshareinfo;
@ -9823,23 +9944,6 @@ void backtomenu(void)
else wm_setapptitle(HEAD); else wm_setapptitle(HEAD);
} }
int load_script(const char *szScript)
{
FILE* fp = fopenfrompath(szScript, "r");
if (fp != NULL)
{
char line[255];
OSD_Printf("Executing \"%s\"\n", szScript);
while (fgets(line ,sizeof(line)-1, fp) != NULL)
OSD_Dispatch(strtok(line,"\r\n"));
fclose(fp);
return 0;
}
return 1;
}
void app_main(int argc,const char **argv) void app_main(int argc,const char **argv)
{ {
int i, j; int i, j;

View file

@ -943,6 +943,32 @@ static int osdcmd_name(const osdfuncparm_t *parm)
return OSDCMD_OK; return OSDCMD_OK;
} }
static int osdcmd_bind(const osdfuncparm_t *parm)
{
int i;
if (parm->numparms==1&&!strcmpi(parm->parms[0],"showkeys"))
{
for(i=0;keynames[i].name;i++)OSD_Printf("%s\n",keynames[i].name);
return OSDCMD_OK;
}
if (parm->numparms==0)
{
OSD_Printf("Keybindings:\n");
for(i=0;i<MAXBOUNDKEYS;i++)if(*boundkeys[i].name)
OSD_Printf("%-11s = %s\n",boundkeys[i].key,boundkeys[i].name);
return OSDCMD_OK;
}
if (parm->numparms < 2) return OSDCMD_SHOWHELP;
for(i=0;keynames[i].name;i++)if(!strcmpi(parm->parms[0],keynames[i].name))break;
if (!keynames[i].name) return OSDCMD_SHOWHELP;
Bstrncpy(boundkeys[keynames[i].id].name,parm->parms[1], MAXSCRIPTFILENAMELENGTH-1);
boundkeys[keynames[i].id].key=keynames[i].name;
return OSDCMD_OK;
}
int registerosdcommands(void) int registerosdcommands(void)
{ {
unsigned int i; unsigned int i;
@ -998,6 +1024,7 @@ int registerosdcommands(void)
OSD_RegisterFunction("vidmode","vidmode [xdim ydim] [bpp] [fullscreen]: immediately change the video mode",osdcmd_vidmode); OSD_RegisterFunction("vidmode","vidmode [xdim ydim] [bpp] [fullscreen]: immediately change the video mode",osdcmd_vidmode);
OSD_RegisterFunction("bind","bind <key> <scriptfile>: executes a command script when <key> gets pressed. Type \"bind showkeys\" for a list of keys.", osdcmd_bind);
//baselayer_onvideomodechange = onvideomodechange; //baselayer_onvideomodechange = onvideomodechange;
return 0; return 0;