mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-14 22:00:50 +00:00
Fix join password not recognizing shifted characters
This commit is contained in:
parent
b5c4866706
commit
52b743a18f
3 changed files with 83 additions and 50 deletions
129
src/d_clisrv.c
129
src/d_clisrv.c
|
@ -22,6 +22,7 @@
|
||||||
#include "i_video.h"
|
#include "i_video.h"
|
||||||
#include "d_net.h"
|
#include "d_net.h"
|
||||||
#include "d_main.h"
|
#include "d_main.h"
|
||||||
|
#include "d_event.h"
|
||||||
#include "g_game.h"
|
#include "g_game.h"
|
||||||
#include "hu_stuff.h"
|
#include "hu_stuff.h"
|
||||||
#include "keys.h"
|
#include "keys.h"
|
||||||
|
@ -1139,42 +1140,6 @@ static UINT8 cl_challengequestion[17];
|
||||||
static char cl_challengepassword[65];
|
static char cl_challengepassword[65];
|
||||||
static UINT8 cl_challengeanswer[17];
|
static UINT8 cl_challengeanswer[17];
|
||||||
|
|
||||||
static void D_JoinChallengeInput(INT32 ch)
|
|
||||||
{
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
while (ch)
|
|
||||||
{
|
|
||||||
if ((ch >= HU_FONTSTART && ch <= HU_FONTEND && hu_font[ch-HU_FONTSTART])
|
|
||||||
|| ch == ' ') // Allow spaces, of course
|
|
||||||
{
|
|
||||||
len = strlen(cl_challengepassword);
|
|
||||||
if (len < 64)
|
|
||||||
{
|
|
||||||
cl_challengepassword[len+1] = 0;
|
|
||||||
cl_challengepassword[len] = ch;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (ch == KEY_BACKSPACE)
|
|
||||||
{
|
|
||||||
len = strlen(cl_challengepassword);
|
|
||||||
|
|
||||||
if (len > 0)
|
|
||||||
cl_challengepassword[len-1] = 0;
|
|
||||||
}
|
|
||||||
else if (ch == KEY_ENTER)
|
|
||||||
{
|
|
||||||
// Done?
|
|
||||||
D_ComputeChallengeAnswer(cl_challengequestion, cl_challengepassword, cl_challengeanswer);
|
|
||||||
cl_mode = CL_ASKJOIN;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ch = I_GetKey();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Player name send/load
|
// Player name send/load
|
||||||
|
|
||||||
static void CV_SavePlayerNames(UINT8 **p)
|
static void CV_SavePlayerNames(UINT8 **p)
|
||||||
|
@ -2136,22 +2101,10 @@ static boolean CL_ServerConnectionTicker(boolean viams, const char *tmpsave, tic
|
||||||
// Call it only once by tic
|
// Call it only once by tic
|
||||||
if (*oldtic != I_GetTime())
|
if (*oldtic != I_GetTime())
|
||||||
{
|
{
|
||||||
INT32 key;
|
|
||||||
|
|
||||||
I_OsPolling();
|
I_OsPolling();
|
||||||
key = I_GetKey();
|
D_ProcessEvents();
|
||||||
// Only ESC and non-keyboard keys abort connection
|
if (gamestate != GS_WAITINGPLAYERS)
|
||||||
if (key == KEY_ESCAPE || key >= KEY_MOUSE1)
|
|
||||||
{
|
|
||||||
CONS_Printf(M_GetText("Network game synchronization aborted.\n"));
|
|
||||||
// M_StartMessage(M_GetText("Network game synchronization aborted.\n\nPress ESC\n"), NULL, MM_NOTHING);
|
|
||||||
D_QuitNetGame();
|
|
||||||
CL_Reset();
|
|
||||||
D_StartTitle();
|
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
else if (cl_mode == CL_CHALLENGE)
|
|
||||||
D_JoinChallengeInput(key);
|
|
||||||
|
|
||||||
// why are these here? this is for servers, we're a client
|
// why are these here? this is for servers, we're a client
|
||||||
//if (key == 's' && server)
|
//if (key == 's' && server)
|
||||||
|
@ -2180,6 +2133,82 @@ static boolean CL_ServerConnectionTicker(boolean viams, const char *tmpsave, tic
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean CL_Responder(event_t *ev)
|
||||||
|
{
|
||||||
|
size_t len;
|
||||||
|
INT32 ch;
|
||||||
|
|
||||||
|
if (!(client && cl_mode != CL_CONNECTED && cl_mode != CL_ABORTED))
|
||||||
|
return false; // Don't do anything outside of the connection screen
|
||||||
|
|
||||||
|
if (ev->type != ev_keydown)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ch = (INT32)ev->data1;
|
||||||
|
|
||||||
|
if (ch == KEY_CAPSLOCK) // it's a toggle.
|
||||||
|
{
|
||||||
|
capslock = !capslock;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only ESC and non-keyboard keys abort connection
|
||||||
|
if (ch == KEY_ESCAPE || ch >= KEY_MOUSE1)
|
||||||
|
{
|
||||||
|
CONS_Printf(M_GetText("Network game synchronization aborted.\n"));
|
||||||
|
//M_StartMessage(M_GetText("Network game synchronization aborted.\n\nPress ESC\n"), NULL, MM_NOTHING);
|
||||||
|
D_QuitNetGame();
|
||||||
|
CL_Reset();
|
||||||
|
D_StartTitle();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cl_mode != CL_CHALLENGE)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if ((ch >= HU_FONTSTART && ch <= HU_FONTEND && hu_font[ch-HU_FONTSTART])
|
||||||
|
|| ch == ' ') // Allow spaces, of course
|
||||||
|
{
|
||||||
|
len = strlen(cl_challengepassword);
|
||||||
|
if (len < 64)
|
||||||
|
{
|
||||||
|
|
||||||
|
// shifting code stolen from lat by fickle, thx :)
|
||||||
|
|
||||||
|
// I know this looks very messy but this works. If it ain't broke, don't fix it!
|
||||||
|
// shift LETTERS to uppercase if we have capslock or are holding shift
|
||||||
|
if ((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z'))
|
||||||
|
{
|
||||||
|
if (shiftdown ^ capslock)
|
||||||
|
ch = shiftxform[ch];
|
||||||
|
}
|
||||||
|
else // if we're holding shift we should still shift non letter symbols
|
||||||
|
{
|
||||||
|
if (shiftdown)
|
||||||
|
ch = shiftxform[ch];
|
||||||
|
}
|
||||||
|
|
||||||
|
cl_challengepassword[len+1] = 0;
|
||||||
|
cl_challengepassword[len] = ch;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (ch == KEY_BACKSPACE)
|
||||||
|
{
|
||||||
|
len = strlen(cl_challengepassword);
|
||||||
|
|
||||||
|
if (len > 0)
|
||||||
|
cl_challengepassword[len-1] = 0;
|
||||||
|
}
|
||||||
|
else if (ch == KEY_ENTER)
|
||||||
|
{
|
||||||
|
// Done?
|
||||||
|
D_ComputeChallengeAnswer(cl_challengequestion, cl_challengepassword, cl_challengeanswer);
|
||||||
|
cl_mode = CL_ASKJOIN;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/** Use adaptive send using net_bandwidth and stat.sendbytes
|
/** Use adaptive send using net_bandwidth and stat.sendbytes
|
||||||
*
|
*
|
||||||
* \param viams ???
|
* \param viams ???
|
||||||
|
|
|
@ -566,6 +566,7 @@ void CL_RemoveSplitscreenPlayer(UINT8 p);
|
||||||
void CL_Reset(void);
|
void CL_Reset(void);
|
||||||
void CL_ClearPlayer(INT32 playernum);
|
void CL_ClearPlayer(INT32 playernum);
|
||||||
void CL_UpdateServerList(boolean internetsearch, INT32 room);
|
void CL_UpdateServerList(boolean internetsearch, INT32 room);
|
||||||
|
boolean CL_Responder(event_t *ev);
|
||||||
// Is there a game running
|
// Is there a game running
|
||||||
boolean Playing(void);
|
boolean Playing(void);
|
||||||
|
|
||||||
|
|
|
@ -236,6 +236,9 @@ void D_ProcessEvents(void)
|
||||||
if (M_ScreenshotResponder(ev))
|
if (M_ScreenshotResponder(ev))
|
||||||
continue; // ate the event
|
continue; // ate the event
|
||||||
|
|
||||||
|
if (CL_Responder(ev))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (gameaction == ga_nothing && gamestate == GS_TITLESCREEN)
|
if (gameaction == ga_nothing && gamestate == GS_TITLESCREEN)
|
||||||
{
|
{
|
||||||
if (cht_Responder(ev))
|
if (cht_Responder(ev))
|
||||||
|
|
Loading…
Reference in a new issue