WindowsXP-SP1/termsrv/reskit/tsreg/reg.c
2020-09-30 16:53:49 +02:00

877 lines
28 KiB
C

/*-----------------------------------------------**
** Copyright (c) 1998 Microsoft Corporation **
** All Rights reserved **
** **
** reg.c **
** **
** Functions for reading, writing, and deleting **
** registry keys - TSREG **
** 07-01-98 a-clindh Created **
**-----------------------------------------------*/
#include <windows.h>
#include <commctrl.h>
#include <TCHAR.H>
#include <stdlib.h>
#include "tsreg.h"
#include "resource.h"
///////////////////////////////////////////////////////////////////////////////
// Had to have this function in case the user wants to save a profile
// that only has default settings. This will write a key but the key
// will contain no values.
///////////////////////////////////////////////////////////////////////////////
void WriteBlankKey(TCHAR lpszRegPath[MAX_PATH])
{
HKEY hKey;
DWORD dwDisposition;
RegCreateKeyEx(HKEY_CURRENT_USER, lpszRegPath,
0, NULL, REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS, 0, &hKey, &dwDisposition);
RegCloseKey(hKey);
}
///////////////////////////////////////////////////////////////////////////////
void SetRegKey(int i, TCHAR lpszRegPath[MAX_PATH])
{
HKEY hKey;
DWORD dwDisposition;
RegCreateKeyEx(HKEY_CURRENT_USER, lpszRegPath,
0, NULL, REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS, 0, &hKey, &dwDisposition);
//
// write the key value to the registry
//
if(hKey != NULL) {
RegSetValueEx(hKey, g_KeyInfo[i].Key, 0, REG_DWORD,
& (unsigned char) (g_KeyInfo[i].CurrentKeyValue),
sizeof(DWORD));
}
RegCloseKey(hKey);
}
///////////////////////////////////////////////////////////////////////////////
void DeleteRegKey(int i, TCHAR lpszRegPath[MAX_PATH])
{
HKEY hKey;
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszRegPath, 0,
KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS) {
RegDeleteValue(hKey, g_KeyInfo[i].Key);
RegCloseKey(hKey);
}
}
///////////////////////////////////////////////////////////////////////////////
// returns 1 if the registry key is there and 0 if it isn't
///////////////////////////////////////////////////////////////////////////////
int GetRegKey(int i, TCHAR lpszRegPath[MAX_PATH])
{
DWORD *dwKeyValue;
HKEY hKey;
DWORD dwType;
DWORD dwSize;
dwType = REG_SZ;
dwSize = sizeof(DWORD);
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszRegPath, 0,
KEY_READ, &hKey) == ERROR_SUCCESS) {
if (RegQueryValueEx(hKey, g_KeyInfo[i].Key, 0,
&dwType, (LPBYTE) &dwKeyValue,
&dwSize) == ERROR_SUCCESS) {
RegCloseKey(hKey);
return 1;
}
RegCloseKey(hKey);
}
return 0;
}
///////////////////////////////////////////////////////////////////////////////
void SaveSettings(HWND dlghwnd, int i,
int nCtlID1, int nCtlID2, TCHAR lpszRegPath[MAX_PATH])
{
do {
if (IsDlgButtonChecked(dlghwnd, nCtlID1)) {
SetRegKey(i, lpszRegPath);
} else {
if (IsDlgButtonChecked(dlghwnd, nCtlID2)) {
DeleteRegKey(i, lpszRegPath);
}
}
dlghwnd = GetNextWindow(dlghwnd, GW_HWNDNEXT);
} while (dlghwnd != NULL);
}
///////////////////////////////////////////////////////////////////////////////
void RestoreSettings(HWND dlghwnd, int i,
int nCtlID1, int nCtlID2, TCHAR lpszRegPath[MAX_PATH])
{
// check settings and enable appropriate radio button.
if (GetRegKey(i, lpszRegPath) != 0) {
CheckDlgButton(dlghwnd, nCtlID1, TRUE);
CheckDlgButton(dlghwnd, nCtlID2, FALSE);
} else {
CheckDlgButton(dlghwnd, nCtlID1, FALSE);
CheckDlgButton(dlghwnd, nCtlID2, TRUE);
}
}
///////////////////////////////////////////////////////////////////////////////
// pass the index of the key and the function
// returns the value stored in the registry
///////////////////////////////////////////////////////////////////////////////
int GetRegKeyValue(int i)
{
int nKeyValue;
HKEY hKey;
DWORD dwType;
DWORD dwSize;
TCHAR lpszRegPath[MAX_PATH];
LoadString (g_hInst, IDS_REG_PATH, lpszRegPath, sizeof (lpszRegPath));
dwType = REG_SZ;
dwSize = sizeof(DWORD);
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszRegPath, 0,
KEY_READ, &hKey) == ERROR_SUCCESS) {
if (RegQueryValueEx(hKey, g_KeyInfo[i].Key, 0,
&dwType, (LPBYTE) &nKeyValue,
&dwSize) == ERROR_SUCCESS) {
RegCloseKey(hKey);
return nKeyValue;
}
RegCloseKey(hKey);
}
return 0;
}
///////////////////////////////////////////////////////////////////////////////
// Initialize the controls for the original "misc" sheet.
///////////////////////////////////////////////////////////////////////////////
void InitMiscControls(HWND hDlg, HWND hwndComboBox)
{
TCHAR szBuffer[4];
int i, nKeyVal;
TCHAR lpszRegPath[MAX_PATH];
LoadString (g_hInst, IDS_REG_PATH, lpszRegPath, sizeof (lpszRegPath));
//
// fill the combo box list
//
SendMessage(hwndComboBox, CB_ADDSTRING, 0,
(LPARAM) (LPCTSTR) TEXT("0"));
for (i = 2; i <= MAXTEXTFRAGSIZE; i*= 2) {
_itot(i, szBuffer, 10);
SendMessage(hwndComboBox, CB_ADDSTRING, 0,
(LPARAM) (LPCTSTR) szBuffer);
} // ** end for loop
//
// limit combo box to 4 characters
//
SendMessage(hwndComboBox, CB_LIMITTEXT, 3, 0);
//
// get values from registry for text frag combo box
//
nKeyVal = GetRegKey(TEXTFRAGINDEX, lpszRegPath); // check for null
if ( nKeyVal == 1 ) {
nKeyVal = GetRegKeyValue(TEXTFRAGINDEX);
} else {
nKeyVal = g_KeyInfo[TEXTFRAGINDEX].DefaultKeyValue;
}
g_KeyInfo[TEXTFRAGINDEX].CurrentKeyValue = nKeyVal;
_itot( nKeyVal, szBuffer, 10);
SendMessage(hwndComboBox, CB_SELECTSTRING, -1,
(LPARAM)(LPCSTR) szBuffer);
//
// get values from registry for radio buttons
//
nKeyVal = GetRegKey(GLYPHINDEX, lpszRegPath); // check for null
if ( nKeyVal == 1 ) {
nKeyVal = GetRegKeyValue(GLYPHINDEX);
switch (nKeyVal) {
case 0:
CheckDlgButton(hDlg, IDC_RADIO_NONE, TRUE);
break;
case 1:
CheckDlgButton(hDlg, IDC_RADIO_PARTIAL, TRUE);
break;
case 2:
CheckDlgButton(hDlg, IDC_RADIO_FULL, TRUE);
break;
}
} else {
nKeyVal = g_KeyInfo[GLYPHINDEX].DefaultKeyValue;
CheckDlgButton(hDlg, IDC_RADIO_FULL, TRUE);
}
g_KeyInfo[GLYPHINDEX].CurrentKeyValue = nKeyVal;
}
///////////////////////////////////////////////////////////////////////////////
// Needed a special funtion to save settings for the bitmap cache. The
// combined total must be 100 and can only be checked after all combo
// boxes have been filled.
///////////////////////////////////////////////////////////////////////////////
BOOL SaveBitmapSettings(TCHAR lpszRegPath[MAX_PATH])
{
static HWND hwndComboCache;
static HWND hwndSliderNumCaches;
static HWND hwndSliderDistProp[PERCENT_COMBO_COUNT];
static HWND hwndPropChkBox[PERCENT_COMBO_COUNT];
static HWND hwndSliderBuddy[PERCENT_COMBO_COUNT];
TCHAR lpszBuffer[6];
int i;
//
// get handles for cache size combo box and the
// number of caches slider
/////////////////////////////////////////////////////////////////
hwndSliderNumCaches = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_SLD_NO_CACHES);
hwndComboCache = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_COMBO_CACHE_SIZE);
//---------------------------------------------------------------
//
// save settings for cache size
/////////////////////////////////////////////////////////////////
if (g_KeyInfo[CACHESIZEINDEX].CurrentKeyValue ==
g_KeyInfo[CACHESIZEINDEX].DefaultKeyValue) {
DeleteRegKey(CACHESIZEINDEX, lpszRegPath);
} else {
SetRegKey(CACHESIZEINDEX, lpszRegPath);
}
//---------------------------------------------------------------
//
// save settings for number of caches
/////////////////////////////////////////////////////////////////
if ( g_KeyInfo[NUM_CELL_CACHES_INDEX].CurrentKeyValue ==
g_KeyInfo[NUM_CELL_CACHES_INDEX].DefaultKeyValue) {
DeleteRegKey(NUM_CELL_CACHES_INDEX, lpszRegPath);
} else {
SetRegKey(NUM_CELL_CACHES_INDEX, lpszRegPath);
}
//---------------------------------------------------------------
for (i = 0; i < PERCENT_COMBO_COUNT; i++) {
//
// get handles to sliders, edit, & check boxes
/////////////////////////////////////////////////////////////
hwndSliderDistProp[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_SLD_DST_PROP_1 + i);
hwndSliderBuddy[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_TXT_DST_PROP_1 + i);
hwndPropChkBox[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_CHK_CSH_1 + i);
//-----------------------------------------------------------
GetWindowText(hwndSliderBuddy[i], lpszBuffer, 4);
g_KeyInfo[CACHEPROP1 + i].CurrentKeyValue =
_ttoi(lpszBuffer);
//
// save settings for cache sizes
/////////////////////////////////////////////////////////////
if ( g_KeyInfo[CACHEPROP1 + i].CurrentKeyValue ==
g_KeyInfo[CACHEPROP1 + i].DefaultKeyValue) {
DeleteRegKey(CACHEPROP1 + i, lpszRegPath);
} else {
SetRegKey(CACHEPROP1 + i, lpszRegPath);
}
//-----------------------------------------------------------
//
// save settings for persistent caching
/////////////////////////////////////////////////////////////
if (IsDlgButtonChecked(g_hwndShadowBitmapDlg, IDC_CHK_CSH_1 + i)) {
g_KeyInfo[BM_PERSIST_BASE_INDEX + i].CurrentKeyValue = 1;
SetRegKey(BM_PERSIST_BASE_INDEX + i, lpszRegPath);
} else {
g_KeyInfo[BM_PERSIST_BASE_INDEX + i].CurrentKeyValue = 0;
DeleteRegKey(BM_PERSIST_BASE_INDEX + i, lpszRegPath);
}
//-----------------------------------------------------------
} // ** end for loop
return TRUE;
}
///////////////////////////////////////////////////////////////////////////////
// reads individual key values for each profile into it's associated
// variable from the regisgry (if there is a value) or assigns the
// element it's default value.
///////////////////////////////////////////////////////////////////////////////
void LoadKeyValues()
{
TCHAR lpszClientProfilePath[MAX_PATH];
static HWND hwndProfilesCBO;
int i, index, nKeyValue;
TCHAR lpszSubKeyPath[MAX_PATH];
DWORD dwType;
DWORD dwSize;
static HKEY hKey;
hwndProfilesCBO = GetDlgItem(g_hwndProfilesDlg, IDC_CBO_PROFILES);
LoadString (g_hInst, IDS_PROFILE_PATH,
lpszClientProfilePath, sizeof(lpszClientProfilePath));
// get the key name of each profile
GetClientProfileNames(lpszClientProfilePath);
g_pkfProfile = g_pkfStart;
for (index = 0; index <= g_pkfProfile->Index; index++) {
// fill combo box existing profile names
SendMessage(hwndProfilesCBO, CB_ADDSTRING, 0,
(LPARAM) g_pkfProfile->KeyInfo->Key);
_tcscpy(lpszSubKeyPath, lpszClientProfilePath);
_tcscat(lpszSubKeyPath, TEXT("\\"));
_tcscat(lpszSubKeyPath, g_pkfProfile->KeyInfo->Key);
for (i = 0; i < KEYCOUNT; i++) {
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszSubKeyPath, 0,
KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS) {
g_pkfProfile->KeyInfo[i].DefaultKeyValue =
g_KeyInfo[i].DefaultKeyValue;
_tcscpy(g_pkfProfile->KeyInfo[i].KeyPath,
lpszSubKeyPath);
if (RegQueryValueEx(hKey, g_KeyInfo[i].Key, 0,
&dwType, (LPBYTE) &nKeyValue,
&dwSize) == ERROR_SUCCESS) {
g_pkfProfile->KeyInfo[i].CurrentKeyValue =
nKeyValue;
RegCloseKey(hKey);
} else {
g_pkfProfile->KeyInfo[i].CurrentKeyValue =
g_KeyInfo[i].DefaultKeyValue;
RegCloseKey(hKey);
}
RegCloseKey(hKey);
}
}// inner for loop
g_pkfProfile = g_pkfProfile->Next;
}// outer for loop
}
///////////////////////////////////////////////////////////////////////////////
void ReadRecordIn(TCHAR lpszBuffer[])
{
// adds values from linked list to default data structure.
int i, index;
g_pkfProfile = g_pkfStart;
for (index = 0; index <= g_pkfProfile->Index; index++) {
if (_tcscmp( lpszBuffer,
g_pkfProfile->KeyInfo->Key) == 0) {
for (i = 0; i < KEYCOUNT; i++) {
g_KeyInfo[i].CurrentKeyValue =
g_pkfProfile->KeyInfo[i].
CurrentKeyValue;
}
break;
}
g_pkfProfile = g_pkfProfile->Next;
}
}
///////////////////////////////////////////////////////////////////////////////
void ReloadKeys(TCHAR lpszBuffer[], HWND hwndProfilesCBO)
{
int index;
SendMessage(hwndProfilesCBO, CB_RESETCONTENT, 0, 0);
// free any allocated memory.
g_pkfProfile = g_pkfStart;
for (index = 0; index <= g_pkfProfile->Index; index++) {
g_pkfProfile = g_pkfStart->Next;
free(g_pkfProfile);
g_pkfStart = g_pkfProfile;
}
// allocate memory and reload keys.
LoadKeyValues();
// read linked list into current key data struct.
ReadRecordIn(lpszBuffer);
// adjust the controls accordingly.
SetControlValues();
}
///////////////////////////////////////////////////////////////////////////////
// change the title of the app to reflect the currently selected profile
///////////////////////////////////////////////////////////////////////////////
void ResetTitle(TCHAR lpszBuffer[])
{
HWND hWndParent;
TCHAR lpszCaption[MAXKEYSIZE] = TEXT("");
// change window caption
LoadString (g_hInst, IDS_WINDOW_TITLE,
lpszCaption, sizeof (lpszCaption));
_tcscat(lpszCaption, lpszBuffer);
hWndParent = GetParent(g_hwndProfilesDlg);
SendMessage(hWndParent, WM_SETTEXT, 0,
(LPARAM) lpszCaption);
}
///////////////////////////////////////////////////////////////////////////////
void SetEditCell(TCHAR lpszBuffer[],
HWND hwndProfilesCBO)
{
LRESULT i;
//
// set edit cell text to selected profile string
//
i = SendMessage(hwndProfilesCBO,
CB_FINDSTRING, 0,
(LPARAM) lpszBuffer);
SendMessage(hwndProfilesCBO,
CB_SETCURSEL, i, 0);
}
///////////////////////////////////////////////////////////////////////////////
// Recursive function to allocate memory and read in the values stored
// in the registry.
///////////////////////////////////////////////////////////////////////////////
void GetClientProfileNames(TCHAR lpszClientProfilePath[])
{
TCHAR lpszKeyName[MAX_PATH];
ULONG lpPathLen = MAX_PATH;
static HKEY hKey;
static int nKeyIndex = 0;
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszClientProfilePath, 0,
KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS) {
if (RegEnumKeyEx(hKey, nKeyIndex, &lpszKeyName[0], &lpPathLen,
NULL, NULL, NULL, NULL) == ERROR_SUCCESS) {
//
// allocate memory for the first key
//
if (nKeyIndex == 0) {
g_pkfProfile = (PROFILE_KEY_INFO *) malloc
(sizeof(PROFILE_KEY_INFO));
g_pkfStart = g_pkfProfile;
}
//
// Catches failure if malloc fails above
//
if(!g_pkfProfile)
{
return;
}
// save the key name to the data structure
_tcsncpy(g_pkfProfile->KeyInfo->Key, lpszKeyName,
sizeof(g_pkfProfile->KeyInfo->Key)/sizeof(TCHAR));
// give the data element an index number
g_pkfProfile->Index = nKeyIndex;
// allocate memory for the next structure
g_pkfProfile->Next = (PROFILE_KEY_INFO *) malloc
(sizeof(PROFILE_KEY_INFO));
// increment the pointer to the next element
g_pkfProfile = g_pkfProfile->Next;
// close the current registry key
RegCloseKey(hKey);
if(!g_pkfProfile)
{
return;
}
nKeyIndex++;
GetClientProfileNames(lpszClientProfilePath);
}
RegCloseKey(hKey);
}
nKeyIndex = 0;
}
///////////////////////////////////////////////////////////////////////////////
// adjust all of the controls in the application to the values stored
// by the profile.
///////////////////////////////////////////////////////////////////////////////
void SetControlValues()
{
TCHAR lpszBuffer[MAXKEYSIZE];
HWND hwndComboCache;
static HWND hwndSliderNumCaches;
static HWND hwndSliderDistProp[PERCENT_COMBO_COUNT];
static HWND hwndSliderDistBuddy[PERCENT_COMBO_COUNT];
static HWND hwndPropChkBox[PERCENT_COMBO_COUNT];
static HWND hwndSlider[NUMBER_OF_SLIDERS];
static HWND hwndSliderEditBuddy[NUMBER_OF_SLIDERS];
static HWND hwndEditNumCaches;
static HWND hwndComboTextFrag;
static HWND hwndComboOrder;
static HWND hwndRadioShadowEn, hwndRadioShadowDis;
static HWND hwndRadioDedicatedEn, hwndRadioDedicatedDis;
static TCHAR lpszRegPath[MAX_PATH];
static UINT nGlyphBuffer;
int nPos;
int i;
LoadString (g_hInst, IDS_REG_PATH, lpszRegPath, sizeof (lpszRegPath));
// shadow bitmap page *****************************************************
hwndComboCache = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_COMBO_CACHE_SIZE);
hwndSliderNumCaches = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_SLD_NO_CACHES);
hwndEditNumCaches = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_TXT_NO_CACHES);
for (i = 0; i < PERCENT_COMBO_COUNT; i++) {
_itot(g_KeyInfo[i + CACHEPROP1].CurrentKeyValue,
lpszBuffer, 10);
hwndSliderDistProp[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_SLD_DST_PROP_1 + i);
hwndSliderDistBuddy[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_TXT_DST_PROP_1 + i);
SetWindowText(hwndSliderDistBuddy[i], lpszBuffer);
hwndPropChkBox[i] = GetDlgItem(g_hwndShadowBitmapDlg,
IDC_CHK_CSH_1 + i);
}
//
// enable/disable check boxes and sliders
//
EnableControls(g_hwndShadowBitmapDlg, hwndSliderDistProp,
hwndPropChkBox, hwndSliderDistBuddy,
hwndEditNumCaches, hwndSliderNumCaches,
PERCENT_COMBO_COUNT, lpszRegPath);
_itot(g_KeyInfo[CACHESIZEINDEX].CurrentKeyValue, lpszBuffer, 10);
SetWindowText(hwndComboCache, lpszBuffer);
// glyph page *************************************************************
hwndComboTextFrag = GetDlgItem(g_hwndGlyphCacheDlg, IDC_CBO_TXT_FRAG);
switch (g_KeyInfo[GLYPHINDEX].CurrentKeyValue) {
case 0:
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_NONE, TRUE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_PARTIAL, FALSE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_FULL, FALSE);
break;
case 1:
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_NONE, FALSE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_PARTIAL, TRUE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_FULL, FALSE);
break;
case 2:
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_NONE, FALSE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_PARTIAL, FALSE);
CheckDlgButton(g_hwndGlyphCacheDlg, IDC_RADIO_FULL, TRUE);
break;
}
_itot(g_KeyInfo[TEXTFRAGINDEX].CurrentKeyValue, lpszBuffer, 10);
SendMessage(hwndComboTextFrag, CB_SELECTSTRING, -1,
(LPARAM)(LPCSTR) lpszBuffer);
for (i = 0; i < NUMBER_OF_SLIDERS; i++) {
hwndSlider[i] = GetDlgItem(g_hwndGlyphCacheDlg,
(IDC_SLIDER1 + i));
hwndSliderEditBuddy[i] = GetDlgItem(g_hwndGlyphCacheDlg,
(IDC_STATIC1 + i));
SetWindowLongPtr(hwndSlider[i], GWLP_USERDATA, i);
_itot(g_KeyInfo[i + GLYPHCACHEBASE].CurrentKeyValue,
(lpszBuffer), 10);
//
// position the thumb on the slider control
//
nGlyphBuffer = g_KeyInfo[i + GLYPHCACHEBASE].CurrentKeyValue;
#ifdef _X86_
// EXECUTE ASSEMBLER CODE ONLY IF X86 PROCESSOR
// BSF: Bit Scan Forward -
// Scans the value contained in the EAX regiseter
// for the first significant (1) bit.
// This function returns the location of the first
// significant bit. The function is used in this
// application as a base 2 logarythm. The location
// of the bit is determined, stored in the nPos
// variable, and nPos is used to set the slider
// control. ie. If the register value is 4, nPos
// is set to 2 (00000100). 10 minus 2 (position 8
// on the slider control) represents the value 4.
__asm
{
BSF EAX, nGlyphBuffer
MOV nPos, EAX
}
nPos = 10 - nPos;
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, (LPARAM)nPos);
#else
switch (nGlyphBuffer) {
case 4:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 8);
break;
case 8:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 7);
break;
case 16:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 6);
break;
case 32:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 5);
break;
case 64:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 4);
break;
case 128:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 3);
break;
case 256:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 2);
break;
case 512:
SendMessage(hwndSlider[i], TBM_SETPOS, TRUE, 1);
break;
}
#endif
}
//misc page ***************************************************************
hwndComboOrder = GetDlgItem(g_hwndMiscDlg, IDC_COMBO_ORDER);
hwndRadioShadowEn = GetDlgItem(g_hwndMiscDlg, IDC_SHADOW_ENABLED);
hwndRadioShadowDis = GetDlgItem(g_hwndMiscDlg, IDC_SHADOW_DISABLED);
hwndRadioDedicatedEn = GetDlgItem(g_hwndMiscDlg, IDC_DEDICATED_ENABLED);
hwndRadioDedicatedDis = GetDlgItem(g_hwndMiscDlg, IDC_DEDICATED_DISABLED);
//
// set radio buttons
//
RestoreSettings(g_hwndMiscDlg, SHADOWINDEX,
IDC_SHADOW_DISABLED, IDC_SHADOW_ENABLED,
g_pkfProfile->KeyInfo[i].KeyPath);
RestoreSettings(g_hwndMiscDlg, DEDICATEDINDEX,
IDC_DEDICATED_ENABLED, IDC_DEDICATED_DISABLED,
g_pkfProfile->KeyInfo[i].KeyPath);
_itot( g_KeyInfo[ORDERINDEX].CurrentKeyValue,
lpszBuffer, 10);
SetWindowText(hwndComboOrder, lpszBuffer);
}
///////////////////////////////////////////////////////////////////////////////
//
//
// send handles to controls and the integer value for the number of
// enabled combo & check boxes
///////////////////////////////////////////////////////////////////////////////
void EnableControls(HWND hDlg,
HWND hwndSliderDistProp[],
HWND hwndPropChkBox[],
HWND hwndSliderDistBuddy[],
HWND hwndEditNumCaches,
HWND hwndSliderNumCaches,
int nNumCellCaches,
TCHAR lpszRegPath[])
{
int i, nPos;
TCHAR lpszBuffer[6];
for (i = 0; i < nNumCellCaches; i++) {
//
// check/uncheck check boxes for persistent caching
//
if (g_KeyInfo[BM_PERSIST_BASE_INDEX + i].CurrentKeyValue == 0)
CheckDlgButton(hDlg, IDC_CHK_CSH_1 + i, FALSE);
else
CheckDlgButton(hDlg, IDC_CHK_CSH_1 + i, TRUE);
//
// enable/disable check & slider controls
//
if (i < (INT) g_KeyInfo[NUM_CELL_CACHES_INDEX].CurrentKeyValue) {
EnableWindow(hwndSliderDistProp[i], TRUE);
EnableWindow(hwndPropChkBox[i], TRUE);
EnableWindow(hwndSliderDistBuddy[i], TRUE);
_itot(g_KeyInfo[CACHEPROP1 + i].CurrentKeyValue,
lpszBuffer, 10);
SetWindowText(hwndSliderDistBuddy[i], lpszBuffer);
//
// position the thumb on the slider control
//
nPos = g_KeyInfo[CACHEPROP1 + i].CurrentKeyValue;
SendMessage(hwndSliderDistProp[i], TBM_SETPOS, TRUE,
11 - nPos / 10);
} else {
EnableWindow(hwndSliderDistProp[i], FALSE);
EnableWindow(hwndPropChkBox[i], FALSE);
EnableWindow(hwndSliderDistBuddy[i], FALSE);
SetWindowText(hwndSliderDistBuddy[i], NULL);
CheckDlgButton(hDlg, IDC_CHK_CSH_1 + i, FALSE);
SendMessage(hwndSliderDistProp[i], TBM_SETPOS, TRUE, 11);
}
}
//
// position the thumb on the slider control (num caches)
//
SendMessage(hwndSliderNumCaches, TBM_SETPOS, TRUE,
g_KeyInfo[NUM_CELL_CACHES_INDEX].CurrentKeyValue + 1);
_itot( g_KeyInfo[NUM_CELL_CACHES_INDEX].CurrentKeyValue,
lpszBuffer, 10);
//
// display string in edit cell
//
SetWindowText(hwndEditNumCaches, lpszBuffer);
}
// end of file
///////////////////////////////////////////////////////////////////////////////
// pass the key name along with the key path and the function
// returns the value stored in the registry
// DWORD values
///////////////////////////////////////////////////////////////////////////////
int GetKeyVal(TCHAR lpszRegPath[MAX_PATH], TCHAR lpszKeyName[MAX_PATH])
{
int nKeyValue;
HKEY hKey;
DWORD dwType;
DWORD dwSize;
dwType = REG_SZ;
dwSize = sizeof(DWORD);
if (RegOpenKeyEx(HKEY_CURRENT_USER, lpszRegPath, 0,
KEY_READ, &hKey) == ERROR_SUCCESS) {
if (RegQueryValueEx(hKey, lpszKeyName, 0,
&dwType, (LPBYTE) &nKeyValue,
&dwSize) == ERROR_SUCCESS) {
RegCloseKey(hKey);
return nKeyValue;
}
RegCloseKey(hKey);
}
return 0;
}
///////////////////////////////////////////////////////////////////////////////
// send path AND key name to set key value - used with foreground window
// lock timeout.
///////////////////////////////////////////////////////////////////////////////
void SetRegKeyVal(TCHAR lpszRegPath[MAX_PATH],
TCHAR lpszKeyName[MAX_PATH],
int nKeyValue)
{
HKEY hKey;
DWORD dwDisposition;
RegCreateKeyEx(HKEY_CURRENT_USER, lpszRegPath,
0, NULL, REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS, 0, &hKey, &dwDisposition);
//
// write the key value to the registry
//
if(hKey != NULL) {
RegSetValueEx(hKey, lpszKeyName, 0, REG_DWORD,
& (unsigned char) (nKeyValue),
sizeof(DWORD));
RegCloseKey(hKey);
}
}
//////////////////////////////////////////////////////////////////////////////