Browse Source

Merge pull request #449 from Deledrius/cleanupexe

Clean up WinMain.
Adam Johnson 10 years ago
parent
commit
eda0bd26d1
  1. 2
      Sources/Plasma/Apps/plClient/res/plClient.rc
  2. 2
      Sources/Plasma/Apps/plClient/res/resource.h
  3. 55
      Sources/Plasma/Apps/plClient/winmain.cpp

2
Sources/Plasma/Apps/plClient/res/plClient.rc

@ -112,7 +112,7 @@ BEGIN
RTEXT "Product String",IDC_PRODUCTSTRING,88,86,194,8 RTEXT "Product String",IDC_PRODUCTSTRING,88,86,194,8
CONTROL "",IDC_STATIC,"Static",SS_BLACKFRAME | SS_SUNKEN,7,49, CONTROL "",IDC_STATIC,"Static",SS_BLACKFRAME | SS_SUNKEN,7,49,
288,168 288,168
PUSHBUTTON "Need an account?",IDC_URULOGIN_GAMETAPLINK,95,183,110, PUSHBUTTON "Need an account?",IDC_URULOGIN_NEWACCTLINK,95,183,110,
14,BS_FLAT 14,BS_FLAT
END END

2
Sources/Plasma/Apps/plClient/res/resource.h

@ -20,7 +20,7 @@
#define IDC_RICHEDIT22 1028 #define IDC_RICHEDIT22 1028
#define IDC_AUTH_TEXT 1029 #define IDC_AUTH_TEXT 1029
#define IDC_BUTTON1 1030 #define IDC_BUTTON1 1030
#define IDC_URULOGIN_GAMETAPLINK 1030 #define IDC_URULOGIN_NEWACCTLINK 1030
#define IDC_AUTH_MESSAGE 1031 #define IDC_AUTH_MESSAGE 1031
#define IDC_PRODUCTSTRING 1033 #define IDC_PRODUCTSTRING 1033
#define IDC_STATUS_TEXT 1034 #define IDC_STATUS_TEXT 1034

55
Sources/Plasma/Apps/plClient/winmain.cpp

@ -43,39 +43,28 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "HeadSpin.h" #include "HeadSpin.h"
#include "hsWindows.h" #include "hsWindows.h"
#include <direct.h> // windows directory handling fxns (for chdir)
#include <process.h> #include <process.h>
#include <shellapi.h> // ShellExecuteA #include <shellapi.h> // ShellExecuteA
#include <algorithm> #include <algorithm>
//#define DETACH_EXE // Microsoft trick to force loading of exe to memory
#ifdef DETACH_EXE
#include <dmdfm.h> // Windows Load EXE into memory suff
#endif
#include <curl/curl.h> #include <curl/curl.h>
#include "hsStream.h" #include "hsStream.h"
#include "plClient.h" #include "plClient.h"
#include "plClientResMgr/plClientResMgr.h" #include "plClientResMgr/plClientResMgr.h"
#include "pfCrashHandler/plCrashCli.h" #include "pfCrashHandler/plCrashCli.h"
#include "plNetClient/plNetClientMgr.h" #include "plNetClient/plNetClientMgr.h"
#include "plNetClient/plNetLinkingMgr.h"
#include "plInputCore/plInputDevice.h" #include "plInputCore/plInputDevice.h"
#include "plInputCore/plInputManager.h" #include "plInputCore/plInputManager.h"
#include "plUnifiedTime/plUnifiedTime.h"
#include "plPipeline.h" #include "plPipeline.h"
#include "plResMgr/plResManager.h" #include "plResMgr/plResManager.h"
#include "plResMgr/plLocalization.h" #include "plResMgr/plLocalization.h"
#include "plFile/plEncryptedStream.h" #include "plFile/plEncryptedStream.h"
#include "pnEncryption/plChallengeHash.h" #include "pnEncryption/plChallengeHash.h"
#include "plStatusLog/plStatusLog.h" #include "plStatusLog/plStatusLog.h"
#include "plProduct.h" #include "plProduct.h"
#include "plNetGameLib/plNetGameLib.h" #include "plNetGameLib/plNetGameLib.h"
#include "plPhysX/plSimulationMgr.h" #include "plPhysX/plSimulationMgr.h"
#include "res/resource.h" #include "res/resource.h"
@ -94,7 +83,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
// //
// Globals // Globals
// //
bool gHasMouse = false;
ITaskbarList3* gTaskbarList = nil; // NT 6.1+ taskbar stuff ITaskbarList3* gTaskbarList = nil; // NT 6.1+ taskbar stuff
extern bool gDataServerLocal; extern bool gDataServerLocal;
@ -121,7 +109,6 @@ int gWinBorderDX = GetSystemMetrics( SM_CXSIZEFRAME );
int gWinBorderDY = GetSystemMetrics( SM_CYSIZEFRAME ); int gWinBorderDY = GetSystemMetrics( SM_CYSIZEFRAME );
int gWinMenuDY = GetSystemMetrics( SM_CYCAPTION ); int gWinMenuDY = GetSystemMetrics( SM_CYCAPTION );
//#include "global.h"
plClient *gClient; plClient *gClient;
bool gPendingActivate = false; bool gPendingActivate = false;
bool gPendingActivateFlag = false; bool gPendingActivateFlag = false;
@ -247,12 +234,6 @@ LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
} }
break; break;
#if 0
case WM_KILLFOCUS:
SetForegroundWindow(hWnd);
break;
#endif
case WM_SYSKEYUP: case WM_SYSKEYUP:
case WM_SYSKEYDOWN: case WM_SYSKEYDOWN:
{ {
@ -555,13 +536,6 @@ bool InitClient( HWND hWnd )
gClient->SetWindowHandle( hWnd ); gClient->SetWindowHandle( hWnd );
#ifdef DETACH_EXE
hInstance = ((LPCREATESTRUCT) lParam)->hInstance;
// This Function loads the EXE into Virtual memory...supposedly
HRESULT hr = DetachFromMedium(hInstance, DMDFM_ALWAYS | DMDFM_ALLPAGES);
#endif
if( gClient->InitPipeline() ) if( gClient->InitPipeline() )
gClient->SetDone(true); gClient->SetDone(true);
else else
@ -602,9 +576,6 @@ BOOL WinInit(HINSTANCE hInst, int nCmdShow)
if (!RegisterClass(&wndClass)) if (!RegisterClass(&wndClass))
return FALSE; return FALSE;
/// 8.11.2000 - Test for OpenGL fullscreen, and if so use no border, no caption;
/// else, use our normal styles
// Create a window // Create a window
HWND hWnd = CreateWindow( HWND hWnd = CreateWindow(
CLASSNAME, plProduct::LongName().c_str(), CLASSNAME, plProduct::LongName().c_str(),
@ -614,7 +585,6 @@ BOOL WinInit(HINSTANCE hInst, int nCmdShow)
600 + gWinBorderDY * 2 + gWinMenuDY, 600 + gWinBorderDY * 2 + gWinMenuDY,
NULL, NULL, hInst, NULL NULL, NULL, hInst, NULL
); );
// gClient->SetWindowHandle((hsWindowHndl)
if( !InitClient( hWnd ) ) if( !InitClient( hWnd ) )
return FALSE; return FALSE;
@ -681,12 +651,7 @@ static void AuthFailedStrings (ENetError authError,
switch (plLocalization::GetLanguage()) switch (plLocalization::GetLanguage())
{ {
case plLocalization::kFrench: case plLocalization::kEnglish:
case plLocalization::kGerman:
case plLocalization::kJapanese:
*ppStr1 = "Authentication Failed. Please try again.";
break;
default: default:
*ppStr1 = "Authentication Failed. Please try again."; *ppStr1 = "Authentication Failed. Please try again.";
@ -1091,7 +1056,7 @@ BOOL CALLBACK UruLoginDialogProc( HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM
return TRUE; return TRUE;
} }
else if (HIWORD(wParam) == BN_CLICKED && LOWORD(wParam) == IDC_URULOGIN_GAMETAPLINK) else if (HIWORD(wParam) == BN_CLICKED && LOWORD(wParam) == IDC_URULOGIN_NEWACCTLINK)
{ {
const char* signupurl = GetServerSignupUrl(); const char* signupurl = GetServerSignupUrl();
ShellExecuteA(NULL, "open", signupurl, NULL, NULL, SW_SHOWNORMAL); ShellExecuteA(NULL, "open", signupurl, NULL, NULL, SW_SHOWNORMAL);
@ -1133,13 +1098,13 @@ BOOL CALLBACK SplashDialogProc( HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM l
case plLocalization::kGerman: case plLocalization::kGerman:
::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Starte URU, bitte warten ..."); ::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Starte URU, bitte warten ...");
break; break;
/* case plLocalization::kSpanish: case plLocalization::kSpanish:
::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Iniciando URU, por favor espera..."); ::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Iniciando URU, por favor espera...");
break; break;
case plLocalization::kItalian: case plLocalization::kItalian:
::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Avvio di URU, attendere..."); ::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "Avvio di URU, attendere...");
break; break;
*/ // default is English // default is English
case plLocalization::kJapanese: case plLocalization::kJapanese:
::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "..."); ::SetDlgItemText( hwndDlg, IDC_STARTING_TEXT, "...");
break; break;
@ -1390,15 +1355,6 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmdLine, int nC
if (!WinInit(hInst, nCmdShow) || gClient->GetDone()) if (!WinInit(hInst, nCmdShow) || gClient->GetDone())
break; break;
// We don't have multiplayer localized assets for Italian or Spanish, so force them to English in that case.
/* if (!plNetClientMgr::GetInstance()->InOfflineMode() &&
(plLocalization::GetLanguage() == plLocalization::kItalian ||
plLocalization::GetLanguage() == plLocalization::kSpanish))
{
plLocalization::SetLanguage(plLocalization::kEnglish);
}
*/
// Done with our splash now // Done with our splash now
::DestroyWindow( splashDialog ); ::DestroyWindow( splashDialog );
@ -1408,8 +1364,6 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmdLine, int nC
// Show the main window // Show the main window
ShowWindow(gClient->GetWindowHandle(), SW_SHOW); ShowWindow(gClient->GetWindowHandle(), SW_SHOW);
gHasMouse = GetSystemMetrics(SM_MOUSEPRESENT);
// Be really REALLY forceful about being in the front // Be really REALLY forceful about being in the front
BringWindowToTop( gClient->GetWindowHandle() ); BringWindowToTop( gClient->GetWindowHandle() );
@ -1473,7 +1427,6 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmdLine, int nC
#endif #endif
// Exit WinMain and terminate the app.... // Exit WinMain and terminate the app....
// return msg.wParam;
return PARABLE_NORMAL_EXIT; return PARABLE_NORMAL_EXIT;
} }

Loading…
Cancel
Save