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.
245 lines
7.8 KiB
245 lines
7.8 KiB
/*****************************************************************************
|
|
*
|
|
* Registry.c - This module handles requests for registry data, and
|
|
* reading/writing of window placement data
|
|
*
|
|
* Microsoft Confidential
|
|
* Copyright (c) 1992-1993 Microsoft Corporation
|
|
*
|
|
*
|
|
****************************************************************************/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "perfmon.h"
|
|
#include "registry.h"
|
|
#include "utils.h"
|
|
#include "sizes.h"
|
|
|
|
static TCHAR PerfmonNamesKey[] = TEXT("SOFTWARE\\Microsoft\\PerfMon") ;
|
|
static TCHAR WindowKeyName[] = TEXT("WindowPos") ;
|
|
static TCHAR TimeOutKeyName[] = TEXT("DataTimeOut") ;
|
|
static TCHAR DupInstanceKeyName[] = TEXT("MonitorDuplicateInstances") ;
|
|
static TCHAR ReportEventsToEventLog[] = TEXT("ReportEventsToEventLog");
|
|
static TCHAR CapPercentsAt100[] = TEXT("CapPercentsAt100");
|
|
|
|
VOID LoadLineGraphSettings(PGRAPHSTRUCT lgraph)
|
|
{
|
|
lgraph->gMaxValues = DEFAULT_MAX_VALUES;
|
|
lgraph->gOptions.bLegendChecked = DEFAULT_F_DISPLAY_LEGEND;
|
|
lgraph->gOptions.bLabelsChecked = DEFAULT_F_DISPLAY_CALIBRATION;
|
|
|
|
return;
|
|
}
|
|
|
|
VOID LoadRefreshSettings(PGRAPHSTRUCT lgraph)
|
|
{
|
|
lgraph->gInterval = DEF_GRAPH_INTERVAL;
|
|
lgraph->gOptions.eTimeInterval = (FLOAT) lgraph->gInterval / (FLOAT) 1000.0 ;
|
|
return;
|
|
}
|
|
|
|
|
|
BOOL LoadMainWindowPlacement (HWND hWnd)
|
|
{
|
|
WINDOWPLACEMENT WindowPlacement ;
|
|
TCHAR szWindowPlacement [TEMP_BUF_LEN] ;
|
|
HKEY hKeyNames ;
|
|
DWORD Size;
|
|
DWORD Type;
|
|
DWORD Status;
|
|
DWORD localDataTimeOut;
|
|
DWORD localFlag;
|
|
STARTUPINFO StartupInfo ;
|
|
|
|
|
|
GetStartupInfo (&StartupInfo) ;
|
|
|
|
DataTimeOut = DEFAULT_DATA_TIMEOUT ;
|
|
|
|
Status = RegOpenKeyEx(HKEY_CURRENT_USER, PerfmonNamesKey,
|
|
0L, KEY_READ | KEY_WRITE, &hKeyNames) ;
|
|
|
|
if (Status == ERROR_SUCCESS)
|
|
{
|
|
// get the data timeout value
|
|
Size = sizeof(localDataTimeOut) ;
|
|
|
|
Status = RegQueryValueEx(hKeyNames, TimeOutKeyName, NULL,
|
|
&Type, (LPBYTE)&localDataTimeOut, &Size) ;
|
|
if (Status == ERROR_SUCCESS && Type == REG_DWORD)
|
|
{
|
|
DataTimeOut = localDataTimeOut ;
|
|
}
|
|
|
|
// check the duplicate entry value
|
|
Size = sizeof (localFlag);
|
|
Status = RegQueryValueEx (hKeyNames, DupInstanceKeyName, NULL,
|
|
&Type, (LPBYTE)&localFlag, &Size);
|
|
if ((Status == ERROR_SUCCESS) && (Type == REG_DWORD)) {
|
|
bMonitorDuplicateInstances = (BOOL)(localFlag == 1);
|
|
} else {
|
|
// value not found or not correct so set to default value
|
|
bMonitorDuplicateInstances = TRUE;
|
|
// and try to save it back in the registry
|
|
localFlag = 1;
|
|
Status = RegSetValueEx(hKeyNames, DupInstanceKeyName, 0,
|
|
REG_DWORD, (LPBYTE)&localFlag, sizeof(localFlag));
|
|
}
|
|
|
|
// check the duplicate entry value
|
|
Size = sizeof (localFlag);
|
|
Status = RegQueryValueEx (hKeyNames, CapPercentsAt100, NULL,
|
|
&Type, (LPBYTE)&localFlag, &Size);
|
|
if ((Status == ERROR_SUCCESS) && (Type == REG_DWORD)) {
|
|
bCapPercentsAt100 = (BOOL)(localFlag == 1);
|
|
} else {
|
|
// value not found or not correct so set to default value
|
|
bCapPercentsAt100 = TRUE;
|
|
// and try to save it back in the registry
|
|
localFlag = 1;
|
|
Status = RegSetValueEx(hKeyNames, CapPercentsAt100, 0,
|
|
REG_DWORD, (LPBYTE)&localFlag, sizeof(localFlag));
|
|
}
|
|
|
|
// check the Report To Event Log entry value
|
|
Size = sizeof (localFlag);
|
|
Status = RegQueryValueEx (hKeyNames, ReportEventsToEventLog, NULL,
|
|
&Type, (LPBYTE)&localFlag, &Size);
|
|
if ((Status == ERROR_SUCCESS) && (Type == REG_DWORD)) {
|
|
bReportEvents = (BOOL)(localFlag == 1);
|
|
} else {
|
|
// value not found or not correct so set to default value
|
|
// which is disabled.
|
|
bReportEvents = FALSE;
|
|
// and try to save it back in the registry
|
|
localFlag = 0;
|
|
Status = RegSetValueEx(hKeyNames, ReportEventsToEventLog, 0,
|
|
REG_DWORD, (LPBYTE)&localFlag, sizeof(localFlag));
|
|
}
|
|
|
|
|
|
// get the window placement data
|
|
Size = sizeof(szWindowPlacement) ;
|
|
|
|
Status = RegQueryValueEx(hKeyNames, WindowKeyName, NULL,
|
|
&Type, (LPBYTE)szWindowPlacement, &Size) ;
|
|
RegCloseKey (hKeyNames) ;
|
|
|
|
if (Status == ERROR_SUCCESS)
|
|
{
|
|
|
|
int iNumScanned ;
|
|
|
|
iNumScanned = swscanf (szWindowPlacement,
|
|
TEXT("%d %d %d %d %d %d %d %d %d"),
|
|
&WindowPlacement.showCmd,
|
|
&WindowPlacement.ptMinPosition.x,
|
|
&WindowPlacement.ptMinPosition.y,
|
|
&WindowPlacement.ptMaxPosition.x,
|
|
&WindowPlacement.ptMaxPosition.y,
|
|
&WindowPlacement.rcNormalPosition.left,
|
|
&WindowPlacement.rcNormalPosition.top,
|
|
&WindowPlacement.rcNormalPosition.right,
|
|
&WindowPlacement.rcNormalPosition.bottom) ;
|
|
|
|
if (StartupInfo.dwFlags == STARTF_USESHOWWINDOW)
|
|
{
|
|
WindowPlacement.showCmd = StartupInfo.wShowWindow ;
|
|
}
|
|
WindowPlacement.length = sizeof(WINDOWPLACEMENT);
|
|
WindowPlacement.flags = WPF_SETMINPOSITION;
|
|
if (!SetWindowPlacement (hWnd, &WindowPlacement)) {
|
|
return (FALSE);
|
|
}
|
|
bPerfmonIconic = IsIconic(hWnd) ;
|
|
return (TRUE) ;
|
|
}
|
|
}
|
|
|
|
if (Status != ERROR_SUCCESS)
|
|
{
|
|
// open registry failed, use input from startup info or Max as default
|
|
|
|
if (StartupInfo.dwFlags == STARTF_USESHOWWINDOW)
|
|
{
|
|
ShowWindow (hWnd, StartupInfo.wShowWindow) ;
|
|
}
|
|
else
|
|
{
|
|
ShowWindow (hWnd, SW_SHOWMAXIMIZED) ;
|
|
}
|
|
return (FALSE) ;
|
|
}
|
|
else
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
|
|
BOOL SaveMainWindowPlacement (HWND hWnd)
|
|
{
|
|
WINDOWPLACEMENT WindowPlacement ;
|
|
TCHAR ObjectType [2] ;
|
|
TCHAR szWindowPlacement [TEMP_BUF_LEN] ;
|
|
HKEY hKeyNames = 0 ;
|
|
DWORD Size ;
|
|
DWORD Status ;
|
|
DWORD dwDisposition ;
|
|
|
|
ObjectType [0] = TEXT(' ') ;
|
|
ObjectType [1] = TEXT('\0') ;
|
|
|
|
WindowPlacement.length = sizeof(WINDOWPLACEMENT);
|
|
if (!GetWindowPlacement (hWnd, &WindowPlacement)) {
|
|
return FALSE;
|
|
}
|
|
TSPRINTF (szWindowPlacement, TEXT("%d %d %d %d %d %d %d %d %d"),
|
|
WindowPlacement.showCmd,
|
|
WindowPlacement.ptMinPosition.x,
|
|
WindowPlacement.ptMinPosition.y,
|
|
WindowPlacement.ptMaxPosition.x,
|
|
WindowPlacement.ptMaxPosition.y,
|
|
WindowPlacement.rcNormalPosition.left,
|
|
WindowPlacement.rcNormalPosition.top,
|
|
WindowPlacement.rcNormalPosition.right,
|
|
WindowPlacement.rcNormalPosition.bottom) ;
|
|
|
|
// try to create it first
|
|
Status = RegCreateKeyEx(HKEY_CURRENT_USER, PerfmonNamesKey, 0L,
|
|
ObjectType, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS | KEY_WRITE,
|
|
NULL, &hKeyNames, &dwDisposition) ;
|
|
|
|
// if it has been created before, then open it
|
|
if (dwDisposition == REG_OPENED_EXISTING_KEY)
|
|
{
|
|
Status = RegOpenKeyEx(HKEY_CURRENT_USER, PerfmonNamesKey, 0L,
|
|
KEY_WRITE, &hKeyNames) ;
|
|
}
|
|
|
|
// we got the handle, now store the window placement data
|
|
if (Status == ERROR_SUCCESS)
|
|
{
|
|
Size = (lstrlen (szWindowPlacement) + 1) * sizeof (TCHAR) ;
|
|
|
|
Status = RegSetValueEx(hKeyNames, WindowKeyName, 0,
|
|
REG_SZ, (LPBYTE)szWindowPlacement, Size) ;
|
|
|
|
if (dwDisposition != REG_OPENED_EXISTING_KEY && Status == ERROR_SUCCESS)
|
|
{
|
|
// now add the DataTimeOut key for the first time
|
|
Status = RegSetValueEx(hKeyNames, TimeOutKeyName, 0,
|
|
REG_DWORD, (LPBYTE)&DataTimeOut, sizeof(DataTimeOut)) ;
|
|
|
|
}
|
|
|
|
RegCloseKey (hKeyNames) ;
|
|
|
|
}
|
|
|
|
return (Status == ERROR_SUCCESS) ;
|
|
}
|
|
|
|
|
|
|
|
|