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);
103 WinHelp (hDlg, g.szHelpFile, HELP_CONTEXT, IDH_AFSCREDS_TAB_DRIVES);
110 void Mount_OnInitDialog (HWND hDlg)
113 SendDlgItemMessage (hDlg, IDC_LIST, LB_SETTABSTOPS, 1, (LPARAM)&xTabStop);
115 Mount_OnUpdate (hDlg, TRUE);
119 void Mount_OnUpdate (HWND hDlg, BOOL fOnInitDialog)
122 memset(&List, 0, sizeof(DRIVEMAPLIST));
123 QueryDriveMapList (&List);
125 HWND hList = GetDlgItem (hDlg, IDC_LIST);
126 int iItemSel = LB_GetSelected(hList);
127 int iDataSel = Mount_DriveFromItem (hDlg, iItemSel);
130 if (fOnInitDialog && (iDataSel == -1))
131 iDataSel = l.iDriveSelectLast;
133 LB_StartChange(hList, TRUE);
135 for (int iDrive = 25; iDrive >= 0; --iDrive)
137 if (!List.aDriveMap[ iDrive ].szMapping[0])
140 TCHAR szAfsPath[ MAX_PATH ];
141 AdjustAfsPath (szAfsPath, List.aDriveMap[ iDrive ].szMapping, TRUE, FALSE);
143 LPTSTR psz = FormatString (IDS_DRIVE_MAP, TEXT("%c%s"), List.aDriveMap[ iDrive ].chDrive, szAfsPath);
144 int iItem = LB_AddItem(hList, psz, List.aDriveMap[ iDrive ].fActive);
147 int iCount = SendMessage(hList, LB_GETCOUNT, 0, 0);
149 /* This really shouldn't work except that we are adding
150 * the strings in alphabetical order. Otherwise, we could
151 * identify an index value for a string that could then change.
153 if (iDrive == iDataSel)
157 LB_EndChange(hList, NULL);
159 LB_SetSelected(hList, iItemSel);
161 Mount_OnSelect (hDlg);
162 FreeDriveMapList (&List);
166 void Mount_OnSelect (HWND hDlg)
168 BOOL fServiceRunning = IsServiceRunning();
170 HWND hList = GetDlgItem (hDlg, IDC_LIST);
171 int iItemSel = LB_GetSelected(hList);
172 int iDataSel = Mount_DriveFromItem (hDlg, iItemSel);
174 l.iDriveSelectLast = iDataSel;
176 EnableWindow (GetDlgItem (hDlg, IDC_ADD), fServiceRunning);
177 EnableWindow (GetDlgItem (hDlg, IDC_EDIT), fServiceRunning && (iDataSel != -1));
178 EnableWindow (GetDlgItem (hDlg, IDC_REMOVE), fServiceRunning && (iDataSel != -1));
182 void Mount_OnCheck (HWND hDlg)
185 QueryDriveMapList (&List);
187 HWND hList = GetDlgItem (hDlg, IDC_LIST);
188 int iItemSel = LB_GetSelected(hList);
189 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
190 BOOL fChecked = SendMessage (hList, LB_GETITEMDATA, iItemSel, 0);
195 if (fChecked && List.aDriveMap[ iDriveSel ].szMapping[0] && !List.aDriveMap[ iDriveSel ].fActive)
197 if (!ActivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, List.aDriveMap[ iDriveSel ].szMapping, List.aDriveMap[ iDriveSel ].szSubmount, List.aDriveMap[ iDriveSel ].fPersistent, &dwStatus))
198 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), dwStatus);
199 Mount_OnUpdate (hDlg);
201 else if (!fChecked && List.aDriveMap[ iDriveSel ].fActive)
203 if (!InactivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, &dwStatus))
204 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
205 Mount_OnUpdate (hDlg);
207 WriteActiveMap(List.aDriveMap[ iDriveSel ].chDrive, fChecked && List.aDriveMap[ iDriveSel ].fPersistent );
210 FreeDriveMapList (&List);
214 void Mount_OnRemove (HWND hDlg)
216 HWND hList = GetDlgItem (hDlg, IDC_LIST);
217 int iItemSel = LB_GetSelected(hList);
218 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
223 QueryDriveMapList (&List);
225 if (List.aDriveMap[ iDriveSel ].szMapping[0])
227 if (List.aDriveMap[ iDriveSel ].fActive)
230 if (!InactivateDriveMap (List.aDriveMap[ iDriveSel ].chDrive, &dwStatus))
232 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
236 List.aDriveMap[ iDriveSel ].szMapping[0] = TEXT('\0');
237 WriteDriveMappings (&List);
239 Mount_OnUpdate (hDlg);
241 WriteActiveMap(List.aDriveMap[ iDriveSel ].chDrive, FALSE );
242 FreeDriveMapList (&List);
247 void Mount_OnAdd (HWND hDlg)
249 Mount_AdjustMapping (hDlg, -1);
253 void Mount_OnEdit (HWND hDlg)
255 HWND hList = GetDlgItem (hDlg, IDC_LIST);
256 int iItemSel = LB_GetSelected(hList);
257 int iDriveSel = Mount_DriveFromItem (hDlg, iItemSel);
259 Mount_AdjustMapping (hDlg, iDriveSel);
263 void Mount_AdjustMapping (HWND hDlg, int iDrive)
266 QueryDriveMapList (&List);
268 DRIVEMAP DriveMapOrig;
269 memset (&DriveMapOrig, 0x00, sizeof(DRIVEMAP));
273 memcpy (&DriveMapOrig, &List.aDriveMap[ iDrive ], sizeof(DRIVEMAP));
277 memcpy (&DriveMap, &DriveMapOrig, sizeof(DRIVEMAP));
279 if (ModalDialogParam (IDD_MAPPING, hDlg, (DLGPROC)Mapping_DlgProc, (LPARAM)&DriveMap) == IDOK)
281 TCHAR szAfsPathOrig[ MAX_PATH ];
283 AdjustAfsPath (szAfsPathOrig, DriveMapOrig.szMapping, TRUE, TRUE);
285 TCHAR szAfsPathNew[ MAX_PATH ];
286 AdjustAfsPath (szAfsPathNew, DriveMap.szMapping, TRUE, TRUE);
288 if ( (lstrcmpi (szAfsPathOrig, szAfsPathNew)) ||
289 (lstrcmpi (DriveMapOrig.szSubmount, DriveMap.szSubmount)) ||
290 (DriveMapOrig.chDrive != DriveMap.chDrive) ||
291 (DriveMapOrig.fPersistent != DriveMap.fPersistent) )
295 if ((iDrive != -1) && (DriveMapOrig.fActive))
297 if (!InactivateDriveMap (DriveMapOrig.chDrive, &dwStatus))
299 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), dwStatus);
300 Mount_OnUpdate (hDlg);
305 if (!ActivateDriveMap (DriveMap.chDrive, szAfsPathNew, DriveMap.szSubmount, DriveMap.fPersistent, &dwStatus))
307 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), dwStatus);
308 Mount_OnUpdate (hDlg);
312 if (DriveMap.szSubmount[0])
314 TCHAR szSubmountNow[ MAX_PATH ];
315 if (GetDriveSubmount (DriveMap.chDrive, szSubmountNow))
317 if (lstrcmpi (DriveMap.szSubmount, szSubmountNow))
319 int idsTitle = (g.fIsWinNT) ? IDS_NEWSUB_TITLE : IDS_NEWSUB_TITLE_95;
320 Message (MB_OK | MB_ICONASTERISK, idsTitle, IDS_NEWSUB_DESC);
326 memset (&List.aDriveMap[ iDrive ], 0x00, sizeof(DRIVEMAP));
327 memcpy (&List.aDriveMap[ DriveMap.chDrive-chDRIVE_A ], &DriveMap, sizeof(DRIVEMAP));
328 lstrcpy (List.aDriveMap[ DriveMap.chDrive-chDRIVE_A ].szMapping, szAfsPathNew);
329 WriteDriveMappings (&List);
331 Mount_OnUpdate (hDlg);
337 int Mount_DriveFromItem (HWND hDlg, int iItem)
339 TCHAR szItem[ 1024 ] = TEXT("");
340 SendDlgItemMessage (hDlg, IDC_LIST, LB_GETTEXT, iItem, (LPARAM)szItem);
343 if ((pch = (LPTSTR)lstrchr (szItem, TEXT(':'))) != NULL)
348 if ((*pch >= TEXT('A')) && (*pch <= TEXT('Z')))
349 return (*pch) - TEXT('A');
357 BOOL CALLBACK Mapping_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
362 SetWindowLongPtr (hDlg, DWLP_USER, lp);
363 Mapping_OnInitDialog (hDlg);
374 EndDialog (hDlg, IDCANCEL);
378 Mapping_OnEnable (hDlg);
382 Mapping_DlgProc (hDlg, WM_HELP, 0, 0);
388 WinHelp (hDlg, g.szHelpFile, HELP_CONTEXT, IDH_AFSCREDS_MAPDRIVE);
395 void Mapping_OnInitDialog (HWND hDlg)
397 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
399 // Fill in the combo box
401 DWORD dwDrives = GetLogicalDrives() | 0x07; // Always pretend A,B,C: are used
403 if (pMap->chDrive != 0)
404 dwDrives &= ~( 1 << (pMap->chDrive - chDRIVE_A) );
407 HWND hCombo = GetDlgItem (hDlg, IDC_MAP_LETTER);
408 SendMessage (hCombo, WM_SETREDRAW, FALSE, 0);
410 for (int ii = 0; ii < 26; ++ii)
412 if (!(dwDrives & (1<<ii)))
414 TCHAR szText[ cchRESOURCE ];
415 GetString (szText, IDS_MAP_LETTER);
418 if ((pch = (LPTSTR)lstrchr (szText, TEXT('*'))) != NULL)
419 *pch = TEXT('A') + ii;
421 int iItem = SendMessage (hCombo, CB_ADDSTRING, 0, (LPARAM)szText);
422 SendMessage (hCombo, CB_SETITEMDATA, iItem, ii);
423 if (pMap->chDrive && (ii == pMap->chDrive - chDRIVE_A))
425 else if ((!pMap->chDrive) && (iItemSel == -1))
430 SendMessage (hCombo, WM_SETREDRAW, TRUE, 0);
431 SendMessage (hCombo, CB_SETCURSEL, iItemSel, 0);
433 TCHAR szMapping[ MAX_PATH ];
434 AdjustAfsPath (szMapping, ((pMap->szMapping[0]) ? pMap->szMapping : cm_slash_mount_root), TRUE, FALSE);
435 CHAR msg[256], msgf[256];
436 if (GetDlgItemText(hDlg,IDC_STATICSUBMOUNT,(LPSTR)msg,sizeof(msg)-1)>0)
438 wsprintf(msgf,msg,cm_back_slash_mount_root,cm_back_slash_mount_root);
439 SetDlgItemText (hDlg, IDC_STATICSUBMOUNT, msgf);
441 SetDlgItemText (hDlg, IDC_MAP_PATH, szMapping);
442 SetDlgItemText (hDlg, IDC_MAP_DESC, pMap->szSubmount);
444 CheckDlgButton (hDlg, IDC_MAP_PERSISTENT, (pMap->chDrive == 0) ? TRUE : (pMap->fPersistent));
446 Mapping_OnEnable (hDlg);
450 void Mapping_OnOK (HWND hDlg)
452 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
454 int iItem = SendDlgItemMessage (hDlg, IDC_MAP_LETTER, CB_GETCURSEL, 0, 0);
455 int iDrive = SendDlgItemMessage (hDlg, IDC_MAP_LETTER, CB_GETITEMDATA, iItem, 0);
457 pMap->chDrive = chDRIVE_A + iDrive;
458 GetDlgItemText (hDlg, IDC_MAP_PATH, pMap->szMapping, MAX_PATH);
459 GetDlgItemText (hDlg, IDC_MAP_DESC, pMap->szSubmount, MAX_PATH);
460 pMap->fPersistent = IsDlgButtonChecked (hDlg, IDC_MAP_PERSISTENT);
462 if (pMap->szSubmount[0] && !IsValidSubmountName (pMap->szSubmount))
464 int idsTitle = (g.fIsWinNT) ? IDS_BADSUB_TITLE : IDS_BADSUB_TITLE_95;
465 Message (MB_ICONHAND, idsTitle, IDS_BADSUB_DESC);
469 if ( (lstrncmpi (pMap->szMapping, cm_slash_mount_root, lstrlen(cm_slash_mount_root))) && /*TEXT("/afs")*/
470 (lstrncmpi (pMap->szMapping, cm_back_slash_mount_root, lstrlen(cm_back_slash_mount_root))) ) /*TEXT("\\afs")*/
472 Message (MB_ICONHAND, IDS_BADMAP_TITLE, IDS_BADMAP_DESC);
476 WriteActiveMap(pMap->chDrive, pMap->fPersistent);
477 EndDialog (hDlg, IDOK);
481 void Mapping_OnEnable (HWND hDlg)
483 TCHAR szPath[ MAX_PATH ];
484 GetDlgItemText (hDlg, IDC_MAP_PATH, szPath, MAX_PATH);
485 EnableWindow (GetDlgItem (hDlg, IDOK), (szPath[0] != TEXT('\0')));