Windows NT 4.0 source code leak
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.
 
 
 
 
 
 

314 lines
5.8 KiB

/*++
Copyright (c) 1994 Microsoft Corporation
Module Name:
ShowPerf.c
Abstract:
Provides a GUI interface to display the contents of a perf data
block
Author:
Bob Watson (a-robw)
Revision History:
23 Nov 94
--*/
#include <windows.h>
#include <stdlib.h>
#include <stdio.h>
#include "showperf.h"
#include "resource.h"
#include "mainwnd.h"
#include "maindlg.h"
#define NUM_BUFS 4
// variable definition
static WORD wHelpContextId = IDH_CONTENTS;
LPCTSTR
GetStringResource (
IN HANDLE hInstance,
IN UINT nId
)
/*++
Routine Description:
look up string resource and return string
Arguments:
IN UINT nId
Resource ID of string to look up
Return Value:
pointer to string referenced by ID in arg list
--*/
{
static TCHAR szBufArray[NUM_BUFS][SMALL_BUFFER_SIZE];
static DWORD dwIndex;
LPTSTR szBuffer;
DWORD dwLength;
HANDLE hMod;
if (hInstance != NULL) {
hMod = hInstance;
} else {
hMod = GetModuleHandle(NULL);
}
dwIndex++;
dwIndex %= NUM_BUFS;
szBuffer = &szBufArray[dwIndex][0];
// clear previous contents
memset (szBuffer, 0, (SMALL_BUFFER_SIZE * sizeof(TCHAR)));
dwLength = LoadString (
hMod,
nId,
szBuffer,
SMALL_BUFFER_SIZE);
return (LPCTSTR)szBuffer;
}
VOID
SetHelpContextId (
WORD wId
)
{
wHelpContextId = wId;
return;
}
WORD
GetHelpContextId (
)
{
return wHelpContextId;
}
int
DisplayMessageBox (
IN HWND hWnd,
IN UINT nMessageId,
IN UINT nTitleId,
IN UINT nStyle
)
/*++
Routine Description:
Displays a message box displaying text from the resource file, as
opposed to literal strings.
Arguments:
IN HWND hWnd window handle to parent window
IN UINT nMessageId String Resource ID of message text to display
IN UINT nTitleId String Resource ID of title text to display
IN UINT nStyle MB style bits (see MessageBox function)
Return Value:
ID of button pressed to exit message box
--*/
{
LPTSTR szMessageText = NULL;
LPTSTR szTitleText = NULL;
HINSTANCE hInst;
int nReturn;
hInst = GET_INSTANCE(hWnd);
szMessageText = GLOBAL_ALLOC (SMALL_BUFFER_BYTES);
szTitleText = GLOBAL_ALLOC (SMALL_BUFFER_BYTES);
if ((szMessageText != NULL) &&
(szTitleText != NULL)) {
LoadString (hInst,
((nTitleId != 0) ? nTitleId : IDS_APP_TITLE),
szTitleText,
SMALL_BUFFER_SIZE -1);
LoadString (hInst,
nMessageId,
szMessageText,
SMALL_BUFFER_SIZE - 1);
nReturn = MessageBox (
hWnd,
szMessageText,
szTitleText,
nStyle);
} else {
nReturn = IDCANCEL;
}
GLOBAL_FREE_IF_ALLOC (szMessageText);
GLOBAL_FREE_IF_ALLOC (szTitleText);
return nReturn;
}
BOOL
UpdateSystemMenu (
IN HWND hWnd // window handle
)
/*++
Routine Description:
modifies the system menu by:
Removing the "Restore", "Size", "Minimize" and "Maximize" entries
Arguments:
IN HWND hWnd
window handle of window containing the system menu to modify
Return Value:
TRUE if successfully made changes, otherwise
FALSE if error occurred
--*/
{
return TRUE;
}
BOOL
ShowAppHelp (
IN HWND hWnd
)
/*++
Routine Description:
Generic routine to call WinHelp engine for displaying application
help. wContext parameter is used for context.
Arguments:
IN HWND hWnd
window handle of calling window
Return Value:
TRUE if help called successfully
--*/
{
return WinHelp (hWnd,
GetStringResource(GET_INSTANCE(hWnd), IDS_HELP_FILENAME),
HELP_CONTEXT,
(DWORD)GetHelpContextId());
}
static
LRESULT
NYIMsgBox (
IN HWND hWnd
)
/*++
Routine Description:
Displays error message box for features that have not been implemented.
in DEBUG builds, this is a message box, in RELEASE builds, this is
only a beep.
Arguments:
hWnd Window handle to main window
Return Value:
ERROR_SUCCESS
--*/
{
#ifdef DBG
DisplayMessageBox (
hWnd,
IDS_NIY,
IDS_APP_ERROR,
MBOK_EXCLAIM);
#else
MessageBeep (BEEP_EXCLAMATION);
#endif
return ERROR_SUCCESS;
}
int APIENTRY
WinMain(
IN HINSTANCE hInstance,
IN HINSTANCE hPrevInstance,
IN LPSTR szCmdLine,
IN int nCmdShow
)
/*++
Routine Description:
Program entry point for LoadAccount application. Initializes Windows
data structures and begins windows message processing loop.
Arguments:
Standard WinMain arguments
ReturnValue:
0 if unable to initialize correctly, or
wParam from WM_QUIT message if messages processed
--*/
{
HWND hWnd; // Main window handle.
HWND hPrevWnd; // previously openend app main window
MSG msg;
HACCEL hAccel;
if (RegisterMainWindowClass(hInstance)) {
hWnd = CreateMainWindow (hInstance);
if (hWnd != NULL) {
// Acquire and dispatch messages until a
// WM_QUIT message is received.
while (GetMessage(&msg, // message structure
NULL, // handle of window receiving the message
0, // lowest message to examine
0)) // highest message to examine
{
// process this message
TranslateMessage(&msg);// Translates virtual key codes
DispatchMessage(&msg); // Dispatches message to window
}
return (msg.wParam); // Returns the value from PostQuitMessage
} else {
return (ERROR_CAN_NOT_COMPLETE);
}
} else {
return (ERROR_CAN_NOT_COMPLETE);
}
}