|
|
@ -47,6 +47,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com |
|
|
|
|
|
|
|
|
|
|
|
#include "Pch.h" |
|
|
|
#include "Pch.h" |
|
|
|
#include "plStatusLog/plStatusLog.h" |
|
|
|
#include "plStatusLog/plStatusLog.h" |
|
|
|
|
|
|
|
#include <queue> |
|
|
|
#pragma hdrstop |
|
|
|
#pragma hdrstop |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -67,7 +68,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com |
|
|
|
|
|
|
|
|
|
|
|
struct ManifestFile |
|
|
|
struct ManifestFile |
|
|
|
{ |
|
|
|
{ |
|
|
|
LINK(ManifestFile) link; |
|
|
|
|
|
|
|
ManifestFile(const wchar_t clientName[], const wchar_t downloadName[], const wchar_t md5val[], int flags, plLauncherInfo *info) |
|
|
|
ManifestFile(const wchar_t clientName[], const wchar_t downloadName[], const wchar_t md5val[], int flags, plLauncherInfo *info) |
|
|
|
{ |
|
|
|
{ |
|
|
|
StrCopy(filename, clientName, arrsize(filename)); |
|
|
|
StrCopy(filename, clientName, arrsize(filename)); |
|
|
@ -142,13 +142,12 @@ static unsigned s_fileListRequests; |
|
|
|
static bool s_patchComplete; |
|
|
|
static bool s_patchComplete; |
|
|
|
static PROCESS_INFORMATION s_pi; |
|
|
|
static PROCESS_INFORMATION s_pi; |
|
|
|
static long s_numFiles; |
|
|
|
static long s_numFiles; |
|
|
|
static CCritSect s_critsect; |
|
|
|
|
|
|
|
static char s_workingDir[MAX_PATH]; |
|
|
|
static char s_workingDir[MAX_PATH]; |
|
|
|
static bool s_patchError; |
|
|
|
static bool s_patchError; |
|
|
|
static long s_asyncCoreInitCount; |
|
|
|
static long s_asyncCoreInitCount; |
|
|
|
static long s_numConnectFailures; |
|
|
|
static long s_numConnectFailures; |
|
|
|
static bool s_running; |
|
|
|
static bool s_running; |
|
|
|
static LISTDECL(ManifestFile, link) s_manifestQueue; |
|
|
|
static std::queue<ManifestFile*> manifestQueue; |
|
|
|
//static AsyncThreadTaskList * s_taskList;
|
|
|
|
//static AsyncThreadTaskList * s_taskList;
|
|
|
|
|
|
|
|
|
|
|
|
// error strings
|
|
|
|
// error strings
|
|
|
@ -347,10 +346,13 @@ void Shutdown(plLauncherInfo *info) { |
|
|
|
//============================================================================
|
|
|
|
//============================================================================
|
|
|
|
static void RequestNextManifestFile () { |
|
|
|
static void RequestNextManifestFile () { |
|
|
|
bool success = true; |
|
|
|
bool success = true; |
|
|
|
ManifestFile *nextfile = s_manifestQueue.Head(); |
|
|
|
|
|
|
|
if(!nextfile) |
|
|
|
if (!manifestQueue.size()) |
|
|
|
return; |
|
|
|
return; |
|
|
|
s_manifestQueue.Unlink(nextfile); |
|
|
|
|
|
|
|
|
|
|
|
ManifestFile* nextFile = manifestQueue.front(); |
|
|
|
|
|
|
|
manifestQueue.pop(); |
|
|
|
|
|
|
|
|
|
|
|
char path[MAX_PATH]; |
|
|
|
char path[MAX_PATH]; |
|
|
|
wchar_t basePath[MAX_PATH]; |
|
|
|
wchar_t basePath[MAX_PATH]; |
|
|
|
StrPrintf(path, arrsize(path), "%s%S", s_workingDir, nextfile->filename); |
|
|
|
StrPrintf(path, arrsize(path), "%s%S", s_workingDir, nextfile->filename); |
|
|
@ -645,7 +647,7 @@ static void ProcessManifest (void * param) { |
|
|
|
} |
|
|
|
} |
|
|
|
else { |
|
|
|
else { |
|
|
|
// queue up this file download
|
|
|
|
// queue up this file download
|
|
|
|
s_manifestQueue.Link(mf); |
|
|
|
manifestQueue.push(mf); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -916,8 +918,10 @@ void UruPrepProc (void * param) { |
|
|
|
AsyncSleep(10); |
|
|
|
AsyncSleep(10); |
|
|
|
} while ((!s_patchComplete && !s_patchError && s_running) || s_perf[kPerfThreadTaskCount]); |
|
|
|
} while ((!s_patchComplete && !s_patchError && s_running) || s_perf[kPerfThreadTaskCount]); |
|
|
|
|
|
|
|
|
|
|
|
while(ManifestFile *mf = s_manifestQueue.Head()) |
|
|
|
while (manifestQueue.size()) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
ManifestFile* mf = manifestQueue.front() |
|
|
|
|
|
|
|
manifestQueue.pop(); |
|
|
|
delete mf; |
|
|
|
delete mf; |
|
|
|
} |
|
|
|
} |
|
|
|
// If s_patchError, we don't wait around for s_numFiles
|
|
|
|
// If s_patchError, we don't wait around for s_numFiles
|
|
|
|