mirror of
https://github.com/reactos/reactos.git
synced 2025-08-04 08:25:48 +00:00
- Keep the value type of each environment variable that was read from the registry and assign the right type for new and modified variables.
- Read and write the the raw (non-expanded) environment variables and display the cooked (expanded) ones only. svn path=/trunk/; revision=29729
This commit is contained in:
parent
f546265f2f
commit
2689ce9561
1 changed files with 59 additions and 51 deletions
|
@ -12,6 +12,7 @@
|
|||
|
||||
typedef struct _VARIABLE_DATA
|
||||
{
|
||||
DWORD dwType;
|
||||
LPTSTR lpName;
|
||||
LPTSTR lpRawValue;
|
||||
LPTSTR lpCookedValue;
|
||||
|
@ -53,7 +54,7 @@ EditVariableDlgProc(HWND hwndDlg,
|
|||
case IDOK:
|
||||
dwNameLength = (DWORD)SendDlgItemMessage(hwndDlg, IDC_VARIABLE_NAME, WM_GETTEXTLENGTH, 0, 0);
|
||||
dwValueLength = (DWORD)SendDlgItemMessage(hwndDlg, IDC_VARIABLE_VALUE, WM_GETTEXTLENGTH, 0, 0);
|
||||
if (dwNameLength != 0 && dwValueLength != 0)
|
||||
if (dwNameLength > 0 && dwValueLength > 0)
|
||||
{
|
||||
if (VarData->lpName == NULL)
|
||||
{
|
||||
|
@ -77,20 +78,26 @@ EditVariableDlgProc(HWND hwndDlg,
|
|||
}
|
||||
SendDlgItemMessage(hwndDlg, IDC_VARIABLE_VALUE, WM_GETTEXT, dwValueLength + 1, (LPARAM)VarData->lpRawValue);
|
||||
|
||||
if (VarData->lpCookedValue != NULL)
|
||||
{
|
||||
GlobalFree(VarData->lpCookedValue);
|
||||
VarData->lpCookedValue = NULL;
|
||||
}
|
||||
|
||||
if (_tcschr(VarData->lpRawValue, _T('%')))
|
||||
{
|
||||
if (VarData->lpCookedValue == NULL)
|
||||
{
|
||||
VarData->dwType = REG_EXPAND_SZ;
|
||||
VarData->lpCookedValue = GlobalAlloc(GPTR, 2 * MAX_PATH * sizeof(TCHAR));
|
||||
}
|
||||
|
||||
ExpandEnvironmentStrings(VarData->lpRawValue,
|
||||
VarData->lpCookedValue,
|
||||
2 * MAX_PATH);
|
||||
}
|
||||
else if (VarData->lpCookedValue)
|
||||
else
|
||||
{
|
||||
GlobalFree(VarData->lpCookedValue);
|
||||
VarData->dwType = REG_SZ;
|
||||
VarData->lpCookedValue = GlobalAlloc(GPTR, (dwValueLength + 1) * sizeof(TCHAR));
|
||||
_tcscpy(VarData->lpCookedValue, VarData->lpRawValue);
|
||||
}
|
||||
}
|
||||
EndDialog(hwndDlg, 1);
|
||||
|
@ -119,7 +126,7 @@ SetEnvironmentVariables(HWND hwndListView,
|
|||
DWORD i;
|
||||
LPTSTR lpName;
|
||||
LPTSTR lpData;
|
||||
LPTSTR lpExpandData = NULL;
|
||||
LPTSTR lpExpandData;
|
||||
DWORD dwNameLength;
|
||||
DWORD dwDataLength;
|
||||
DWORD dwType;
|
||||
|
@ -167,6 +174,15 @@ SetEnvironmentVariables(HWND hwndListView,
|
|||
return;
|
||||
}
|
||||
|
||||
lpExpandData = GlobalAlloc(GPTR, 2048 * sizeof(TCHAR));
|
||||
if (lpExpandData == NULL)
|
||||
{
|
||||
GlobalFree(lpName);
|
||||
GlobalFree(lpData);
|
||||
RegCloseKey(hKey);
|
||||
return;
|
||||
}
|
||||
|
||||
for (i = 0; i < dwValues; i++)
|
||||
{
|
||||
dwNameLength = dwMaxValueNameLength + 1;
|
||||
|
@ -187,33 +203,23 @@ SetEnvironmentVariables(HWND hwndListView,
|
|||
return;
|
||||
}
|
||||
|
||||
if (dwType != REG_SZ && dwType != REG_EXPAND_SZ)
|
||||
continue;
|
||||
|
||||
VarData = GlobalAlloc(GPTR, sizeof(VARIABLE_DATA));
|
||||
|
||||
VarData->dwType = dwType;
|
||||
|
||||
VarData->lpName = GlobalAlloc(GPTR, (dwNameLength + 1) * sizeof(TCHAR));
|
||||
_tcscpy(VarData->lpName, lpName);
|
||||
|
||||
VarData->lpRawValue = GlobalAlloc(GPTR, (dwDataLength + 1) * sizeof(TCHAR));
|
||||
_tcscpy(VarData->lpRawValue, lpData);
|
||||
|
||||
if (dwType == REG_EXPAND_SZ)
|
||||
{
|
||||
lpExpandData = GlobalAlloc(GPTR, MAX_PATH * 2* sizeof(TCHAR));
|
||||
if (lpExpandData == NULL)
|
||||
{
|
||||
GlobalFree(lpName);
|
||||
GlobalFree(lpData);
|
||||
RegCloseKey(hKey);
|
||||
return;
|
||||
}
|
||||
|
||||
ExpandEnvironmentStrings(lpData,
|
||||
lpExpandData,
|
||||
2 * MAX_PATH);
|
||||
ExpandEnvironmentStrings(lpData, lpExpandData, 2048);
|
||||
|
||||
VarData->lpCookedValue = GlobalAlloc(GPTR, (_tcslen(lpExpandData) + 1) * sizeof(TCHAR));
|
||||
_tcscpy(VarData->lpCookedValue, lpExpandData);
|
||||
GlobalFree(lpExpandData);
|
||||
}
|
||||
|
||||
memset(&lvi, 0x00, sizeof(lvi));
|
||||
lvi.mask = LVIF_TEXT | LVIF_STATE | LVIF_PARAM;
|
||||
|
@ -222,10 +228,10 @@ SetEnvironmentVariables(HWND hwndListView,
|
|||
lvi.state = (i == 0) ? LVIS_SELECTED : 0;
|
||||
iItem = ListView_InsertItem(hwndListView, &lvi);
|
||||
|
||||
ListView_SetItemText(hwndListView, iItem, 1,
|
||||
(VarData->lpCookedValue) ? VarData->lpCookedValue : VarData->lpRawValue);
|
||||
ListView_SetItemText(hwndListView, iItem, 1, VarData->lpCookedValue);
|
||||
}
|
||||
|
||||
GlobalFree(lpExpandData);
|
||||
GlobalFree(lpName);
|
||||
GlobalFree(lpData);
|
||||
RegCloseKey(hKey);
|
||||
|
@ -316,7 +322,7 @@ OnNewVariable(HWND hwndDlg,
|
|||
if (!DialogBoxParam(hApplet,
|
||||
MAKEINTRESOURCE(IDD_EDIT_VARIABLE),
|
||||
hwndDlg,
|
||||
(DLGPROC) EditVariableDlgProc,
|
||||
(DLGPROC)EditVariableDlgProc,
|
||||
(LPARAM)VarData) > 0)
|
||||
{
|
||||
if (VarData->lpName != NULL)
|
||||
|
@ -332,7 +338,7 @@ OnNewVariable(HWND hwndDlg,
|
|||
}
|
||||
else
|
||||
{
|
||||
if(VarData->lpName != NULL && (VarData->lpCookedValue || VarData->lpRawValue))
|
||||
if (VarData->lpName != NULL && (VarData->lpCookedValue || VarData->lpRawValue))
|
||||
{
|
||||
memset(&lvi, 0x00, sizeof(lvi));
|
||||
lvi.mask = LVIF_TEXT | LVIF_STATE | LVIF_PARAM;
|
||||
|
@ -341,8 +347,7 @@ OnNewVariable(HWND hwndDlg,
|
|||
lvi.state = 0;
|
||||
iItem = ListView_InsertItem(hwndListView, &lvi);
|
||||
|
||||
ListView_SetItemText(hwndListView, iItem, 1,
|
||||
(VarData->lpCookedValue) ? VarData->lpCookedValue : VarData->lpRawValue);
|
||||
ListView_SetItemText(hwndListView, iItem, 1, VarData->lpCookedValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -373,12 +378,11 @@ OnEditVariable(HWND hwndDlg,
|
|||
if (DialogBoxParam(hApplet,
|
||||
MAKEINTRESOURCE(IDD_EDIT_VARIABLE),
|
||||
hwndDlg,
|
||||
(DLGPROC) EditVariableDlgProc,
|
||||
(DLGPROC)EditVariableDlgProc,
|
||||
(LPARAM)VarData) > 0)
|
||||
{
|
||||
ListView_SetItemText(hwndListView, iItem, 0, VarData->lpName);
|
||||
ListView_SetItemText(hwndListView, iItem, 1,
|
||||
(VarData->lpCookedValue) ? VarData->lpCookedValue : VarData->lpRawValue);
|
||||
ListView_SetItemText(hwndListView, iItem, 1, VarData->lpCookedValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -468,6 +472,7 @@ ReleaseListViewItems(HWND hwndDlg,
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
VOID
|
||||
SetAllVars(HWND hwndDlg,
|
||||
INT iDlgItem)
|
||||
|
@ -477,7 +482,6 @@ SetAllVars(HWND hwndDlg,
|
|||
LV_ITEM lvi;
|
||||
INT iItem;
|
||||
HKEY hk;
|
||||
DWORD Type = 0;
|
||||
|
||||
memset(&lvi, 0x00, sizeof(lvi));
|
||||
|
||||
|
@ -503,28 +507,26 @@ SetAllVars(HWND hwndDlg,
|
|||
return;
|
||||
}
|
||||
|
||||
/* loop through all system variables */
|
||||
/* Loop through all variables */
|
||||
while(ListView_GetItem(hwndListView, &lvi))
|
||||
{
|
||||
/* Get the data in each item */
|
||||
VarData = (PVARIABLE_DATA)lvi.lParam;
|
||||
if (VarData != NULL)
|
||||
{
|
||||
/* Get the type */
|
||||
RegQueryValueEx(hk,VarData->lpName,NULL,&Type,NULL,NULL);
|
||||
|
||||
/* Set the new value */
|
||||
if (RegSetValueEx(hk,
|
||||
VarData->lpName,
|
||||
0,
|
||||
Type,
|
||||
(LPBYTE) VarData->lpRawValue,
|
||||
VarData->dwType,
|
||||
(LPBYTE)VarData->lpRawValue,
|
||||
(DWORD)(_tcslen(VarData->lpRawValue) + 1) * sizeof(TCHAR)))
|
||||
{
|
||||
RegCloseKey(hk);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/* Fill struct for next item */
|
||||
lvi.mask = LVIF_PARAM;
|
||||
lvi.iItem = ++iItem;
|
||||
|
@ -533,6 +535,7 @@ SetAllVars(HWND hwndDlg,
|
|||
RegCloseKey(hk);
|
||||
}
|
||||
|
||||
|
||||
/* Environment dialog procedure */
|
||||
INT_PTR CALLBACK
|
||||
EnvironmentDlgProc(HWND hwndDlg,
|
||||
|
@ -576,15 +579,20 @@ EnvironmentDlgProc(HWND hwndDlg,
|
|||
case IDOK:
|
||||
SetAllVars(hwndDlg, IDC_USER_VARIABLE_LIST);
|
||||
SetAllVars(hwndDlg, IDC_SYSTEM_VARIABLE_LIST);
|
||||
EndDialog(hwndDlg, 0);
|
||||
return TRUE;
|
||||
|
||||
case IDCANCEL:
|
||||
ReleaseListViewItems(hwndDlg, IDC_USER_VARIABLE_LIST);
|
||||
ReleaseListViewItems(hwndDlg, IDC_SYSTEM_VARIABLE_LIST);
|
||||
EndDialog(hwndDlg, 0);
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
|
||||
case WM_DESTROY:
|
||||
ReleaseListViewItems(hwndDlg, IDC_USER_VARIABLE_LIST);
|
||||
ReleaseListViewItems(hwndDlg, IDC_SYSTEM_VARIABLE_LIST);
|
||||
break;
|
||||
|
||||
case WM_NOTIFY:
|
||||
{
|
||||
NMHDR *phdr;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue