2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
14 #include <afsconfig.h>
15 #include <afs/param.h>
17 #include <afs/fs_utils.h>
24 * VARIABLES __________________________________________________________________
35 * PROTOTYPES _________________________________________________________________
39 void Mount_OnInitDialog (HWND hDlg);
40 void Mount_OnUpdate (HWND hDlg, BOOL fOnInitDialog = FALSE);
41 void Mount_OnSelect (HWND hDlg);
42 void Mount_OnCheck (HWND hDlg);
43 void Mount_OnRemove (HWND hDlg);
44 void Mount_OnAdd (HWND hDlg);
45 void Mount_OnEdit (HWND hDlg);
47 void Mount_AdjustMapping (HWND hDlg, int iDrive);
48 int Mount_DriveFromItem (HWND hDlg, int iItem);
50 BOOL CALLBACK Mapping_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp);
51 void Mapping_OnInitDialog (HWND hDlg);
52 void Mapping_OnOK (HWND hDlg);
53 void Mapping_OnEnable (HWND hDlg);
57 * ROUTINES ___________________________________________________________________
61 BOOL CALLBACK Mount_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
67 GetClientRect (GetParent(hDlg), &rTab);
68 TabCtrl_AdjustRect (GetParent (hDlg), FALSE, &rTab);
69 SetWindowPos (hDlg, NULL, rTab.left, rTab.top, 0, 0, SWP_NOSIZE | SWP_NOACTIVATE | SWP_NOZORDER);
71 Mount_OnInitDialog (hDlg);
86 Mount_OnRemove (hDlg);
90 if (HIWORD(wp) == LBN_CLICKED)
92 else if ((HIWORD(wp) == LBN_SELCHANGE) || (HIWORD(wp) == LBN_SELCANCEL))
93 Mount_OnSelect (hDlg);
97 Mount_DlgProc (hDlg, WM_HELP, 0, 0);
106 void Mount_OnInitDialog (HWND hDlg)
109 SendDlgItemMessage (hDlg, IDC_LIST, LB_SETTABSTOPS, 1, (LPARAM)&xTabStop);
111 Mount_OnUpdate (hDlg, TRUE);
115 void Mount_OnUpdate (HWND hDlg, BOOL fOnInitDialog)
118 memset(&List, 0, sizeof(DRIVEMAPLIST));
119 QueryDriveMapList (&List);
121 HWND hList = GetDlgItem (hDlg, IDC_LIST);
122 int iItemSel = LB_GetSelected(hList);
123 int iDataSel = Mount_DriveFromItem (hDlg, iItemSel);
126 if (fOnInitDialog && (iDataSel == -1))
127 iDataSel = l.iDriveSelectLast;
129 LB_StartChange(hList, TRUE);
131 for (int iDrive = 25; iDrive >= 0; --iDrive)
133 if (!List.aDriveMap[ iDrive ].szMapping[0])
136 TCHAR szAfsPath[ MAX_PATH ];
137 AdjustAfsPath (szAfsPath, List.aDriveMap[ iDrive ].szMapping, TRUE, FALSE);
139 LPTSTR psz = FormatString (IDS_DRIVE_MAP, TEXT("%c%s"), List.aDriveMap[ iDrive ].chDrive, szAfsPath);
140 int iItem = LB_AddItem(hList, psz, List.aDriveMap[ iDrive ].fActive);
143 int iCount = SendMessage(hList, LB_GETCOUNT, 0, 0);
145 /* This really shouldn't work except that we are adding
146 * the strings in alphabetical order. Otherwise, we could
147 * identify an index value for a string that could then change.
149 if (iDrive == iDataSel)
153 LB_EndChange(hList, NULL);
155 LB_SetSelected(hList, iItemSel);
157 Mount_OnSelect (hDlg);
158 FreeDriveMapList (&List);
162 void Mount_OnSelect (HWND hDlg)
164 BOOL fServiceRunning = IsServiceRunning();
166 HWND hList = GetDlgItem (hDlg, IDC_LIST);
167 int iItemSel = LB_GetSelected(hList);
168 int iDataSel = Mount_DriveFromItem (hDlg, iItemSel);
170 l.iDriveSelectLast = iDataSel;
172 EnableWindow (GetDlgItem (hDlg, IDC_ADD), fServiceRunning);
173 EnableWindow (GetDlgItem (hDlg, IDC_EDIT), fServiceRunning && (iDataSel != -1));
174 EnableWindow (GetDlgItem (hDlg, IDC_REMOVE), fServiceRunning && (iDataSel != -1));
178 void Mount_OnCheck (HWND hDlg)
181 QueryDriveMapList (&List);
183 HWND hList = GetDlgItem (hDlg, IDC_LIST);
184 int iItemSel = LB_GetSelected(hList);
185 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
186 BOOL fChecked = SendMessage (hList, LB_GETITEMDATA, iItemSel, 0);
191 if (fChecked && List.aDriveMap[ iDriveSel ].szMapping[0] && !List.aDriveMap[ iDriveSel ].fActive)
193 if (!ActivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, List.aDriveMap[ iDriveSel ].szMapping, List.aDriveMap[ iDriveSel ].szSubmount, List.aDriveMap[ iDriveSel ].fPersistent, &dwStatus))
194 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), dwStatus);
195 Mount_OnUpdate (hDlg);
197 else if (!fChecked && List.aDriveMap[ iDriveSel ].fActive)
199 if (!InactivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, &dwStatus))
200 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
201 Mount_OnUpdate (hDlg);
203 WriteActiveMap(List.aDriveMap[ iDriveSel ].chDrive, fChecked && List.aDriveMap[ iDriveSel ].fPersistent );
206 FreeDriveMapList (&List);
210 void Mount_OnRemove (HWND hDlg)
212 HWND hList = GetDlgItem (hDlg, IDC_LIST);
213 int iItemSel = LB_GetSelected(hList);
214 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
219 QueryDriveMapList (&List);
221 if (List.aDriveMap[ iDriveSel ].szMapping[0])
223 if (List.aDriveMap[ iDriveSel ].fActive)
226 if (!InactivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, &dwStatus))
228 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
232 List.aDriveMap[ iDriveSel ].szMapping[0] = TEXT('\0');
233 WriteDriveMappings (&List);
235 Mount_OnUpdate (hDlg);
237 WriteActiveMap(List.aDriveMap[ iDriveSel ].chDrive, FALSE );
238 FreeDriveMapList (&List);
243 void Mount_OnAdd (HWND hDlg)
245 Mount_AdjustMapping (hDlg, -1);
249 void Mount_OnEdit (HWND hDlg)
251 HWND hList = GetDlgItem (hDlg, IDC_LIST);
252 int iItemSel = LB_GetSelected(hList);
253 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
255 Mount_AdjustMapping (hDlg, iDriveSel);
259 void Mount_AdjustMapping (HWND hDlg, int iDrive)
262 QueryDriveMapList (&List);
264 DRIVEMAP DriveMapOrig;
265 memset (&DriveMapOrig, 0x00, sizeof(DRIVEMAP));
269 memcpy (&DriveMapOrig, &List.aDriveMap[ iDrive ], sizeof(DRIVEMAP));
273 memcpy (&DriveMap, &DriveMapOrig, sizeof(DRIVEMAP));
275 if (ModalDialogParam (IDD_MAPPING, hDlg, (DLGPROC)Mapping_DlgProc, (LPARAM)&DriveMap) == IDOK)
277 TCHAR szAfsPathOrig[ MAX_PATH ];
279 AdjustAfsPath (szAfsPathOrig, DriveMapOrig.szMapping, TRUE, TRUE);
281 TCHAR szAfsPathNew[ MAX_PATH ];
282 AdjustAfsPath (szAfsPathNew, DriveMap.szMapping, TRUE, TRUE);
284 if ( (lstrcmpi (szAfsPathOrig, szAfsPathNew)) ||
285 (lstrcmpi (DriveMapOrig.szSubmount, DriveMap.szSubmount)) ||
286 (DriveMapOrig.chDrive != DriveMap.chDrive) ||
287 (DriveMapOrig.fPersistent != DriveMap.fPersistent) )
291 if ((iDrive != -1) && (DriveMapOrig.fActive))
293 if (!InactivateDriveMap (DriveMapOrig.chDrive, &dwStatus))
295 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
296 Mount_OnUpdate (hDlg);
301 if (!ActivateDriveMap (DriveMap.chDrive, szAfsPathNew, DriveMap.szSubmount, DriveMap.fPersistent, &dwStatus))
303 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), dwStatus);
304 Mount_OnUpdate (hDlg);
308 if (DriveMap.szSubmount[0])
310 TCHAR szSubmountNow[ MAX_PATH ];
311 if (GetDriveSubmount (DriveMap.chDrive, szSubmountNow))
313 if (lstrcmpi (DriveMap.szSubmount, szSubmountNow))
315 int idsTitle = (g.fIsWinNT) ? IDS_NEWSUB_TITLE : IDS_NEWSUB_TITLE_95;
316 Message (MB_OK | MB_ICONASTERISK, idsTitle, IDS_NEWSUB_DESC);
322 memset (&List.aDriveMap[ iDrive ], 0x00, sizeof(DRIVEMAP));
323 memcpy (&List.aDriveMap[ DriveMap.chDrive-chDRIVE_A ], &DriveMap, sizeof(DRIVEMAP));
324 lstrcpy (List.aDriveMap[ DriveMap.chDrive-chDRIVE_A ].szMapping, szAfsPathNew);
325 WriteDriveMappings (&List);
327 Mount_OnUpdate (hDlg);
333 int Mount_DriveFromItem (HWND hDlg, int iItem)
335 TCHAR szItem[ 1024 ] = TEXT("");
336 SendDlgItemMessage (hDlg, IDC_LIST, LB_GETTEXT, iItem, (LPARAM)szItem);
339 if ((pch = (LPTSTR)lstrchr (szItem, TEXT(':'))) != NULL)
344 if ((*pch >= TEXT('A')) && (*pch <= TEXT('Z')))
345 return (*pch) - TEXT('A');
353 BOOL CALLBACK Mapping_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
358 SetWindowLongPtr (hDlg, DWLP_USER, lp);
359 Mapping_OnInitDialog (hDlg);
370 EndDialog (hDlg, IDCANCEL);
374 Mapping_OnEnable (hDlg);
378 Mapping_DlgProc (hDlg, WM_HELP, 0, 0);
387 void Mapping_OnInitDialog (HWND hDlg)
389 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
391 // Fill in the combo box
393 DWORD dwDrives = GetLogicalDrives() | 0x07; // Always pretend A,B,C: are used
395 if (pMap->chDrive != 0)
396 dwDrives &= ~( 1 << (pMap->chDrive - chDRIVE_A) );
399 HWND hCombo = GetDlgItem (hDlg, IDC_MAP_LETTER);
400 SendMessage (hCombo, WM_SETREDRAW, FALSE, 0);
402 for (int ii = 0; ii < 26; ++ii)
404 if (!(dwDrives & (1<<ii)))
406 TCHAR szText[ cchRESOURCE ];
407 GetString (szText, IDS_MAP_LETTER);
410 if ((pch = (LPTSTR)lstrchr (szText, TEXT('*'))) != NULL)
411 *pch = TEXT('A') + ii;
413 int iItem = SendMessage (hCombo, CB_ADDSTRING, 0, (LPARAM)szText);
414 SendMessage (hCombo, CB_SETITEMDATA, iItem, ii);
415 if (pMap->chDrive && (ii == pMap->chDrive - chDRIVE_A))
417 else if ((!pMap->chDrive) && (iItemSel == -1))
422 SendMessage (hCombo, WM_SETREDRAW, TRUE, 0);
423 SendMessage (hCombo, CB_SETCURSEL, iItemSel, 0);
425 TCHAR szMapping[ MAX_PATH ];
426 AdjustAfsPath (szMapping, ((pMap->szMapping[0]) ? pMap->szMapping : cm_slash_mount_root), TRUE, FALSE);
427 CHAR msg[256], msgf[256];
428 if (GetDlgItemText(hDlg,IDC_STATICSUBMOUNT,(LPSTR)msg,sizeof(msg)-1)>0)
430 wsprintf(msgf,msg,cm_back_slash_mount_root,cm_back_slash_mount_root);
431 SetDlgItemText (hDlg, IDC_STATICSUBMOUNT, msgf);
433 SetDlgItemText (hDlg, IDC_MAP_PATH, szMapping);
434 SetDlgItemText (hDlg, IDC_MAP_DESC, pMap->szSubmount);
436 CheckDlgButton (hDlg, IDC_MAP_PERSISTENT, (pMap->chDrive == 0) ? TRUE : (pMap->fPersistent));
438 Mapping_OnEnable (hDlg);
442 void Mapping_OnOK (HWND hDlg)
444 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
446 int iItem = SendDlgItemMessage (hDlg, IDC_MAP_LETTER, CB_GETCURSEL, 0, 0);
447 int iDrive = SendDlgItemMessage (hDlg, IDC_MAP_LETTER, CB_GETITEMDATA, iItem, 0);
449 pMap->chDrive = chDRIVE_A + iDrive;
450 GetDlgItemText (hDlg, IDC_MAP_PATH, pMap->szMapping, MAX_PATH);
451 GetDlgItemText (hDlg, IDC_MAP_DESC, pMap->szSubmount, MAX_PATH);
452 pMap->fPersistent = IsDlgButtonChecked (hDlg, IDC_MAP_PERSISTENT);
454 if (pMap->szSubmount[0] && !IsValidSubmountName (pMap->szSubmount))
456 int idsTitle = (g.fIsWinNT) ? IDS_BADSUB_TITLE : IDS_BADSUB_TITLE_95;
457 Message (MB_ICONHAND, idsTitle, IDS_BADSUB_DESC);
461 if ( (lstrncmpi (pMap->szMapping, cm_slash_mount_root, lstrlen(cm_slash_mount_root))) && /*TEXT("/afs")*/
462 (lstrncmpi (pMap->szMapping, cm_back_slash_mount_root, lstrlen(cm_back_slash_mount_root))) ) /*TEXT("\\afs")*/
464 Message (MB_ICONHAND, IDS_BADMAP_TITLE, IDS_BADMAP_DESC);
468 WriteActiveMap(pMap->chDrive, pMap->fPersistent);
469 EndDialog (hDlg, IDOK);
473 void Mapping_OnEnable (HWND hDlg)
475 TCHAR szPath[ MAX_PATH ];
476 GetDlgItemText (hDlg, IDC_MAP_PATH, szPath, MAX_PATH);
477 EnableWindow (GetDlgItem (hDlg, IDOK), (szPath[0] != TEXT('\0')));