mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
476 lines
14 KiB
476 lines
14 KiB
/*++
|
|
|
|
Copyright (c) 1994 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
EXITMESS.C
|
|
|
|
Abstract:
|
|
|
|
good bye message dialog box
|
|
|
|
Author:
|
|
|
|
Bob Watson (a-robw)
|
|
|
|
Revision History:
|
|
|
|
17 Feb 94 Written
|
|
|
|
--*/
|
|
//
|
|
// Windows Include Files
|
|
//
|
|
|
|
#include <windows.h>
|
|
#include <stdio.h>
|
|
#include <malloc.h>
|
|
#include <tchar.h> // unicode macros
|
|
//
|
|
// app include files
|
|
//
|
|
#include "otnboot.h"
|
|
#include "otnbtdlg.h"
|
|
//
|
|
extern BOOL bDisplayExitMessages;
|
|
|
|
static
|
|
DWORD
|
|
FormatExitMessageString (
|
|
IN HWND hTextWnd,
|
|
IN OUT LPTSTR szBuffer,
|
|
IN DWORD dwBufSize
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Formats the message string to fit in the Text Window by word wrapping
|
|
and indenting the text string in szBuffer.
|
|
|
|
Arguments:
|
|
|
|
IN HWND hTextWnd
|
|
handle of text window that will display the text
|
|
|
|
IN OUT LPTSTR szBuffer
|
|
string to display
|
|
|
|
IN DWORD dwBufSize
|
|
size of szBuffer in characters
|
|
|
|
Return Value:
|
|
|
|
|
|
|
|
--*/
|
|
{
|
|
LPTSTR szWorkString;
|
|
LPTSTR szSrc, szDest, szLine, szSrcWord, szDestWord;
|
|
HDC hDC;
|
|
SIZE sizeText;
|
|
RECT rTextWnd;
|
|
int nCharsInLine;
|
|
DWORD dwCharsInString = 0;
|
|
LONG nWindowWidth;
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
|
|
WORD wCharType;
|
|
WCHAR szCheckStyle[2];
|
|
LCID lcid = GetSystemDefaultLCID();
|
|
HFONT hf, hfOld;
|
|
|
|
//#endif
|
|
|
|
szWorkString = GlobalAlloc (GPTR, dwBufSize * sizeof(TCHAR));
|
|
|
|
if (szWorkString != NULL) {
|
|
// get DC of window
|
|
hDC = GetDC (hTextWnd);
|
|
|
|
if( hDC != NULL ) {
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
|
|
// reset DC with font object for getting correct size
|
|
hf = (HFONT)SendMessage(hTextWnd, WM_GETFONT, 0, 0);
|
|
if (hf) hfOld = SelectObject(hDC, hf);
|
|
//#endif
|
|
|
|
// get size of window
|
|
GetWindowRect (hTextWnd, &rTextWnd);
|
|
nWindowWidth = rTextWnd.right - rTextWnd.left;
|
|
// subtract left & right borders
|
|
nWindowWidth -= (GetSystemMetrics (SM_CXBORDER) * 2);
|
|
// subtract scroll bar width
|
|
nWindowWidth -= GetSystemMetrics (SM_CXVSCROLL);
|
|
// subtract text indent
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
|
|
sizeText.cx = sizeText.cy = 0;
|
|
GetTextExtentPoint32 (hDC,
|
|
fmtLeadingSpaces,
|
|
lstrlen(fmtLeadingSpaces),
|
|
&sizeText);
|
|
nWindowWidth -= sizeText.cx;
|
|
//#else
|
|
// nWindowWidth -= 4; // as measured
|
|
//#endif
|
|
// initialize pointers & counters
|
|
szSrc = szSrcWord = szBuffer;
|
|
szLine = szDestWord = szDest = szWorkString;
|
|
nCharsInLine = 0;
|
|
dwCharsInString = 0;
|
|
// process string
|
|
while (*szSrc != 0) {
|
|
*szDest = *szSrc;
|
|
// get length of new string after a word has been copied
|
|
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
// fixed kkntbug #13147
|
|
// NCAdmin:When ending "Make Network Installation Setup Disk" ,apllication error occurs.
|
|
|
|
//
|
|
// check what the "szSrc"(just 1 character) is type
|
|
//
|
|
szCheckStyle[0] = *szSrc;
|
|
szCheckStyle[1] = UNICODE_NULL;
|
|
if (!GetStringTypeEx(lcid,
|
|
CT_CTYPE3,
|
|
szCheckStyle,
|
|
1,
|
|
&wCharType))
|
|
wCharType = 0;
|
|
|
|
if ((*szSrc == cSpace) ||
|
|
(wCharType & C3_KATAKANA) ||
|
|
!(wCharType & C3_HALFWIDTH)) {
|
|
//#else
|
|
// if (*szSrc == cSpace) {
|
|
//#endif
|
|
// reset size variable
|
|
sizeText.cx = sizeText.cy = 0;
|
|
GetTextExtentPoint32 (hDC, szLine, nCharsInLine, &sizeText);
|
|
// then check the size
|
|
if (sizeText.cx >= nWindowWidth) {
|
|
// this word pushes past the edge so wrap the word
|
|
// and place it on the next line
|
|
lstrcpy (szDestWord, cszCrLf);
|
|
szLine = szDestWord+2; // start new line after CrLf
|
|
dwCharsInString += 2;
|
|
lstrcat (szDestWord, fmtLeadingSpaces);
|
|
szSrc = szSrcWord;
|
|
szDest = szDestWord + lstrlen(szDestWord);
|
|
// copy last word to new line
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
// fixed kkntbug #13147
|
|
// NCAdmin:When ending "Make Network Installation Setup Disk" ,apllication error occurs.
|
|
|
|
while (*szSrc) {
|
|
//
|
|
// check what the "szSrc"(just 1 character) is type
|
|
//
|
|
szCheckStyle[0] = *szSrc;
|
|
szCheckStyle[1] = UNICODE_NULL;
|
|
if (!GetStringTypeEx(lcid,
|
|
CT_CTYPE3,
|
|
szCheckStyle,
|
|
1,
|
|
&wCharType))
|
|
wCharType = 0;
|
|
|
|
if ((wCharType & C3_KATAKANA) ||
|
|
!(wCharType & C3_HALFWIDTH) ||
|
|
(*szSrc == cSpace) ||
|
|
(*szSrc == 0))
|
|
break;
|
|
//#else
|
|
// while ((*szSrc != cSpace) && (*szSrc != 0)) {
|
|
//#endif
|
|
*szDest++ = *szSrc++;
|
|
}
|
|
//#ifdef DBCS
|
|
// fixed kkntbug #10802
|
|
// NCAdmin: The sentence of an end message is strange
|
|
|
|
if ((*szSrc != 0) &&
|
|
!(wCharType & C3_KATAKANA) &&
|
|
(wCharType & C3_HALFWIDTH)) {
|
|
//#else
|
|
// if (*szSrc != 0) {
|
|
//#endif
|
|
// copy space after word to get back to pre-wrap
|
|
// position
|
|
*szDest++ = *szSrc++;
|
|
}
|
|
// update counters
|
|
nCharsInLine = lstrlen(szLine);
|
|
dwCharsInString += nCharsInLine;
|
|
} else {
|
|
//this one fits, so advance pointer to next char
|
|
szDest++;
|
|
szSrc++;
|
|
nCharsInLine++;
|
|
dwCharsInString++;
|
|
}
|
|
// update word pointers
|
|
szSrcWord = szSrc;
|
|
szDestWord = szDest;
|
|
} else {
|
|
szSrc++;
|
|
szDest++;
|
|
nCharsInLine++;
|
|
dwCharsInString++;
|
|
}
|
|
if (dwCharsInString >= dwBufSize) break; // quit before overflow
|
|
}
|
|
//#ifdef DBCS
|
|
// restore old font object
|
|
if (hf) SelectObject(hDC, hfOld);
|
|
//#endif
|
|
ReleaseDC (hTextWnd, hDC);
|
|
// copy new string to orig.
|
|
lstrcpy (szBuffer, szWorkString);
|
|
FREE_IF_ALLOC (szWorkString);
|
|
}
|
|
}
|
|
return dwCharsInString;
|
|
}
|
|
|
|
static
|
|
BOOL
|
|
ExitMessDlg_WM_INITDIALOG (
|
|
IN HWND hwndDlg,
|
|
IN WPARAM wParam,
|
|
IN LPARAM lParam
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Initializes message display translating all buffered message codes
|
|
and writing the corresponding messages to the display. If no
|
|
messages are in the list, the the dialog box is closed and not
|
|
displayed.
|
|
|
|
Arguments:
|
|
|
|
IN HWND hwndDlg
|
|
Handle to dialog box window
|
|
|
|
IN WPARAM wParam
|
|
Not Used
|
|
|
|
IN LPARAM lParam
|
|
Not Used
|
|
|
|
Return Value:
|
|
|
|
FALSE if messages displayed
|
|
TRUE if dialog box is closed
|
|
|
|
--*/
|
|
{
|
|
LPTSTR szTextBuff;
|
|
LPTSTR szStringBuff;
|
|
DWORD dwMsgNdx;
|
|
RECT rEditWindow;
|
|
BOOL bReturn;
|
|
|
|
// don't even bother unless the "display Exit Messages" flag is set
|
|
|
|
if (bDisplayExitMessages) {
|
|
szStringBuff = GlobalAlloc (GPTR, SMALL_BUFFER_SIZE * sizeof(TCHAR));
|
|
|
|
if (szStringBuff == NULL) return TRUE;
|
|
|
|
// only display if there are any messages to show
|
|
|
|
if (pAppInfo->uExitMessages[0] != 0) {
|
|
RemoveMaximizeFromSysMenu (hwndDlg);
|
|
PositionWindow (hwndDlg);
|
|
|
|
szTextBuff = GlobalAlloc (GPTR, (MEDIUM_BUFFER_SIZE * sizeof(TCHAR)));
|
|
|
|
if (szTextBuff != NULL) {
|
|
*szTextBuff = 0;
|
|
// load TextBuff with strings that should appear in message box
|
|
for (dwMsgNdx = 0; dwMsgNdx < MAX_EXITMSG; dwMsgNdx++) {
|
|
if (pAppInfo->uExitMessages[dwMsgNdx] > 0) {
|
|
if (LoadString (
|
|
(HINSTANCE)GetWindowLongPtr(GetParent(hwndDlg), GWLP_HINSTANCE),
|
|
pAppInfo->uExitMessages[dwMsgNdx],
|
|
szStringBuff,
|
|
MAX_PATH) > 0) {
|
|
FormatExitMessageString (
|
|
GetDlgItem (hwndDlg, NCDU_CONTINUE_MESSAGE),
|
|
szStringBuff, SMALL_BUFFER_SIZE);
|
|
if ((lstrlen(szStringBuff) + lstrlen(szTextBuff) + 2) > MEDIUM_BUFFER_SIZE) {
|
|
if(GlobalReAlloc(szTextBuff, (lstrlen(szStringBuff) + lstrlen(szTextBuff) + 2), GPTR) == NULL) {
|
|
break;
|
|
}
|
|
lstrcat (szTextBuff, szStringBuff);
|
|
lstrcat (szTextBuff, cszCrLf);
|
|
}
|
|
}
|
|
} else {
|
|
break;
|
|
}
|
|
}
|
|
GetClientRect (GetDlgItem (hwndDlg, NCDU_CONTINUE_MESSAGE), &rEditWindow);
|
|
SendDlgItemMessage (hwndDlg, NCDU_CONTINUE_MESSAGE, EM_SETRECT,
|
|
(WPARAM)0, (LPARAM)&rEditWindow);
|
|
SendDlgItemMessage (hwndDlg, NCDU_CONTINUE_MESSAGE, EM_FMTLINES,
|
|
(WPARAM)TRUE, 0);
|
|
SetDlgItemText (hwndDlg, NCDU_CONTINUE_MESSAGE, szTextBuff);
|
|
GetDlgItemText (hwndDlg, NCDU_CONTINUE_MESSAGE,
|
|
szTextBuff, (int)GlobalSize (szTextBuff));
|
|
SetDlgItemText (hwndDlg, NCDU_CONTINUE_MESSAGE, szTextBuff);
|
|
|
|
FREE_IF_ALLOC (szTextBuff);
|
|
} else {
|
|
// this is OK because this dialog never "registered"
|
|
EndDialog (hwndDlg, (int)WM_CLOSE);
|
|
}
|
|
|
|
SetFocus (GetDlgItem(hwndDlg, IDOK));
|
|
bReturn = FALSE;
|
|
} else {
|
|
// no mesaages to show so end dialog now
|
|
EndDialog (hwndDlg, (int)WM_CLOSE);
|
|
bReturn = TRUE;
|
|
}
|
|
|
|
FREE_IF_ALLOC (szStringBuff);
|
|
|
|
PostMessage (GetParent(hwndDlg), NCDU_CLEAR_DLG, (WPARAM)hwndDlg, IDOK);
|
|
PostMessage (GetParent(hwndDlg), NCDU_REGISTER_DLG,
|
|
NCDU_EXIT_MESSAGE_DLG, (LPARAM)hwndDlg);
|
|
SetCursor(LoadCursor(NULL, IDC_ARROW));
|
|
} else {
|
|
// this is OK because this dialog never "registered"
|
|
EndDialog (hwndDlg, (int)WM_CLOSE);
|
|
bReturn = TRUE;
|
|
}
|
|
|
|
return bReturn;
|
|
}
|
|
|
|
static
|
|
BOOL
|
|
ExitMessDlg_WM_COMMAND (
|
|
IN HWND hwndDlg,
|
|
IN WPARAM wParam,
|
|
IN LPARAM lParam
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Processes the windows message sent when a user presses a button or
|
|
menu item
|
|
|
|
Arguments:
|
|
|
|
IN HWND hwndDlg
|
|
Handle to dialog box window
|
|
|
|
IN WPARAM wParam
|
|
LOPARAM contains the ID of the control that initiated the command
|
|
(i.e. the one that was pushed)
|
|
|
|
IN LPARAM lParam
|
|
Not used
|
|
|
|
Return Value:
|
|
|
|
TRUE if the message was processed
|
|
FALSE if not
|
|
--*/
|
|
{
|
|
switch (LOWORD(wParam)) {
|
|
case IDCANCEL:
|
|
switch (HIWORD(wParam)) {
|
|
case BN_CLICKED:
|
|
PostMessage (GetParent (hwndDlg),
|
|
(int)NCDU_SHOW_SW_CONFIG_DLG, 0, 0);
|
|
SetCursor(LoadCursor(NULL, IDC_WAIT));
|
|
return TRUE;
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
|
|
case IDOK:
|
|
switch (HIWORD(wParam)) {
|
|
case BN_CLICKED:
|
|
PostMessage (GetParent (hwndDlg),
|
|
(int)WM_CLOSE, 0, 0);
|
|
SetCursor(LoadCursor(NULL, IDC_WAIT));
|
|
return TRUE;
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
INT_PTR CALLBACK
|
|
ExitMessDlgProc (
|
|
IN HWND hwndDlg,
|
|
IN UINT message,
|
|
IN WPARAM wParam,
|
|
IN LPARAM lParam
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Main Dialog Box Param. Dispatchs to the local processing routine
|
|
on receipt of the following messages.
|
|
|
|
WM_INITDIALOG: Dialog box initialization
|
|
WM_COMMAND: Sent when user selects a button
|
|
WM_PAINT: for painting icon when minimized
|
|
WM_MOVE: for saving the new location of the window
|
|
WM_SYSCOMMAND: for processing menu messages
|
|
|
|
all other messages are passed to the default dialag box
|
|
procedure.
|
|
|
|
Arguments:
|
|
|
|
Standard WNDPROC arguments
|
|
|
|
Return Value:
|
|
|
|
FALSE if not processed otherwise, the value returned by the
|
|
called routine.
|
|
|
|
--*/
|
|
{
|
|
switch (message) {
|
|
case WM_INITDIALOG: return (ExitMessDlg_WM_INITDIALOG (hwndDlg, wParam, lParam));
|
|
case WM_COMMAND: return (ExitMessDlg_WM_COMMAND (hwndDlg, wParam, lParam));
|
|
case WM_PAINT: return (Dlg_WM_PAINT (hwndDlg, wParam, lParam));
|
|
case WM_MOVE: return (Dlg_WM_MOVE (hwndDlg, wParam, lParam));
|
|
case WM_SYSCOMMAND: return (Dlg_WM_SYSCOMMAND (hwndDlg, wParam, lParam));
|
|
default: return FALSE;
|
|
}
|
|
}
|
|
|
|
|
|
|