git-svn-id: https://svn.eduke32.com/eduke32@830 1a8010ca-5511-0410-912e-c29ae57300e0

This commit is contained in:
terminx 2008-07-01 11:14:18 +00:00
parent 9091b75be1
commit a7d9ab4603
5 changed files with 141 additions and 47 deletions

View file

@ -2462,9 +2462,10 @@ static void parascan(int dax1, int dax2, int sectnum, char dastat, int bunch)
{ {
wallnum = thewall[z]; nextsectnum = wall[wallnum].nextsector; wallnum = thewall[z]; nextsectnum = wall[wallnum].nextsector;
if(nextsectnum >= 0) { //else negative array access if (nextsectnum >= 0) //else negative array access
if (dastat == 0) j = sector[nextsectnum].ceilingstat; {
else j = sector[nextsectnum].floorstat; if (dastat == 0) j = sector[nextsectnum].ceilingstat;
else j = sector[nextsectnum].floorstat;
} }
if ((nextsectnum < 0) || (wall[wallnum].cstat&32) || ((j&1) == 0)) if ((nextsectnum < 0) || (wall[wallnum].cstat&32) || ((j&1) == 0))

View file

@ -344,7 +344,80 @@ static int _internal_osdfunc_vars(const osdfuncparm_t *parm)
return OSDCMD_OK; return OSDCMD_OK;
} }
} }
if (!Bstrcasecmp(parm->name, "osdcompletionstyle")) else if (!Bstrcasecmp(parm->name, "osdpromptshade"))
{
if (showval) { OSD_Printf("osdpromptshade is %d\n", osdpromptshade); return OSDCMD_OK; }
else
{
osdpromptshade = atoi(parm->parms[0]);
if (osdpromptshade < -128) osdpromptshade = -128;
else if (osdpromptshade > 127) osdpromptshade = 127;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdeditshade"))
{
if (showval) { OSD_Printf("osdeditshade is %d\n", osdeditshade); return OSDCMD_OK; }
else
{
osdeditshade = atoi(parm->parms[0]);
if (osdeditshade < -128) osdeditshade = -128;
else if (osdeditshade > 127) osdeditshade = 127;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdtextshade"))
{
if (showval) { OSD_Printf("osdtextshade is %d\n", osdtextshade); return OSDCMD_OK; }
else
{
osdtextshade = atoi(parm->parms[0]);
if (osdtextshade < -128) osdtextshade = -128;
else if (osdtextshade > 127) osdtextshade = 127;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdpromptpal"))
{
if (showval) { OSD_Printf("osdpromptpal is %d\n", osdpromptpal); return OSDCMD_OK; }
else
{
osdpromptpal = atoi(parm->parms[0]);
if (osdpromptpal < 0) osdpromptpal = 0;
else if (osdpromptpal > MAXPALOOKUPS-1) osdpromptpal = MAXPALOOKUPS;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdeditpal"))
{
if (showval) { OSD_Printf("osdeditpal is %d\n", osdeditpal); return OSDCMD_OK; }
else
{
osdeditpal = atoi(parm->parms[0]);
if (osdeditpal < 0) osdeditpal = 0;
else if (osdeditpal > MAXPALOOKUPS-1) osdeditpal = MAXPALOOKUPS;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdtextpal"))
{
if (showval) { OSD_Printf("osdtextpal is %d\n", osdtextpal); return OSDCMD_OK; }
else
{
osdtextpal = atoi(parm->parms[0]);
if (osdtextpal < 0) osdtextpal = 0;
else if (osdtextpal > MAXPALOOKUPS-1) osdtextpal = MAXPALOOKUPS;
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
}
else if (!Bstrcasecmp(parm->name, "osdcompletionstyle"))
{ {
if (showval) { OSD_Printf("osdcompletionstyle is %d\n", osdcompletionstyle); return OSDCMD_OK; } if (showval) { OSD_Printf("osdcompletionstyle is %d\n", osdcompletionstyle); return OSDCMD_OK; }
else else
@ -356,17 +429,16 @@ static int _internal_osdfunc_vars(const osdfuncparm_t *parm)
return OSDCMD_OK; return OSDCMD_OK;
} }
} }
else else if (!Bstrcasecmp(parm->name, "logcutoff"))
if (!Bstrcasecmp(parm->name, "logcutoff")) {
if (showval) { OSD_Printf("logcutoff is %d\n", logcutoff); return OSDCMD_OK; }
else
{ {
if (showval) { OSD_Printf("logcutoff is %d\n", logcutoff); return OSDCMD_OK; } logcutoff = atoi(parm->parms[0]);
else OSD_Printf("%s\n",parm->raw);
{ return OSDCMD_OK;
logcutoff = atoi(parm->parms[0]);
OSD_Printf("%s\n",parm->raw);
return OSDCMD_OK;
}
} }
}
return OSDCMD_SHOWHELP; return OSDCMD_SHOWHELP;
} }
@ -474,6 +546,12 @@ void OSD_Init(void)
OSD_RegisterFunction("unalias","unalias: removes an alias created with \"alias\"",_internal_osdfunc_unalias); OSD_RegisterFunction("unalias","unalias: removes an alias created with \"alias\"",_internal_osdfunc_unalias);
OSD_RegisterFunction("exec","exec <scriptfile>: executes a script", _internal_osdfunc_exec); OSD_RegisterFunction("exec","exec <scriptfile>: executes a script", _internal_osdfunc_exec);
OSD_RegisterFunction("osdcompletionstyle","osdcompletionstyle: sets the type of tab completion to be used in the OSD; 0 (default) = bash style, 1 = cycling style",_internal_osdfunc_vars); OSD_RegisterFunction("osdcompletionstyle","osdcompletionstyle: sets the type of tab completion to be used in the OSD; 0 (default) = bash style, 1 = cycling style",_internal_osdfunc_vars);
OSD_RegisterFunction("osdpromptshade","osdpromptshade: sets the shade of the OSD prompt",_internal_osdfunc_vars);
OSD_RegisterFunction("osdeditshade","osdeditshade: sets the shade of the OSD input text",_internal_osdfunc_vars);
OSD_RegisterFunction("osdtextshade","osdtextshade: sets the shade of the OSD text",_internal_osdfunc_vars);
OSD_RegisterFunction("osdpromptpal","osdpromptpal: sets the palette of the OSD prompt",_internal_osdfunc_vars);
OSD_RegisterFunction("osdeditpal","osdeditpal: sets the palette of the OSD input text",_internal_osdfunc_vars);
OSD_RegisterFunction("osdtextpal","osdtextpal: sets the palette of the OSD text",_internal_osdfunc_vars);
atexit(OSD_Cleanup); atexit(OSD_Cleanup);
} }
@ -554,9 +632,17 @@ void OSD_CaptureKey(int sc)
// //
// OSD_FindDiffPoint() -- Finds the length of the longest common prefix of 2 strings, stolen from ZDoom // OSD_FindDiffPoint() -- Finds the length of the longest common prefix of 2 strings, stolen from ZDoom
// //
static int OSD_FindDiffPoint (const char *str1, const char *str2) { int i; static int OSD_FindDiffPoint(const char *str1, const char *str2)
for (i = 0; Btolower(str1[i]) == Btolower(str2[i]); i++) if (str1[i] == 0 || str2[i] == 0) break; {
return i; } int i;
for (i = 0; Btolower(str1[i]) == Btolower(str2[i]); i++)
if (str1[i] == 0 || str2[i] == 0)
break;
return i;
}
// //
// OSD_HandleKey() -- Handles keyboard input when capturing input. // OSD_HandleKey() -- Handles keyboard input when capturing input.
// Returns 0 if the key was handled internally, or the scancode if it should // Returns 0 if the key was handled internally, or the scancode if it should
@ -651,10 +737,10 @@ int OSD_HandleKey(int sc, int press)
{ {
if (findsymbol(osdedittmp, tabc->next)) if (findsymbol(osdedittmp, tabc->next))
{ {
char tempbuf[512];
symbol_t *symb=tabc; symbol_t *symb=tabc;
int maxwidth = 0, x = 0; int maxwidth = 0, x = 0;
OSD_Printf("Completions for '%s':\n",osdedittmp);
while (symb && symb != lastmatch) while (symb && symb != lastmatch)
{ {
int diffpt; int diffpt;
@ -673,6 +759,13 @@ int OSD_HandleKey(int sc, int press)
lastmatch = symb; lastmatch = symb;
symb=findsymbol(osdedittmp, lastmatch->next); symb=findsymbol(osdedittmp, lastmatch->next);
} }
if (!osdcompletionstyle)
{
Bstrncpy(tempbuf,tabc->name,commonsize);
tempbuf[commonsize] = '\0';
}
else Bstrcpy(tempbuf,osdedittmp);
OSD_Printf("Completions for '%s':\n",tempbuf);
maxwidth += 3; maxwidth += 3;
symb = tabc; symb = tabc;
OSD_Printf(" "); OSD_Printf(" ");
@ -712,7 +805,7 @@ int OSD_HandleKey(int sc, int press)
for (i=osdeditcursor;i>0;i--) if (osdeditbuf[i-1] == ' ') break; for (i=osdeditcursor;i>0;i--) if (osdeditbuf[i-1] == ' ') break;
osdeditlen = i; osdeditlen = i;
for (j=0;tabc->name[j] && osdeditlen <= EDITLENGTH for (j=0;tabc->name[j] && osdeditlen <= EDITLENGTH
&& (!osdcompletionstyle?osdeditlen < commonsize:1);i++,j++,osdeditlen++) && (!osdcompletionstyle?osdeditlen < commonsize:1);i++,j++,osdeditlen++)
osdeditbuf[i] = tabc->name[j]; osdeditbuf[i] = tabc->name[j];
osdeditcursor = osdeditlen; osdeditcursor = osdeditlen;
osdeditwinend = osdeditcursor; osdeditwinend = osdeditcursor;

View file

@ -862,10 +862,10 @@ void CONFIG_WriteBinds(void) // save binds and aliases to disk
if (symb->func == (void *)OSD_ALIAS) if (symb->func == (void *)OSD_ALIAS)
fprintf(fp,"alias %s \"%s\"\n", symb->name, symb->help); fprintf(fp,"alias %s \"%s\"\n", symb->name, symb->help);
/* for (i = 0; i < sizeof(cvar)/sizeof(cvarmappings); i++) /* for (i = 0; i < sizeof(cvar)/sizeof(cvarmappings); i++)
if (!(cvar[i].type&CVAR_NOSAVE)) if (!(cvar[i].type&CVAR_NOSAVE))
fprintf(fp,"%s \"%d\"\n",cvar[i].name,*(int*)cvar[i].var); fprintf(fp,"%s \"%d\"\n",cvar[i].name,*(int*)cvar[i].var);
*/ */
fclose(fp); fclose(fp);
} }
} }

View file

@ -21,27 +21,27 @@ void GAME_drawosdstr(int x, int y, char *ch, int len, int shade, int pal)
for (x = (x<<3)+x; len>0; len--, ch++, x++) for (x = (x<<3)+x; len>0; len--, ch++, x++)
{ {
/* if (*ch == '^' && isdigit(*(ch+1))) /* if (*ch == '^' && isdigit(*(ch+1)))
{ {
char smallbuf[4]; char smallbuf[4];
ch++, len--; ch++, len--;
if (isdigit(*(ch+1))) if (isdigit(*(ch+1)))
{ {
smallbuf[0] = *(ch++); smallbuf[0] = *(ch++);
len--; len--;
smallbuf[1] = *(ch); smallbuf[1] = *(ch);
smallbuf[2] = '\0'; smallbuf[2] = '\0';
pal = atol(smallbuf); pal = atol(smallbuf);
} }
else else
{ {
smallbuf[0] = *(ch); smallbuf[0] = *(ch);
smallbuf[1] = '\0'; smallbuf[1] = '\0';
pal = atol(smallbuf); pal = atol(smallbuf);
} }
x--; x--;
continue; continue;
} */ } */
if (*ch == 32) if (*ch == 32)
{ {
// x+=5; // x+=5;
@ -52,8 +52,8 @@ void GAME_drawosdstr(int x, int y, char *ch, int len, int shade, int pal)
if (ac < STARTALPHANUM || ac > ENDALPHANUM) return; if (ac < STARTALPHANUM || ac > ENDALPHANUM) return;
rotatesprite(x<<16, (y<<3)<<16, 65536l, 0, ac, shade, pal, 8|16, 0, 0, xdim-1, ydim-1); rotatesprite(x<<16, (y<<3)<<16, 65536l, 0, ac, shade, pal, 8|16, 0, 0, xdim-1, ydim-1);
/* if (*ch >= '0' && *ch <= '9') x+=8; /* if (*ch >= '0' && *ch <= '9') x+=8;
else x += tilesizx[ac]; */ else x += tilesizx[ac]; */
x += OSDCHAR_WIDTH; x += OSDCHAR_WIDTH;
} }
} }