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

This commit is contained in:
terminx 2008-12-31 09:07:49 +00:00
parent 695829d357
commit ac7607a8bb
12 changed files with 73 additions and 40 deletions

View file

@ -102,6 +102,7 @@ void setmousepresscallback(void (*callback)(int,int));
void setjoypresscallback(void (*callback)(int,int)); void setjoypresscallback(void (*callback)(int,int));
const unsigned char *getkeyname(int num); const unsigned char *getkeyname(int num);
const unsigned char *getjoyname(int what, int num); // what: 0=axis, 1=button, 2=hat const unsigned char *getjoyname(int what, int num); // what: 0=axis, 1=button, 2=hat
char *strtolower(char *str, int len);
unsigned char bgetchar(void); unsigned char bgetchar(void);
int bkbhit(void); int bkbhit(void);

View file

@ -47,6 +47,19 @@ struct glinfo glinfo =
}; };
#endif #endif
char *strtolower(char *str, int len)
{
int i = 0;
if (len <= 0) return str;
do
{
*(str+i) = Btolower(*(str+i));
i++;
}
while (--len);
return str;
}
static void onvideomodechange(int newmode) { UNREFERENCED_PARAMETER(newmode); } static void onvideomodechange(int newmode) { UNREFERENCED_PARAMETER(newmode); }
void (*baselayer_onvideomodechange)(int) = onvideomodechange; void (*baselayer_onvideomodechange)(int) = onvideomodechange;

View file

@ -3072,7 +3072,8 @@ SKIP:
posx = mousxplc; posx = mousxplc;
posy = mousyplc; posy = mousyplc;
} }
_printmessage16("Zoom: %d",zoom); if (zoom > 16384) zoom = 16384;
printmessage16("Zoom: %d",zoom);
} }
if ((keystatus[buildkeys[BK_MOVEDOWN]] || (bstatus&32)) && (zoom > 8)) if ((keystatus[buildkeys[BK_MOVEDOWN]] || (bstatus&32)) && (zoom > 8))
{ {
@ -3084,10 +3085,9 @@ SKIP:
posx = mousxplc; posx = mousxplc;
posy = mousyplc; posy = mousyplc;
} }
_printmessage16("Zoom: %d",zoom); if (zoom < 8) zoom = 8;
printmessage16("Zoom: %d",zoom);
} }
if (zoom < 8) zoom = 8;
if (zoom > 16384) zoom = 16384;
if (keystatus[0x22]) // G (grid on/off) if (keystatus[0x22]) // G (grid on/off)
{ {

View file

@ -65,6 +65,7 @@ extern int remapinit;
extern double msens; extern double msens;
extern int editorgridextent; extern int editorgridextent;
extern int showheightindicators; extern int showheightindicators;
extern int graphicsmode;
/* /*
* SETUP.DAT * SETUP.DAT
@ -228,6 +229,9 @@ int loadsetup(const char *fn)
if (readconfig(fp, "showheightindicators", val, VL) > 0) if (readconfig(fp, "showheightindicators", val, VL) > 0)
showheightindicators = min(max(Batoi(val),0),2); showheightindicators = min(max(Batoi(val),0),2);
if (readconfig(fp, "graphicsmode", val, VL) > 0)
graphicsmode = min(max(Batoi(val),0),2);
#ifdef _WIN32 #ifdef _WIN32
{ {
extern char map_dik_code(int); extern char map_dik_code(int);
@ -373,6 +377,9 @@ int writesetup(const char *fn)
"\n" "\n"
"; Height indicators (0:none, 1:only 2-sided&different, 2:all)\n" "; Height indicators (0:none, 1:only 2-sided&different, 2:all)\n"
"showheightindicators = %d\n\n" "showheightindicators = %d\n\n"
"\n"
"; 2D mode display type (0:classic, 1:textured, 2:textured/animated)\n"
"graphicsmode = %d\n\n"
#if 1 #if 1
"; Key Settings\n" "; Key Settings\n"
"; Here's a map of all the keyboard scan codes: NOTE: values are listed in hex!\n" "; Here's a map of all the keyboard scan codes: NOTE: values are listed in hex!\n"
@ -434,7 +441,7 @@ int writesetup(const char *fn)
#endif #endif
option[3], msens, unrealedlook, pk_uedaccel, quickmapcycling, option[3], msens, unrealedlook, pk_uedaccel, quickmapcycling,
revertCTRL,scrollamount,pk_turnaccel,pk_turndecel,autosave, revertCTRL,scrollamount,pk_turnaccel,pk_turndecel,autosave,
showheightindicators, showheightindicators,graphicsmode,
#if 1 #if 1
keys[0], keys[1], keys[2], keys[3], keys[4], keys[5], keys[0], keys[1], keys[2], keys[3], keys[4], keys[5],
keys[6], keys[7], keys[8], keys[9], keys[10], keys[11], keys[6], keys[7], keys[8], keys[9], keys[10], keys[11],

View file

@ -105,7 +105,7 @@ static int osdcursorpal=0; */
static symbol_t *osdsymbptrs[MAXSYMBOLS]; static symbol_t *osdsymbptrs[MAXSYMBOLS];
static int osdnumsymbols = 0; static int osdnumsymbols = 0;
static struct HASH_table osdsymbolsH = { MAXSYMBOLS<<1, NULL }; static struct HASH_table osdsymbolsH = { MAXSYMBOLS<<1, NULL };
// application callbacks // application callbacks
static void (*drawosdchar)(int, int, char, int, int) = _internal_drawosdchar; static void (*drawosdchar)(int, int, char, int, int) = _internal_drawosdchar;
@ -1790,6 +1790,7 @@ void OSD_SetVersionString(const char *version, int shade, int pal)
static symbol_t *addnewsymbol(const char *name) static symbol_t *addnewsymbol(const char *name)
{ {
symbol_t *newsymb, *s, *t; symbol_t *newsymb, *s, *t;
char *lname;
if (osdnumsymbols >= MAXSYMBOLS) return NULL; if (osdnumsymbols >= MAXSYMBOLS) return NULL;
newsymb = (symbol_t *)Bmalloc(sizeof(symbol_t)); newsymb = (symbol_t *)Bmalloc(sizeof(symbol_t));
@ -1823,6 +1824,9 @@ static symbol_t *addnewsymbol(const char *name)
} }
} }
HASH_add(&osdsymbolsH, name, osdnumsymbols); HASH_add(&osdsymbolsH, name, osdnumsymbols);
lname = strtolower(Bstrdup(name),Bstrlen(name));
HASH_add(&osdsymbolsH, lname, osdnumsymbols);
Bfree(lname);
osdsymbptrs[osdnumsymbols++] = newsymb; osdsymbptrs[osdnumsymbols++] = newsymb;
return newsymb; return newsymb;
} }
@ -1842,7 +1846,6 @@ static symbol_t *findsymbol(const char *name, symbol_t *startingat)
return NULL; return NULL;
} }
// //
// findexactsymbol() -- Finds a symbol, complete named // findexactsymbol() -- Finds a symbol, complete named
// //
@ -1852,9 +1855,6 @@ static symbol_t *findexactsymbol(const char *name)
char *lname = Bstrdup(name); char *lname = Bstrdup(name);
if (!symbols) return NULL; if (!symbols) return NULL;
for (i=Bstrlen(lname);i>=0;i--)
lname[i] = Btolower(lname[i]);
i = HASH_find(&osdsymbolsH,lname); i = HASH_find(&osdsymbolsH,lname);
if (i > -1) if (i > -1)
{ {
@ -1863,7 +1863,14 @@ static symbol_t *findexactsymbol(const char *name)
Bfree(lname); Bfree(lname);
return osdsymbptrs[i]; return osdsymbptrs[i];
} }
// try it again
lname = strtolower(lname, Bstrlen(name));
i = HASH_find(&osdsymbolsH,lname);
Bfree(lname); Bfree(lname);
if (i > -1)
return osdsymbptrs[i];
return NULL; return NULL;
} }

View file

@ -4152,7 +4152,7 @@ static LRESULT CALLBACK WndProcCallback(HWND hWnd, UINT uMsg, WPARAM wParam, LPA
grabmouse(1); grabmouse(1);
regrabmouse = 0; regrabmouse = 0;
} }
ShowWindow(hWindow, SW_SHOWNORMAL); ShowWindow(hWindow, SW_RESTORE);
SetForegroundWindow(hWindow); SetForegroundWindow(hWindow);
SetFocus(hWindow); SetFocus(hWindow);
setgamemode(realfs,xdim,ydim,bpp); setgamemode(realfs,xdim,ydim,bpp);

View file

@ -44,7 +44,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include <shellapi.h> #include <shellapi.h>
#endif #endif
#define BUILDDATE " 20081228" #define BUILDDATE " 20081230"
#define VERSION " 1.2.0devel" #define VERSION " 1.2.0devel"
static int floor_over_floor; static int floor_over_floor;

View file

@ -57,10 +57,18 @@ int32 CONFIG_FunctionNameToNum(char * func)
{ {
int32 i; int32 i;
i = HASH_findcase(&gamefuncH,func); i = HASH_find(&gamefuncH,func);
if (i > -1)
if (i < 0)
{
char *str = strtolower(Bstrdup(func),Bstrlen(func));
i = HASH_find(&gamefuncH,str);
Bfree(str);
return i; return i;
return -1; }
return i;
} }
/* /*

View file

@ -10926,7 +10926,12 @@ void app_main(int argc,const char **argv)
HASH_init(&gamefuncH); HASH_init(&gamefuncH);
for (i=NUMGAMEFUNCTIONS-1;i>=0;i--) for (i=NUMGAMEFUNCTIONS-1;i>=0;i--)
{
char *str = strtolower(Bstrdup(gamefunctions[i]),Bstrlen(gamefunctions[i]));
HASH_add(&gamefuncH,gamefunctions[i],i); HASH_add(&gamefuncH,gamefunctions[i],i);
HASH_add(&gamefuncH,str,i);
Bfree(str);
}
i = CONFIG_ReadSetup(); i = CONFIG_ReadSetup();
if (getenv("DUKE3DGRP")) duke3dgrp = getenv("DUKE3DGRP"); if (getenv("DUKE3DGRP")) duke3dgrp = getenv("DUKE3DGRP");

View file

@ -1410,20 +1410,6 @@ static inline int isaltok(char c)
return (isalnum(c) || c == '{' || c == '}' || c == '/' || c == '*' || c == '-' || c == '_' || c == '.'); return (isalnum(c) || c == '{' || c == '}' || c == '/' || c == '*' || c == '-' || c == '_' || c == '.');
} }
// strlower -- makes a string in memory lowercase and returns a pointer
static char *strtolower(char *str, int len)
{
int i = 0;
if (len <= 0) return str;
do
{
*(str+i) = Btolower(*(str+i));
i++;
}
while (--len);
return str;
}
static inline int GetLabelNameid(const memberlabel_t *pLabel, struct HASH_table *tH, const char *psz) static inline int GetLabelNameid(const memberlabel_t *pLabel, struct HASH_table *tH, const char *psz)
{ {
// find the label psz in the table pLabel. // find the label psz in the table pLabel.
@ -4736,6 +4722,12 @@ repeatcase:
gamefunctions[j][i] = '\0'; gamefunctions[j][i] = '\0';
keydefaults[j*3][i] = '\0'; keydefaults[j*3][i] = '\0';
HASH_add(&gamefuncH,gamefunctions[j],j); HASH_add(&gamefuncH,gamefunctions[j],j);
{
char *str = strtolower(Bstrdup(gamefunctions[j]),Bstrlen(gamefunctions[j]));
HASH_add(&gamefuncH,str,j);
Bfree(str);
}
return 0; return 0;
case CON_DEFINESKILLNAME: case CON_DEFINESKILLNAME:

View file

@ -440,7 +440,7 @@ static void X_Move(void)
intptr_t *moveptr; intptr_t *moveptr;
int a = g_sp->hitag, goalang, angdif; int a = g_sp->hitag, goalang, angdif;
int daxvel; int daxvel;
int dead = (A_CheckEnemySprite(g_sp) && g_sp->extra <= 0); int deadflag = (A_CheckEnemySprite(g_sp) && g_sp->extra <= 0);
if (a == -1) a = 0; if (a == -1) a = 0;
@ -448,7 +448,7 @@ static void X_Move(void)
if (g_t[1] == 0 || a == 0) if (g_t[1] == 0 || a == 0)
{ {
if ((ActorExtra[g_i].bposx != g_sp->x) || (ActorExtra[g_i].bposy != g_sp->y)) if (deadflag || (ActorExtra[g_i].bposx != g_sp->x) || (ActorExtra[g_i].bposy != g_sp->y))
{ {
ActorExtra[g_i].bposx = g_sp->x; ActorExtra[g_i].bposx = g_sp->x;
ActorExtra[g_i].bposy = g_sp->y; ActorExtra[g_i].bposy = g_sp->y;
@ -457,7 +457,7 @@ static void X_Move(void)
return; return;
} }
if (a&face_player && !dead) if (a&face_player && !deadflag)
{ {
if (g_player[g_p].ps->newowner >= 0) if (g_player[g_p].ps->newowner >= 0)
goalang = getangle(g_player[g_p].ps->oposx-g_sp->x,g_player[g_p].ps->oposy-g_sp->y); goalang = getangle(g_player[g_p].ps->oposx-g_sp->x,g_player[g_p].ps->oposy-g_sp->y);
@ -468,10 +468,10 @@ static void X_Move(void)
g_sp->ang += angdif; g_sp->ang += angdif;
} }
if (a&spin && !dead) if (a&spin && !deadflag)
g_sp->ang += sintable[((g_t[0]<<3)&2047)]>>6; g_sp->ang += sintable[((g_t[0]<<3)&2047)]>>6;
if (a&face_player_slow && !dead) if (a&face_player_slow && !deadflag)
{ {
if (g_player[g_p].ps->newowner >= 0) if (g_player[g_p].ps->newowner >= 0)
goalang = getangle(g_player[g_p].ps->oposx-g_sp->x,g_player[g_p].ps->oposy-g_sp->y); goalang = getangle(g_player[g_p].ps->oposx-g_sp->x,g_player[g_p].ps->oposy-g_sp->y);
@ -482,13 +482,13 @@ static void X_Move(void)
g_sp->ang += angdif; g_sp->ang += angdif;
} }
if (((a&jumptoplayer) == jumptoplayer) && !dead) if (((a&jumptoplayer) == jumptoplayer) && !deadflag)
{ {
if (g_t[0] < 16) if (g_t[0] < 16)
g_sp->zvel -= (sintable[(512+(g_t[0]<<4))&2047]>>5); g_sp->zvel -= (sintable[(512+(g_t[0]<<4))&2047]>>5);
} }
if (a&face_player_smart && !dead) if (a&face_player_smart && !deadflag)
{ {
int newx = g_player[g_p].ps->posx+(g_player[g_p].ps->posxv/768); int newx = g_player[g_p].ps->posx+(g_player[g_p].ps->posxv/768);
int newy = g_player[g_p].ps->posy+(g_player[g_p].ps->posyv/768); int newy = g_player[g_p].ps->posy+(g_player[g_p].ps->posyv/768);
@ -505,10 +505,10 @@ static void X_Move(void)
if (a&geth) g_sp->xvel += (*moveptr-g_sp->xvel)>>1; if (a&geth) g_sp->xvel += (*moveptr-g_sp->xvel)>>1;
if (a&getv) g_sp->zvel += ((*(moveptr+1)<<4)-g_sp->zvel)>>1; if (a&getv) g_sp->zvel += ((*(moveptr+1)<<4)-g_sp->zvel)>>1;
if (a&dodgebullet && !dead) if (a&dodgebullet && !deadflag)
A_Dodge(g_sp); A_Dodge(g_sp);
if (g_sp->picnum != APLAYER && !dead) if (g_sp->picnum != APLAYER)
X_AlterAng(a); X_AlterAng(a);
if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0; if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0;

View file

@ -23,7 +23,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
#include "duke3d.h" #include "duke3d.h"
const char *s_buildDate = "20081228"; const char *s_buildDate = "20081230";
char *MusicPtr = NULL; char *MusicPtr = NULL;
int g_musicSize; int g_musicSize;