mirror of
git://source.winehq.org/git/wine.git
synced 2024-09-14 17:46:23 +00:00
winemine: Convert to Unicode.
This commit is contained in:
parent
be91790988
commit
020faceaae
|
@ -1,5 +1,6 @@
|
||||||
MODULE = winemine.exe
|
MODULE = winemine.exe
|
||||||
APPMODE = -mwindows
|
APPMODE = -mwindows -municode
|
||||||
|
EXTRADEFS = -DWINE_NO_UNICODE_MACROS
|
||||||
IMPORTS = user32 gdi32 advapi32
|
IMPORTS = user32 gdi32 advapi32
|
||||||
DELAYIMPORTS = shell32
|
DELAYIMPORTS = shell32
|
||||||
|
|
||||||
|
|
|
@ -63,16 +63,15 @@ INT_PTR CALLBACK CongratsDlgProc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lP
|
||||||
switch( uMsg ) {
|
switch( uMsg ) {
|
||||||
case WM_INITDIALOG:
|
case WM_INITDIALOG:
|
||||||
p_board = (BOARD*) lParam;
|
p_board = (BOARD*) lParam;
|
||||||
SetDlgItemText( hDlg, IDC_EDITNAME,
|
SetDlgItemTextW( hDlg, IDC_EDITNAME, p_board->best_name[p_board->difficulty] );
|
||||||
p_board->best_name[p_board->difficulty] );
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
switch( LOWORD( wParam ) ) {
|
switch( LOWORD( wParam ) ) {
|
||||||
case IDOK:
|
case IDOK:
|
||||||
GetDlgItemText( hDlg, IDC_EDITNAME,
|
GetDlgItemTextW( hDlg, IDC_EDITNAME,
|
||||||
p_board->best_name[p_board->difficulty],
|
p_board->best_name[p_board->difficulty],
|
||||||
sizeof( p_board->best_name[p_board->difficulty] ) );
|
sizeof( p_board->best_name[p_board->difficulty] ) / sizeof(WCHAR) );
|
||||||
EndDialog( hDlg, 0 );
|
EndDialog( hDlg, 0 );
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
@ -96,7 +95,7 @@ INT_PTR CALLBACK TimesDlgProc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
|
|
||||||
/* set best names */
|
/* set best names */
|
||||||
for( i = 0; i < 3; i++ )
|
for( i = 0; i < 3; i++ )
|
||||||
SetDlgItemText( hDlg, (IDC_NAME1) + i, p_board->best_name[i] );
|
SetDlgItemTextW( hDlg, (IDC_NAME1) + i, p_board->best_name[i] );
|
||||||
|
|
||||||
/* set best times */
|
/* set best times */
|
||||||
for( i = 0; i < 3; i++ )
|
for( i = 0; i < 3; i++ )
|
||||||
|
|
|
@ -33,8 +33,19 @@
|
||||||
WINE_DEFAULT_DEBUG_CHANNEL(winemine);
|
WINE_DEFAULT_DEBUG_CHANNEL(winemine);
|
||||||
|
|
||||||
static const DWORD wnd_style = WS_OVERLAPPEDWINDOW & ~WS_THICKFRAME & ~WS_MAXIMIZEBOX;
|
static const DWORD wnd_style = WS_OVERLAPPEDWINDOW & ~WS_THICKFRAME & ~WS_MAXIMIZEBOX;
|
||||||
static const char* registry_key = "Software\\Microsoft\\WinMine";
|
static const WCHAR registry_key[] = {'S','o','f','t','w','a','r','e','\\',
|
||||||
|
'M','i','c','r','o','s','o','f','t','\\',
|
||||||
|
'W','i','n','M','i','n','e',0};
|
||||||
|
|
||||||
|
static const WCHAR xposW[] = {'X','p','o','s',0};
|
||||||
|
static const WCHAR yposW[] = {'Y','p','o','s',0};
|
||||||
|
static const WCHAR heightW[] = {'H','e','i','g','h','t',0};
|
||||||
|
static const WCHAR widthW[] = {'W','i','d','t','h',0};
|
||||||
|
static const WCHAR minesW[] = {'M','i','n','e','s',0};
|
||||||
|
static const WCHAR difficultyW[] = {'D','i','f','f','i','c','u','l','t','y',0};
|
||||||
|
static const WCHAR markW[] = {'M','a','r','k',0};
|
||||||
|
static const WCHAR nameW[] = {'N','a','m','e','%','u',0};
|
||||||
|
static const WCHAR timeW[] = {'T','i','m','e','%','u',0};
|
||||||
|
|
||||||
void CheckLevel( BOARD *p_board )
|
void CheckLevel( BOARD *p_board )
|
||||||
{
|
{
|
||||||
|
@ -62,62 +73,61 @@ static void LoadBoard( BOARD *p_board )
|
||||||
DWORD size;
|
DWORD size;
|
||||||
DWORD type;
|
DWORD type;
|
||||||
HKEY hkey;
|
HKEY hkey;
|
||||||
char data[MAX_PLAYER_NAME_SIZE+1];
|
WCHAR data[MAX_PLAYER_NAME_SIZE+1];
|
||||||
char key_name[8];
|
WCHAR key_name[8];
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
RegOpenKeyEx( HKEY_CURRENT_USER, registry_key,
|
RegOpenKeyExW( HKEY_CURRENT_USER, registry_key, 0, KEY_QUERY_VALUE, &hkey );
|
||||||
0, KEY_QUERY_VALUE, &hkey );
|
|
||||||
|
|
||||||
size = sizeof( p_board->pos.x );
|
size = sizeof( p_board->pos.x );
|
||||||
if( !RegQueryValueEx( hkey, "Xpos", NULL, &type,
|
if( !RegQueryValueExW( hkey, xposW, NULL, &type,
|
||||||
(LPBYTE) &p_board->pos.x, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->pos.x, &size ) == ERROR_SUCCESS )
|
||||||
p_board->pos.x = 0;
|
p_board->pos.x = 0;
|
||||||
|
|
||||||
size = sizeof( p_board->pos.y );
|
size = sizeof( p_board->pos.y );
|
||||||
if( !RegQueryValueEx( hkey, "Ypos", NULL, &type,
|
if( !RegQueryValueExW( hkey, yposW, NULL, &type,
|
||||||
(LPBYTE) &p_board->pos.y, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->pos.y, &size ) == ERROR_SUCCESS )
|
||||||
p_board->pos.y = 0;
|
p_board->pos.y = 0;
|
||||||
|
|
||||||
size = sizeof( p_board->rows );
|
size = sizeof( p_board->rows );
|
||||||
if( !RegQueryValueEx( hkey, "Height", NULL, &type,
|
if( !RegQueryValueExW( hkey, heightW, NULL, &type,
|
||||||
(LPBYTE) &p_board->rows, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->rows, &size ) == ERROR_SUCCESS )
|
||||||
p_board->rows = BEGINNER_ROWS;
|
p_board->rows = BEGINNER_ROWS;
|
||||||
|
|
||||||
size = sizeof( p_board->cols );
|
size = sizeof( p_board->cols );
|
||||||
if( !RegQueryValueEx( hkey, "Width", NULL, &type,
|
if( !RegQueryValueExW( hkey, widthW, NULL, &type,
|
||||||
(LPBYTE) &p_board->cols, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->cols, &size ) == ERROR_SUCCESS )
|
||||||
p_board->cols = BEGINNER_COLS;
|
p_board->cols = BEGINNER_COLS;
|
||||||
|
|
||||||
size = sizeof( p_board->mines );
|
size = sizeof( p_board->mines );
|
||||||
if( !RegQueryValueEx( hkey, "Mines", NULL, &type,
|
if( !RegQueryValueExW( hkey, minesW, NULL, &type,
|
||||||
(LPBYTE) &p_board->mines, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->mines, &size ) == ERROR_SUCCESS )
|
||||||
p_board->mines = BEGINNER_MINES;
|
p_board->mines = BEGINNER_MINES;
|
||||||
|
|
||||||
size = sizeof( p_board->difficulty );
|
size = sizeof( p_board->difficulty );
|
||||||
if( !RegQueryValueEx( hkey, "Difficulty", NULL, &type,
|
if( !RegQueryValueExW( hkey, difficultyW, NULL, &type,
|
||||||
(LPBYTE) &p_board->difficulty, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->difficulty, &size ) == ERROR_SUCCESS )
|
||||||
p_board->difficulty = BEGINNER;
|
p_board->difficulty = BEGINNER;
|
||||||
|
|
||||||
size = sizeof( p_board->IsMarkQ );
|
size = sizeof( p_board->IsMarkQ );
|
||||||
if( !RegQueryValueEx( hkey, "Mark", NULL, &type,
|
if( !RegQueryValueExW( hkey, markW, NULL, &type,
|
||||||
(LPBYTE) &p_board->IsMarkQ, &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->IsMarkQ, &size ) == ERROR_SUCCESS )
|
||||||
p_board->IsMarkQ = TRUE;
|
p_board->IsMarkQ = TRUE;
|
||||||
|
|
||||||
for( i = 0; i < 3; i++ ) {
|
for( i = 0; i < 3; i++ ) {
|
||||||
wsprintf( key_name, "Name%d", i+1 );
|
wsprintfW( key_name, nameW, i+1 );
|
||||||
size = sizeof( data );
|
size = sizeof( data );
|
||||||
if( RegQueryValueEx( hkey, key_name, NULL, &type,
|
if( RegQueryValueExW( hkey, key_name, NULL, &type,
|
||||||
(LPBYTE) data, &size ) == ERROR_SUCCESS )
|
(LPBYTE) data, &size ) == ERROR_SUCCESS )
|
||||||
lstrcpynA( p_board->best_name[i], data, sizeof(p_board->best_name[i]) );
|
lstrcpynW( p_board->best_name[i], data, sizeof(p_board->best_name[i])/sizeof(WCHAR) );
|
||||||
else
|
else
|
||||||
LoadString( p_board->hInst, IDS_NOBODY, p_board->best_name[i], MAX_PLAYER_NAME_SIZE+1 );
|
LoadStringW( p_board->hInst, IDS_NOBODY, p_board->best_name[i], MAX_PLAYER_NAME_SIZE+1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
for( i = 0; i < 3; i++ ) {
|
for( i = 0; i < 3; i++ ) {
|
||||||
wsprintf( key_name, "Time%d", i+1 );
|
wsprintfW( key_name, timeW, i+1 );
|
||||||
size = sizeof( p_board->best_time[i] );
|
size = sizeof( p_board->best_time[i] );
|
||||||
if( !RegQueryValueEx( hkey, key_name, NULL, &type,
|
if( !RegQueryValueExW( hkey, key_name, NULL, &type,
|
||||||
(LPBYTE) &p_board->best_time[i], &size ) == ERROR_SUCCESS )
|
(LPBYTE) &p_board->best_time[i], &size ) == ERROR_SUCCESS )
|
||||||
p_board->best_time[i] = 999;
|
p_board->best_time[i] = 999;
|
||||||
}
|
}
|
||||||
|
@ -128,9 +138,9 @@ static void InitBoard( BOARD *p_board )
|
||||||
{
|
{
|
||||||
HMENU hMenu;
|
HMENU hMenu;
|
||||||
|
|
||||||
p_board->hMinesBMP = LoadBitmap( p_board->hInst, "mines");
|
p_board->hMinesBMP = LoadBitmapW( p_board->hInst, MAKEINTRESOURCEW(IDI_MINES));
|
||||||
p_board->hFacesBMP = LoadBitmap( p_board->hInst, "faces");
|
p_board->hFacesBMP = LoadBitmapW( p_board->hInst, MAKEINTRESOURCEW(IDI_FACES));
|
||||||
p_board->hLedsBMP = LoadBitmap( p_board->hInst, "leds");
|
p_board->hLedsBMP = LoadBitmapW( p_board->hInst, MAKEINTRESOURCEW(IDI_LEDS));
|
||||||
|
|
||||||
LoadBoard( p_board );
|
LoadBoard( p_board );
|
||||||
|
|
||||||
|
@ -148,32 +158,32 @@ static void SaveBoard( BOARD *p_board )
|
||||||
{
|
{
|
||||||
HKEY hkey;
|
HKEY hkey;
|
||||||
unsigned i;
|
unsigned i;
|
||||||
char data[MAX_PLAYER_NAME_SIZE+1];
|
WCHAR data[MAX_PLAYER_NAME_SIZE+1];
|
||||||
char key_name[8];
|
WCHAR key_name[8];
|
||||||
|
|
||||||
if( RegCreateKeyEx( HKEY_CURRENT_USER, registry_key,
|
if( RegCreateKeyExW( HKEY_CURRENT_USER, registry_key,
|
||||||
0, NULL,
|
0, NULL,
|
||||||
REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL,
|
REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL,
|
||||||
&hkey, NULL ) != ERROR_SUCCESS)
|
&hkey, NULL ) != ERROR_SUCCESS)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
RegSetValueEx( hkey, "Xpos", 0, REG_DWORD, (LPBYTE) &p_board->pos.x, sizeof(p_board->pos.x) );
|
RegSetValueExW( hkey, xposW, 0, REG_DWORD, (LPBYTE) &p_board->pos.x, sizeof(p_board->pos.x) );
|
||||||
RegSetValueEx( hkey, "Ypos", 0, REG_DWORD, (LPBYTE) &p_board->pos.y, sizeof(p_board->pos.y) );
|
RegSetValueExW( hkey, yposW, 0, REG_DWORD, (LPBYTE) &p_board->pos.y, sizeof(p_board->pos.y) );
|
||||||
RegSetValueEx( hkey, "Difficulty", 0, REG_DWORD, (LPBYTE) &p_board->difficulty, sizeof(p_board->difficulty) );
|
RegSetValueExW( hkey, difficultyW, 0, REG_DWORD, (LPBYTE) &p_board->difficulty, sizeof(p_board->difficulty) );
|
||||||
RegSetValueEx( hkey, "Height", 0, REG_DWORD, (LPBYTE) &p_board->rows, sizeof(p_board->rows) );
|
RegSetValueExW( hkey, heightW, 0, REG_DWORD, (LPBYTE) &p_board->rows, sizeof(p_board->rows) );
|
||||||
RegSetValueEx( hkey, "Width", 0, REG_DWORD, (LPBYTE) &p_board->cols, sizeof(p_board->cols) );
|
RegSetValueExW( hkey, widthW, 0, REG_DWORD, (LPBYTE) &p_board->cols, sizeof(p_board->cols) );
|
||||||
RegSetValueEx( hkey, "Mines", 0, REG_DWORD, (LPBYTE) &p_board->mines, sizeof(p_board->mines) );
|
RegSetValueExW( hkey, minesW, 0, REG_DWORD, (LPBYTE) &p_board->mines, sizeof(p_board->mines) );
|
||||||
RegSetValueEx( hkey, "Mark", 0, REG_DWORD, (LPBYTE) &p_board->IsMarkQ, sizeof(p_board->IsMarkQ) );
|
RegSetValueExW( hkey, markW, 0, REG_DWORD, (LPBYTE) &p_board->IsMarkQ, sizeof(p_board->IsMarkQ) );
|
||||||
|
|
||||||
for( i = 0; i < 3; i++ ) {
|
for( i = 0; i < 3; i++ ) {
|
||||||
wsprintf( key_name, "Name%u", i+1 );
|
wsprintfW( key_name, nameW, i+1 );
|
||||||
lstrcpyn( data, p_board->best_name[i], sizeof( data ) );
|
lstrcpynW( data, p_board->best_name[i], sizeof(data)/sizeof(WCHAR) );
|
||||||
RegSetValueEx( hkey, key_name, 0, REG_SZ, (LPBYTE) data, strlen(data)+1 );
|
RegSetValueExW( hkey, key_name, 0, REG_SZ, (LPBYTE) data, (lstrlenW(data)+1) * sizeof(WCHAR) );
|
||||||
}
|
}
|
||||||
|
|
||||||
for( i = 0; i < 3; i++ ) {
|
for( i = 0; i < 3; i++ ) {
|
||||||
wsprintf( key_name, "Time%u", i+1 );
|
wsprintfW( key_name, timeW, i+1 );
|
||||||
RegSetValueEx( hkey, key_name, 0, REG_DWORD, (LPBYTE) &p_board->best_time[i], sizeof(p_board->best_time[i]) );
|
RegSetValueExW( hkey, key_name, 0, REG_DWORD, (LPBYTE) &p_board->best_time[i], sizeof(p_board->best_time[i]) );
|
||||||
}
|
}
|
||||||
RegCloseKey( hkey );
|
RegCloseKey( hkey );
|
||||||
}
|
}
|
||||||
|
@ -190,7 +200,7 @@ static void SetDifficulty( BOARD *p_board, DIFFICULTY difficulty )
|
||||||
HMENU hMenu;
|
HMENU hMenu;
|
||||||
|
|
||||||
if ( difficulty == CUSTOM )
|
if ( difficulty == CUSTOM )
|
||||||
if (DialogBoxParam( p_board->hInst, "DLG_CUSTOM", p_board->hWnd,
|
if (DialogBoxParamW( p_board->hInst, MAKEINTRESOURCEW(DLG_CUSTOM), p_board->hWnd,
|
||||||
CustomDlgProc, (LPARAM) p_board) != 0)
|
CustomDlgProc, (LPARAM) p_board) != 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -246,7 +256,7 @@ static void MoveOnScreen(RECT* rect)
|
||||||
|
|
||||||
/* ... and move it into the work area (ie excluding task bar)*/
|
/* ... and move it into the work area (ie excluding task bar)*/
|
||||||
mi.cbSize = sizeof(mi);
|
mi.cbSize = sizeof(mi);
|
||||||
GetMonitorInfo(hMonitor, &mi);
|
GetMonitorInfoW(hMonitor, &mi);
|
||||||
|
|
||||||
ShiftBetween(&rect->left, &rect->right, mi.rcWork.left, mi.rcWork.right);
|
ShiftBetween(&rect->left, &rect->right, mi.rcWork.left, mi.rcWork.right);
|
||||||
ShiftBetween(&rect->top, &rect->bottom, mi.rcWork.top, mi.rcWork.bottom);
|
ShiftBetween(&rect->top, &rect->bottom, mi.rcWork.top, mi.rcWork.bottom);
|
||||||
|
@ -821,11 +831,10 @@ static void TestBoard( HWND hWnd, BOARD *p_board, int x, int y, int msg )
|
||||||
p_board->time < p_board->best_time[p_board->difficulty] ) {
|
p_board->time < p_board->best_time[p_board->difficulty] ) {
|
||||||
p_board->best_time[p_board->difficulty] = p_board->time;
|
p_board->best_time[p_board->difficulty] = p_board->time;
|
||||||
|
|
||||||
DialogBoxParam( p_board->hInst, "DLG_CONGRATS", hWnd,
|
DialogBoxParamW( p_board->hInst, MAKEINTRESOURCEW(DLG_CONGRATS), hWnd,
|
||||||
CongratsDlgProc, (LPARAM) p_board);
|
CongratsDlgProc, (LPARAM) p_board);
|
||||||
|
DialogBoxParamW( p_board->hInst, MAKEINTRESOURCEW(DLG_TIMES), hWnd,
|
||||||
DialogBoxParam( p_board->hInst, "DLG_TIMES", hWnd,
|
TimesDlgProc, (LPARAM) p_board);
|
||||||
TimesDlgProc, (LPARAM) p_board);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
TestFace( p_board, pt, msg );
|
TestFace( p_board, pt, msg );
|
||||||
|
@ -841,7 +850,7 @@ static LRESULT WINAPI MainProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lPara
|
||||||
|
|
||||||
switch( msg ) {
|
switch( msg ) {
|
||||||
case WM_CREATE:
|
case WM_CREATE:
|
||||||
board.hInst = ((LPCREATESTRUCT) lParam)->hInstance;
|
board.hInst = ((LPCREATESTRUCTW) lParam)->hInstance;
|
||||||
board.hWnd = hWnd;
|
board.hWnd = hWnd;
|
||||||
InitBoard( &board );
|
InitBoard( &board );
|
||||||
CreateBoard( &board );
|
CreateBoard( &board );
|
||||||
|
@ -980,12 +989,12 @@ static LRESULT WINAPI MainProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lPara
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case IDM_EXIT:
|
case IDM_EXIT:
|
||||||
SendMessage( hWnd, WM_CLOSE, 0, 0);
|
SendMessageW( hWnd, WM_CLOSE, 0, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case IDM_TIMES:
|
case IDM_TIMES:
|
||||||
DialogBoxParam( board.hInst, "DLG_TIMES", hWnd,
|
DialogBoxParamW( board.hInst, MAKEINTRESOURCEW(DLG_TIMES), hWnd,
|
||||||
TimesDlgProc, (LPARAM) &board);
|
TimesDlgProc, (LPARAM) &board);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case IDM_ABOUT:
|
case IDM_ABOUT:
|
||||||
|
@ -1002,18 +1011,18 @@ static LRESULT WINAPI MainProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lPara
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return( DefWindowProc( hWnd, msg, wParam, lParam ));
|
return DefWindowProcW( hWnd, msg, wParam, lParam );
|
||||||
}
|
}
|
||||||
|
|
||||||
int WINAPI WinMain( HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR cmdline, int cmdshow )
|
int WINAPI wWinMain( HINSTANCE hInst, HINSTANCE hPrevInst, LPWSTR cmdline, int cmdshow )
|
||||||
{
|
{
|
||||||
MSG msg;
|
MSG msg;
|
||||||
WNDCLASSEX wc;
|
WNDCLASSEXW wc;
|
||||||
HWND hWnd;
|
HWND hWnd;
|
||||||
HACCEL haccel;
|
HACCEL haccel;
|
||||||
char appname[20];
|
WCHAR appname[20];
|
||||||
|
|
||||||
LoadString( hInst, IDS_APPNAME, appname, sizeof(appname));
|
LoadStringW( hInst, IDS_APPNAME, appname, sizeof(appname)/sizeof(WCHAR));
|
||||||
|
|
||||||
wc.cbSize = sizeof(wc);
|
wc.cbSize = sizeof(wc);
|
||||||
wc.style = 0;
|
wc.style = 0;
|
||||||
|
@ -1021,16 +1030,16 @@ int WINAPI WinMain( HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR cmdline, int cmd
|
||||||
wc.cbClsExtra = 0;
|
wc.cbClsExtra = 0;
|
||||||
wc.cbWndExtra = 0;
|
wc.cbWndExtra = 0;
|
||||||
wc.hInstance = hInst;
|
wc.hInstance = hInst;
|
||||||
wc.hIcon = LoadIcon( hInst, "WINEMINE" );
|
wc.hIcon = LoadIconW( hInst, MAKEINTRESOURCEW(IDI_WINEMINE) );
|
||||||
wc.hCursor = LoadCursor( 0, IDI_APPLICATION );
|
wc.hCursor = LoadCursorW( 0, (LPWSTR)IDI_APPLICATION );
|
||||||
wc.hbrBackground = GetStockObject( BLACK_BRUSH );
|
wc.hbrBackground = GetStockObject( BLACK_BRUSH );
|
||||||
wc.lpszMenuName = "MENU_WINEMINE";
|
wc.lpszMenuName = MAKEINTRESOURCEW(IDM_WINEMINE);
|
||||||
wc.lpszClassName = appname;
|
wc.lpszClassName = appname;
|
||||||
wc.hIconSm = LoadImage( hInst, "WINEMINE", IMAGE_ICON,
|
wc.hIconSm = LoadImageW( hInst, MAKEINTRESOURCEW(IDI_WINEMINE), IMAGE_ICON,
|
||||||
GetSystemMetrics(SM_CXSMICON), GetSystemMetrics(SM_CYSMICON), LR_SHARED );
|
GetSystemMetrics(SM_CXSMICON), GetSystemMetrics(SM_CYSMICON), LR_SHARED );
|
||||||
|
|
||||||
if (!RegisterClassEx(&wc)) ExitProcess(1);
|
if (!RegisterClassExW(&wc)) ExitProcess(1);
|
||||||
hWnd = CreateWindow( appname, appname,
|
hWnd = CreateWindowW( appname, appname,
|
||||||
wnd_style,
|
wnd_style,
|
||||||
CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT,
|
CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT,
|
||||||
0, 0, hInst, NULL );
|
0, 0, hInst, NULL );
|
||||||
|
@ -1040,14 +1049,14 @@ int WINAPI WinMain( HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR cmdline, int cmd
|
||||||
ShowWindow( hWnd, cmdshow );
|
ShowWindow( hWnd, cmdshow );
|
||||||
UpdateWindow( hWnd );
|
UpdateWindow( hWnd );
|
||||||
|
|
||||||
haccel = LoadAccelerators( hInst, MAKEINTRESOURCE(IDA_WINEMINE) );
|
haccel = LoadAcceleratorsW( hInst, MAKEINTRESOURCEW(IDA_WINEMINE) );
|
||||||
SetTimer( hWnd, ID_TIMER, 1000, NULL );
|
SetTimer( hWnd, ID_TIMER, 1000, NULL );
|
||||||
|
|
||||||
while( GetMessage(&msg, 0, 0, 0) ) {
|
while( GetMessageW(&msg, 0, 0, 0) ) {
|
||||||
if (!TranslateAccelerator( hWnd, haccel, &msg ))
|
if (!TranslateAcceleratorW( hWnd, haccel, &msg ))
|
||||||
TranslateMessage( &msg );
|
TranslateMessage( &msg );
|
||||||
|
|
||||||
DispatchMessage( &msg );
|
DispatchMessageW( &msg );
|
||||||
}
|
}
|
||||||
return msg.wParam;
|
return msg.wParam;
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,7 +86,7 @@ typedef struct tagBOARD
|
||||||
unsigned rows;
|
unsigned rows;
|
||||||
unsigned cols;
|
unsigned cols;
|
||||||
unsigned mines;
|
unsigned mines;
|
||||||
char best_name [3][MAX_PLAYER_NAME_SIZE+1];
|
WCHAR best_name [3][MAX_PLAYER_NAME_SIZE+1];
|
||||||
DWORD best_time [3];
|
DWORD best_time [3];
|
||||||
DIFFICULTY difficulty;
|
DIFFICULTY difficulty;
|
||||||
|
|
||||||
|
|
|
@ -52,3 +52,14 @@
|
||||||
#define IDS_ABOUT 1103
|
#define IDS_ABOUT 1103
|
||||||
|
|
||||||
#define IDA_WINEMINE 1201
|
#define IDA_WINEMINE 1201
|
||||||
|
|
||||||
|
#define IDM_WINEMINE 1
|
||||||
|
|
||||||
|
#define IDI_WINEMINE 1
|
||||||
|
#define IDI_FACES 2
|
||||||
|
#define IDI_LEDS 3
|
||||||
|
#define IDI_MINES 4
|
||||||
|
|
||||||
|
#define DLG_TIMES 1
|
||||||
|
#define DLG_CONGRATS 2
|
||||||
|
#define DLG_CUSTOM 3
|
||||||
|
|
|
@ -29,7 +29,7 @@ STRINGTABLE {
|
||||||
IDS_ABOUT, "Copyright 2000 Joshua Thielen"
|
IDS_ABOUT, "Copyright 2000 Joshua Thielen"
|
||||||
}
|
}
|
||||||
|
|
||||||
MENU_WINEMINE MENU
|
IDM_WINEMINE MENU
|
||||||
{
|
{
|
||||||
POPUP "&Game" {
|
POPUP "&Game" {
|
||||||
MENUITEM "&New\tF2", IDM_NEW
|
MENUITEM "&New\tF2", IDM_NEW
|
||||||
|
@ -102,13 +102,13 @@ IDA_WINEMINE ACCELERATORS
|
||||||
LANGUAGE LANG_NEUTRAL,SUBLANG_NEUTRAL
|
LANGUAGE LANG_NEUTRAL,SUBLANG_NEUTRAL
|
||||||
|
|
||||||
/* @makedep: winemine.ico */
|
/* @makedep: winemine.ico */
|
||||||
WINEMINE ICON winemine.ico
|
IDI_WINEMINE ICON winemine.ico
|
||||||
|
|
||||||
/* @makedep: faces.bmp */
|
/* @makedep: faces.bmp */
|
||||||
FACES BITMAP faces.bmp
|
IDI_FACES BITMAP faces.bmp
|
||||||
|
|
||||||
/* @makedep: leds.bmp */
|
/* @makedep: leds.bmp */
|
||||||
LEDS BITMAP leds.bmp
|
IDI_LEDS BITMAP leds.bmp
|
||||||
|
|
||||||
/* @makedep: mines.bmp */
|
/* @makedep: mines.bmp */
|
||||||
MINES BITMAP mines.bmp
|
IDI_MINES BITMAP mines.bmp
|
||||||
|
|
Loading…
Reference in a new issue