Legacy download code recieves more attention.

- Make all the I_Errors return false and print to the console instead.
- New prints for missing files if you can't fit it all into one packet.
- Make the startmessage warning less specific and direct you to the logfile, to accomodate all the different ways legacy downloads can fail.
This commit is contained in:
toaster 2022-10-31 17:49:52 +00:00
parent 5ab988dc3e
commit a679e7a9e1
2 changed files with 36 additions and 15 deletions

View file

@ -1335,8 +1335,10 @@ static inline void CL_DrawConnectionStatus(void)
strncpy(tempname, filename, sizeof(tempname)-1); strncpy(tempname, filename, sizeof(tempname)-1);
} }
V_DrawCenteredString(BASEVIDWIDTH/2, BASEVIDHEIGHT-58-30, 0,
va(M_GetText("%s downloading"), ((cl_mode == CL_DOWNLOADHTTPFILES) ? "\x82""HTTP" : "\x85""Direct")));
V_DrawCenteredString(BASEVIDWIDTH/2, BASEVIDHEIGHT-58-22, V_YELLOWMAP, V_DrawCenteredString(BASEVIDWIDTH/2, BASEVIDHEIGHT-58-22, V_YELLOWMAP,
va(M_GetText("Downloading \"%s\""), tempname)); va(M_GetText("\"%s\""), tempname));
V_DrawString(BASEVIDWIDTH/2-128, BASEVIDHEIGHT-58, V_20TRANS|V_MONOSPACE, V_DrawString(BASEVIDWIDTH/2-128, BASEVIDHEIGHT-58, V_20TRANS|V_MONOSPACE,
va(" %4uK/%4uK",fileneeded[lastfilenum].currentsize>>10,file->totalsize>>10)); va(" %4uK/%4uK",fileneeded[lastfilenum].currentsize>>10,file->totalsize>>10));
V_DrawRightAlignedString(BASEVIDWIDTH/2+128, BASEVIDHEIGHT-58, V_20TRANS|V_MONOSPACE, V_DrawRightAlignedString(BASEVIDWIDTH/2+128, BASEVIDHEIGHT-58, V_20TRANS|V_MONOSPACE,
@ -2483,9 +2485,8 @@ static boolean CL_ServerConnectionTicker(const char *tmpsave, tic_t *oldtic, tic
CL_Reset(); CL_Reset();
D_StartTitle(); D_StartTitle();
M_StartMessage(M_GetText( M_StartMessage(M_GetText(
"The legacy file downloader could not handle that many files.\n" "The direct download encountered an error.\n"
"Ask the server host to set up a http source, or\n" "See the logfile for more info.\n"
"locate and download the necessary files yourself.\n"
"\n" "\n"
"Press ESC\n" "Press ESC\n"
), NULL, MM_NOTHING); ), NULL, MM_NOTHING);

View file

@ -300,7 +300,7 @@ boolean CL_CheckDownloadable(void)
} }
// The following was written and then quickly deemed too fragile on paper to be worth testing. // The following was written and then quickly deemed too fragile on paper to be worth testing.
//#DEFINE MORELEGACYDOWNLOADER //#define MORELEGACYDOWNLOADER
/** Sends requests for files in the ::fileneeded table with a status of /** Sends requests for files in the ::fileneeded table with a status of
* ::FS_NOTFOUND. * ::FS_NOTFOUND.
@ -321,18 +321,21 @@ boolean CL_SendRequestFile(void)
#ifdef PARANOIA #ifdef PARANOIA
if (M_CheckParm("-nodownload")) if (M_CheckParm("-nodownload"))
I_Error("CL_SendRequestFile: Attempted to download files in -nodownload mode"); {
CONS_Printf("Direct download - Attempted to download files in -nodownload mode");
return false;
}
#endif #endif
for (i = 0; i < fileneedednum; i++) for (i = 0; i < fileneedednum; i++)
{ {
#ifdef PARANOIA
if (fileneeded[i].status != FS_FOUND && fileneeded[i].status != FS_OPEN if (fileneeded[i].status != FS_FOUND && fileneeded[i].status != FS_OPEN
&& (fileneeded[i].willsend == 0 || fileneeded[i].willsend == 2)) && (fileneeded[i].willsend == 0 || fileneeded[i].willsend == 2))
{ {
I_Error("CL_SendRequestFile: Attempted to download files that were not sendable"); CONS_Printf("Direct download - attempted to download files that were not sendable\n");
return false;
} }
#endif
if ((fileneeded[i].status == FS_NOTFOUND || fileneeded[i].status == FS_MD5SUMBAD || fileneeded[i].status == FS_FALLBACK)) if ((fileneeded[i].status == FS_NOTFOUND || fileneeded[i].status == FS_MD5SUMBAD || fileneeded[i].status == FS_FALLBACK))
{ {
// Error check for the first time around. // Error check for the first time around.
@ -342,9 +345,13 @@ boolean CL_SendRequestFile(void)
I_GetDiskFreeSpace(&availablefreespace); I_GetDiskFreeSpace(&availablefreespace);
if (totalfreespaceneeded > availablefreespace) if (totalfreespaceneeded > availablefreespace)
I_Error("To play on this server you must download %s KB,\n" {
"but you have only %s KB free space on this drive\n", CONS_Printf("Direct download -\n"
" To play on this server you must download %s KB,\n"
" but you have only %s KB free space on this drive\n",
sizeu1((size_t)(totalfreespaceneeded>>10)), sizeu2((size_t)(availablefreespace>>10))); sizeu1((size_t)(totalfreespaceneeded>>10)), sizeu2((size_t)(availablefreespace>>10)));
return false;
}
#ifdef MORELEGACYDOWNLOADER #ifdef MORELEGACYDOWNLOADER
tryagain: tryagain:
@ -386,20 +393,33 @@ tryagain:
#else #else
// If we're not trying extralong legacy download requests, gotta bail. // If we're not trying extralong legacy download requests, gotta bail.
if (skippedafile != -1) if (skippedafile != -1)
{
#ifndef MORELEGACYDOWNLOADER
CONS_Printf("Direct download - missing files are as follows:\n");
for (i = 0; i < fileneedednum; i++)
{
if ((fileneeded[i].status == FS_NOTFOUND || fileneeded[i].status == FS_MD5SUMBAD || fileneeded[i].status == FS_FALLBACK || fileneeded[i].status == FS_REQUESTED)) // FS_REQUESTED added
CONS_Printf(" %s\n", fileneeded[i].filename);
}
#endif
return false; return false;
else }
#endif #endif
I_mkdir(downloaddir, 0755); I_mkdir(downloaddir, 0755);
#ifdef PARANOIA
// Couldn't fit a single one in? // Couldn't fit a single one in?
if (p == (char *)netbuffer->u.textcmd) if (p == (char *)netbuffer->u.textcmd)
I_Error("CL_SendRequestFile: Fileneeded name for %s (fileneeded[%d]) too long??", (p > 0 ? fileneeded[p].filename : NULL), p); {
#endif CONS_Printf("Direct download - fileneeded name for %s (fileneeded[%d]) too long??\n", (skippedafile != -1 ? fileneeded[skippedafile].filename : NULL), skippedafile);
return false;
}
WRITEUINT8(p, 0xFF); // terminator WRITEUINT8(p, 0xFF); // terminator
if (!HSendPacket(servernode, true, 0, p - (char *)netbuffer->u.textcmd)) if (!HSendPacket(servernode, true, 0, p - (char *)netbuffer->u.textcmd))
{
CONS_Printf("Direct download - unable to send packet.\n");
return false; return false;
}
#ifdef MORELEGACYDOWNLOADER #ifdef MORELEGACYDOWNLOADER
if (skippedafile != -1) if (skippedafile != -1)