void CNBListViewCtrl::AddDiskObjectList(NBUnitDevicePtrList &disks) { NBUnitDevicePtrList::iterator itr; for ( itr = disks.begin(); itr != disks.end(); ++itr ) AddDiskObject( *itr ); SortItems(); }
NBUnitDevicePtrList CNBListViewCtrl::GetDiskObjectList() { int nCount = CListViewCtrl::GetItemCount(); NBUnitDevicePtrList diskList; for ( int i=0; i < nCount; i++ ) { diskList.push_back( (CNBUnitDevice *)CListViewCtrl::GetItemData(i) ); } return diskList; }
void CMainFrame::OnSpareRemove(UINT wNotifyCode, int wID, HWND hwndCtl) { CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBUnitDevice *pUnitDevice = dynamic_cast<CNBUnitDevice *>(pDevice); if(!pUnitDevice || !pUnitDevice->GetLogicalDevice()->IsOperatableAll()) return; NBUnitDevicePtrList listUnitDevices; listUnitDevices.push_back(pUnitDevice); CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_SPARE_REMOVE_DLG_CAPTION, IDS_SPARE_REMOVE_DLG_MESSAGE, listUnitDevices, 0, NULL, NULL); if(dlgSelectDevice.DoModal() != IDOK) return; NDASCOMM_CONNECTION_INFO ci; pUnitDevice->InitConnectionInfo(&ci, TRUE); AutoCursor l_auto_cursor(IDC_WAIT); BOOL bResults = NdasOpSpareRemove(&ci); l_auto_cursor.Release(); pUnitDevice->GetLogicalDevice()->HixChangeNotify(pGetNdasHostGuid()); if(!bResults) { CString strMsg; DWORD dwLastError = ::GetLastError(); strMsg.LoadString(IDS_OPERATION_FAIL); ShowErrorMessageBox(strMsg); return; } OnRefreshStatus(NULL, NULL, NULL); }
NBUnitDevicePtrList CNBLogicalDevice::GetOperatableDevices() { NBUnitDevicePtrList listUnitDevices; for(UINT32 i = 0; i < DevicesTotal(); i++) { if(!m_mapUnitDevices.count(i)) continue; listUnitDevices.push_back(m_mapUnitDevices[i]); } return listUnitDevices; }
NBUnitDevicePtrList CNBListViewCtrl::GetSelectedDiskObjectList() { int nCount = CListViewCtrl::GetSelectedCount(); int nItem; NBUnitDevicePtrList selectDiskList; nItem = -1; for ( int i=0; i < nCount; i++ ) { nItem = CListViewCtrl::GetNextItem( nItem, LVNI_SELECTED ); selectDiskList.push_back( (CNBUnitDevice *)CListViewCtrl::GetItemData(nItem) ); } return selectDiskList; }
NBUnitDevicePtrList CNBLogicalDevice::GetOperatableDevices() { NBUnitDevicePtrList listUnitDevices; for(UINT32 i = 0; i < DevicesTotal(); i++) { if(!m_mapUnitDevices.count(i)) continue; if (m_mapUnitDevices[i]->IsMissingMember()) { // Cannot touch missing device. continue; } listUnitDevices.push_back(m_mapUnitDevices[i]); } return listUnitDevices; }
NBUnitDevicePtrList CMainFrame::GetOperatableSingleDevices() { NBUnitDevicePtrList listUnitDevicesSingle; CNBLogicalDevice *pLogicalDevice; for(NBLogicalDevicePtrList::iterator itLogicalDevice = m_listLogicalDevices.begin(); itLogicalDevice != m_listLogicalDevices.end(); itLogicalDevice++) { pLogicalDevice = *itLogicalDevice; if( pLogicalDevice->IsOperatable() && pLogicalDevice->IsHDD() && !pLogicalDevice->IsGroup()) { listUnitDevicesSingle.push_back((*pLogicalDevice)[0]); } } return listUnitDevicesSingle; }
void CSelectDiskPage::OnClickAddRemove(UINT /*wNotifyCode*/, int wID, HWND /*hwndCtl*/) { CNBListViewCtrl *pWndFrom, *pWndTo; switch(wID) { case IDC_BTN_ADD: pWndFrom = &m_wndListSingle; pWndTo = &m_wndListBind; break; case IDC_BTN_REMOVE_ALL: m_wndListBind.SelectAllDiskObject(); case IDC_BTN_REMOVE: pWndFrom = &m_wndListBind; pWndTo = &m_wndListSingle; break; default: return; } NBUnitDevicePtrList selectedDisks = pWndFrom->GetSelectedDiskObjectList(); if ( selectedDisks.size() == 0 ) return; pWndFrom->DeleteDiskObjectList( selectedDisks ); pWndTo->AddDiskObjectList( selectedDisks ); pWndTo->SelectDiskObjectList( selectedDisks ); /* for ( UINT i=0; i < selectedDisks.size(); i++ ) { if ( bFromSingle ) m_wndDiskList.InsertItem(); else m_wndDiskList.DeleteItem(); } */ UpdateControls(); }
void CNBListViewCtrl::DeleteDiskObjectList(NBUnitDevicePtrList &disks) { NBUnitDevicePtrList::iterator itr; for ( itr = disks.begin(); itr != disks.end(); ++itr ) DeleteDiskObject( *itr ); }
void CMainFrame::OnUnBind(UINT wNotifyCode, int wID, HWND hwndCtl) { CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBLogicalDevice *pLogicalDevice = dynamic_cast<CNBLogicalDevice *>(pDevice); if(!pLogicalDevice) return; BOOL bUnbindMirror = (NMT_RAID1 == pLogicalDevice->GetType() || NMT_RAID1R == pLogicalDevice->GetType() || NMT_MIRROR == pLogicalDevice->GetType()); // warning message CString strMsg; NBUnitDevicePtrList listUnitDevices = pLogicalDevice->GetOperatableDevices(); CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_UNBIND_DLG_CAPTION, (bUnbindMirror) ? IDS_WARNING_UNBIND_MIR : IDS_WARNING_UNBIND, listUnitDevices, 0, NULL, NULL); if(dlgSelectDevice.DoModal() != IDOK) return; NDASCOMM_CONNECTION_INFO *ci = new NDASCOMM_CONNECTION_INFO[listUnitDevices.size()]; UINT32 i = 0; for(NBUnitDevicePtrList::iterator itUnitDevice = listUnitDevices.begin(); itUnitDevice != listUnitDevices.end(); i++, itUnitDevice++) { (*itUnitDevice)->InitConnectionInfo(&ci[i], TRUE); } AutoCursor l_auto_cursor(IDC_WAIT); UINT32 BindResult = NdasOpBind(listUnitDevices.size(), ci, NMT_SINGLE, 0); l_auto_cursor.Release(); DWORD dwLastError = ::GetLastError(); if(i == BindResult) { CString strTitle; strTitle.LoadString(IDS_APPLICATION); strMsg.LoadString( (bUnbindMirror) ? IDS_WARNING_UNBIND_AFTER_MIR : IDS_WARNING_UNBIND_AFTER); MessageBox( strMsg, strTitle, MB_OK|MB_ICONINFORMATION ); } else { ::SetLastError(dwLastError); switch(dwLastError) { case NDASCOMM_ERROR_RW_USER_EXIST: case NDASOP_ERROR_ALREADY_USED: case NDASOP_ERROR_DEVICE_FAIL: case NDASOP_ERROR_NOT_SINGLE_DISK: case NDASOP_ERROR_DEVICE_UNSUPPORTED: case NDASOP_ERROR_NOT_BOUND_DISK: // does not return this error if(BindResult < listUnitDevices.size()) { i = 0; for(NBUnitDevicePtrList::iterator itUnitDevice = listUnitDevices.begin(); itUnitDevice != listUnitDevices.end(); i++, itUnitDevice++) { if(i == BindResult) strMsg.FormatMessage(IDS_BIND_FAIL_AT_SINGLE_NDAS_FMT, (*itUnitDevice)->GetName()); } } else strMsg.LoadString(IDS_BIND_FAIL); break; default: strMsg.LoadString(IDS_BIND_FAIL); break; } ShowErrorMessageBox(IDS_MAINFRAME_SINGLE_ACCESS_FAIL); } for(NBUnitDevicePtrList::iterator itUnitDevice = listUnitDevices.begin(); itUnitDevice != listUnitDevices.end(); i++, itUnitDevice++) { (*itUnitDevice)->HixChangeNotify(pGetNdasHostGuid()); } delete [] ci; OnRefreshStatus(NULL, NULL, NULL); return; }
void CMainFrame::OnSingle(UINT wNotifyCode, int wID, HWND hwndCtl) { CString strMsg; CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBUnitDevice *pUnitDevice; if(dynamic_cast<CNBLogicalDevice *>(pDevice)) { CNBLogicalDevice *pLogicalDevice = dynamic_cast<CNBLogicalDevice *>(pDevice); if(!pLogicalDevice || !pLogicalDevice->IsOperatableAll()) return; pUnitDevice = (*pLogicalDevice)[0]; } else { pUnitDevice = dynamic_cast<CNBUnitDevice *>(pDevice); if(!pUnitDevice || !pUnitDevice->IsOperatable()) return; } if(!pUnitDevice) return; NBUnitDevicePtrList listUnitDevices; listUnitDevices.push_back(pUnitDevice); CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_SINGLE_DLG_CAPTION, IDS_SINGLE_DLG_MESSAGE, listUnitDevices, 0, NULL, NULL); if(dlgSelectDevice.DoModal() != IDOK) return; NDASCOMM_CONNECTION_INFO ConnectionInfo; if(!pUnitDevice->InitConnectionInfo(&ConnectionInfo, TRUE)) { // "%1!s! does not have a write access privilege. You need to set write key to this NDAS device before this action." strMsg.FormatMessage(IDS_ERROR_NOT_REGISTERD_WRITE_FMT, pUnitDevice->GetName() ); CString strTitle; strTitle.LoadString(IDS_APPLICATION); MessageBox( strMsg, strTitle, MB_OK|MB_ICONERROR ); return; } AutoCursor l_auto_cursor(IDC_WAIT); UINT32 BindResult = NdasOpBind( 1, &ConnectionInfo, NMT_SINGLE, 0); l_auto_cursor.Release(); if(1 != BindResult) { DWORD dwLastError = ::GetLastError(); switch(dwLastError) { case NDASCOMM_ERROR_RW_USER_EXIST: case NDASOP_ERROR_ALREADY_USED: case NDASOP_ERROR_DEVICE_FAIL: case NDASOP_ERROR_NOT_SINGLE_DISK: case NDASOP_ERROR_DEVICE_UNSUPPORTED: case NDASOP_ERROR_NOT_BOUND_DISK: // does not return this error strMsg.FormatMessage(IDS_BIND_FAIL_AT_SINGLE_NDAS_FMT, pUnitDevice->GetName()); break; default: strMsg.LoadString(IDS_BIND_FAIL); break; } ShowErrorMessageBox(strMsg); } pUnitDevice->HixChangeNotify(pGetNdasHostGuid()); OnRefreshStatus(NULL, NULL, NULL); }
void CMainFrame::OnMigrate(UINT wNotifyCode, int wID, HWND hwndCtl) { CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBLogicalDevice *pLogicalDevice = dynamic_cast<CNBLogicalDevice *>(pDevice); if(!pLogicalDevice) return; if (NMT_MIRROR != pLogicalDevice->GetType() && NMT_RAID1 != pLogicalDevice->GetType() && NMT_RAID4 != pLogicalDevice->GetType()) return; // warning message CString strMsg; NBUnitDevicePtrList listUnitDevices = pLogicalDevice->GetOperatableDevices(); CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_MIGRATE_DLG_CAPTION, IDS_MIGRATE_DLG_MESSAGE, listUnitDevices, 0, NULL, NULL); if(dlgSelectDevice.DoModal() != IDOK) return; NDASCOMM_CONNECTION_INFO *ci = new NDASCOMM_CONNECTION_INFO[listUnitDevices.size()]; UINT32 i = 0; for(NBUnitDevicePtrList::iterator itUnitDevice = listUnitDevices.begin(); itUnitDevice != listUnitDevices.end(); i++, itUnitDevice++) { (*itUnitDevice)->InitConnectionInfo(&ci[i], TRUE); } AutoCursor l_auto_cursor(IDC_WAIT); BOOL bResult = NdasOpMigrate(&ci[0]); l_auto_cursor.Release(); DWORD dwLastError = ::GetLastError(); if(!bResult) { ShowErrorMessageBox(IDS_MAINFRAME_SINGLE_ACCESS_FAIL); } for(NBUnitDevicePtrList::iterator itUnitDevice = listUnitDevices.begin(); itUnitDevice != listUnitDevices.end(); i++, itUnitDevice++) { (*itUnitDevice)->HixChangeNotify(pGetNdasHostGuid()); } delete [] ci; OnRefreshStatus(NULL, NULL, NULL); return; }
void CMainFrame::OnAddMirror(UINT wNotifyCode, int wID, HWND hwndCtl) { CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBLogicalDevice *pLogicalDevice = dynamic_cast<CNBLogicalDevice *>(pDevice); if(!pLogicalDevice || pLogicalDevice->IsGroup()) return; NBUnitDevicePtrList listUnitDevices = GetOperatableSingleDevices(); // remove self listUnitDevices.remove((*pLogicalDevice)[0]); CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_MIRROR_ADD_DLG_CAPTION, IDS_MIRROR_ADD_DLG_MESSAGE, listUnitDevices, 1, CheckCapacityForMirror, pLogicalDevice); if(dlgSelectDevice.DoModal() != IDOK) return; CNBUnitDevice *pUnitDeviceAdd = dlgSelectDevice.GetSelectedDevice(); CNBUnitDevice *pUnitDevice = pUnitDevice = (*pLogicalDevice)[0]; // Bind & Synchronize NDASCOMM_CONNECTION_INFO ConnectionInfo[2]; pUnitDevice->InitConnectionInfo(&ConnectionInfo[0], TRUE); pUnitDeviceAdd->InitConnectionInfo(&ConnectionInfo[1], TRUE); AutoCursor l_auto_cursor(IDC_WAIT); UINT32 BindResult = NdasOpBind( 2, ConnectionInfo, NMT_SAFE_RAID1, 0); l_auto_cursor.Release(); if(2 != BindResult) { CString strMsg; DWORD dwLastError = ::GetLastError(); switch(dwLastError) { case NDASCOMM_ERROR_RW_USER_EXIST: case NDASOP_ERROR_ALREADY_USED: case NDASOP_ERROR_DEVICE_FAIL: case NDASOP_ERROR_NOT_SINGLE_DISK: case NDASOP_ERROR_DEVICE_UNSUPPORTED: strMsg.FormatMessage(IDS_BIND_FAIL_AT_SINGLE_NDAS_FMT, (BindResult == 0) ? pUnitDevice->GetName() : pUnitDeviceAdd->GetName()); break; default: strMsg.LoadString(IDS_BIND_FAIL); break; } ShowErrorMessageBox(strMsg); return; } pUnitDevice->HixChangeNotify(pGetNdasHostGuid()); pUnitDeviceAdd->HixChangeNotify(pGetNdasHostGuid()); /* CRecoverDlg dlgRecover(FALSE, IDS_LOGDEV_TYPE_DISK_RAID1, IDS_RECOVERDLG_TASK_ADD_MIRROR); ATLASSERT(FALSE); // dlgRecover.SetMemberDevice(pUnitDeviceAdd); dlgRecover.DoModal(); */ OnRefreshStatus(NULL, NULL, NULL); }
void CMainFrame::OnReplaceUnitDevice(UINT wNotifyCode, int wID, HWND hwndCtl) { CNBDevice *pDevice = m_viewTreeList.GetSelectedDevice(); if(!pDevice) return; if(!pDevice->GetCommandAbility(wID)) return; CNBLogicalDevice *pLogicalDevice = dynamic_cast<CNBLogicalDevice *>(pDevice); if(!pLogicalDevice) return; // find the missing device CNBLogicalDevice *pLogicalDeviceReplace = NULL; CNBUnitDevice *pUnitDeviceReplace = NULL; NBUnitDevicePtrList listUnitDevicesReplace; NBLogicalDevicePtrList::iterator itLogicalDevice; for(UINT32 i = 0; i < pLogicalDevice->DevicesTotal(); i++) { if(!(*pLogicalDevice)[i]) { for(itLogicalDevice = m_listLogicalDevices.begin(); itLogicalDevice != m_listLogicalDevices.end(); ++itLogicalDevice) { pLogicalDeviceReplace = *itLogicalDevice; if(pLogicalDeviceReplace) { if (pLogicalDeviceReplace->IsHDD() && !pLogicalDeviceReplace->IsGroup() && pLogicalDeviceReplace->IsOperatable()) { pUnitDeviceReplace = (*pLogicalDeviceReplace)[0]; if (pUnitDeviceReplace->IsThis( pLogicalDevice->DIB()->UnitDisks[i].MACAddr, pLogicalDevice->DIB()->UnitDisks[i].UnitNumber)) { // ok we found replacable HDD listUnitDevicesReplace.push_back(pUnitDeviceReplace); } } } } } } if(!listUnitDevicesReplace.size()) return; CNBSelectDeviceDlg dlgSelectDevice( IDD_DEVICE_LIST, IDS_REPLACE_UNIT_DEVICE_DLG_CAPTION, IDS_REPLACE_UNIT_DEVICE_DLG_MESSAGE, listUnitDevicesReplace, 0, CheckCapacityForSpare, pLogicalDevice); if(dlgSelectDevice.DoModal() != IDOK) return; // dlgSelectDevice is not selective dialog. get unit device from listUnitDevicesReplace CNBUnitDevice *pUnitDevice = *(listUnitDevicesReplace.begin()); // Bind & Synchronize NDASCOMM_CONNECTION_INFO ci, ci_replace; pLogicalDevice->InitConnectionInfo(&ci, TRUE); // use write access. this function does not support run time replace yet. pUnitDevice->InitConnectionInfo(&ci_replace, TRUE); for(UINT32 i = 0; i < pLogicalDevice->DevicesTotal(); i++) { if (!(*pLogicalDevice)[i]) { break; } } if(pLogicalDevice->DevicesTotal() == i) { // failed to find missing device return; } AutoCursor l_auto_cursor(IDC_WAIT); BOOL bResults = NdasOpReplaceUnitDevice( &ci, &ci_replace, i); l_auto_cursor.Release(); pLogicalDevice->HixChangeNotify(pGetNdasHostGuid()); pUnitDevice->HixChangeNotify(pGetNdasHostGuid()); if(!bResults) { CString strMsg; DWORD dwLastError = ::GetLastError(); strMsg.LoadString(IDS_OPERATION_FAIL); ShowErrorMessageBox(strMsg); return; } OnRefreshStatus(NULL, NULL, NULL); }
// 0 to automatically advance to the next page // -1 to prevent the page from changing INT CSelectDiskPage::OnWizardNext() { ATLASSERT( m_wndListBind.GetItemCount() == (int)m_pWizData->m_nDiskCount); ATLASSERT( NMT_AGGREGATE == m_pWizData->m_nBindType || NMT_RAID0 == m_pWizData->m_nBindType || NMT_RAID1 == m_pWizData->m_nBindType || NMT_RAID4 == m_pWizData->m_nBindType); NBUnitDevicePtrList listBind; unsigned int i; UINT32 BindResult; WTL::CString strMsg; // warning message { WTL::CString strTitle; strTitle.LoadString(IDS_APPLICATION); strMsg.LoadString(IDS_WARNING_BIND); int id = MessageBox( strMsg, strTitle, MB_YESNO|MB_ICONEXCLAMATION ); if(IDYES != id) return -1; } m_pWizData->listUnitDevicesBind = m_wndListBind.GetDiskObjectList(); NDASCOMM_CONNECTION_INFO *pConnectionInfo; pConnectionInfo = new NDASCOMM_CONNECTION_INFO[m_pWizData->m_nDiskCount]; ZeroMemory(pConnectionInfo, sizeof(NDASCOMM_CONNECTION_INFO) * m_pWizData->m_nDiskCount); listBind = m_wndListBind.GetDiskObjectList(); WTL::CString strTitle; CNBUnitDevice *UnitDiskObject; NBUnitDevicePtrList::const_iterator itr; for (i = 0, itr = listBind.begin(); itr != listBind.end(); ++itr, i++ ) { UnitDiskObject = *itr; if(!UnitDiskObject->InitConnectionInfo(&pConnectionInfo[i], TRUE)) // if(!((*itr)->GetAccessMask() & GENERIC_WRITE)) { // "%1!s! does not have a write access privilege. You need to set write key to this NDAS device before this action." strMsg.FormatMessage(IDS_ERROR_NOT_REGISTERD_WRITE_FMT, (*itr)->GetName() ); strTitle.LoadString(IDS_APPLICATION); MessageBox( strMsg, strTitle, MB_OK|MB_ICONERROR ); delete [] pConnectionInfo; return -1; } } m_pWizData->m_BindResult = NdasOpBind( m_pWizData->m_nDiskCount, pConnectionInfo, m_pWizData->m_nBindType); if(m_pWizData->m_BindResult != m_pWizData->m_nDiskCount) // error m_pWizData->dwBindLastError = ::GetLastError(); CNdasHIXChangeNotify HixChangeNotify(pGetNdasHostGuid()); BOOL bResults = HixChangeNotify.Initialize(); if(bResults) { for (i = 0; i < m_pWizData->m_nDiskCount; i++ ) { NDAS_UNITDEVICE_ID unitDeviceId; CopyMemory(unitDeviceId.DeviceId.Node, pConnectionInfo[i].AddressLPX, sizeof(unitDeviceId.DeviceId.Node)); unitDeviceId.UnitNo = pConnectionInfo[i].UnitNo; HixChangeNotify.Notify(unitDeviceId); } } delete [] pConnectionInfo; return 0; }
// 0 to automatically advance to the next page // -1 to prevent the page from changing INT CSelectDiskPage::OnWizardNext() { ATLASSERT( m_wndListBind.GetItemCount() == (int)m_pWizData->m_nDiskCount); ATLASSERT( NMT_AGGREGATE == m_pWizData->m_nBindType || NMT_RAID0 == m_pWizData->m_nBindType || NMT_RAID1R3 == m_pWizData->m_nBindType || NMT_RAID4R3 == m_pWizData->m_nBindType || NMT_RAID5 == m_pWizData->m_nBindType ); NBUnitDevicePtrList listBind; unsigned int i; CString strMsg; // Warning message if disk is over 2T. { UINT64 nSize = pGetBoundDiskSize( m_pWizData->m_nBindType, m_pWizData->m_nDiskCount, m_wndListBind.GetDiskObjectList()); if (nSize >= 2LL * 1024 * 1024 * 1024 * 1024) { // 2 Tera. CString strTitle; strTitle.LoadString(IDS_APPLICATION); strMsg.LoadString(IDS_WARNING_BIND_SIZE); int id = MessageBox( strMsg, strTitle, MB_YESNO|MB_ICONEXCLAMATION ); if(IDYES != id) return -1; } } // warning message { CString strTitle; strTitle.LoadString(IDS_APPLICATION); strMsg.LoadString(IDS_WARNING_BIND); int id = MessageBox( strMsg, strTitle, MB_YESNO|MB_ICONEXCLAMATION ); if(IDYES != id) return -1; } m_pWizData->listUnitDevicesBind = m_wndListBind.GetDiskObjectList(); NDASCOMM_CONNECTION_INFO *pConnectionInfo; pConnectionInfo = new NDASCOMM_CONNECTION_INFO[m_pWizData->m_nDiskCount]; ZeroMemory(pConnectionInfo, sizeof(NDASCOMM_CONNECTION_INFO) * m_pWizData->m_nDiskCount); listBind = m_wndListBind.GetDiskObjectList(); CString strTitle; CNBUnitDevice *UnitDiskObject; NBUnitDevicePtrList::const_iterator itr; for (i = 0, itr = listBind.begin(); itr != listBind.end(); ++itr, i++ ) { UnitDiskObject = *itr; if(!UnitDiskObject->InitConnectionInfo(&pConnectionInfo[i], TRUE)) // if(!((*itr)->GetAccessMask() & GENERIC_WRITE)) { // "%1!s! does not have a write access privilege. You need to set write key to this NDAS device before this action." strMsg.FormatMessage(IDS_ERROR_NOT_REGISTERD_WRITE_FMT, (*itr)->GetName() ); strTitle.LoadString(IDS_APPLICATION); MessageBox( strMsg, strTitle, MB_OK|MB_ICONERROR); delete [] pConnectionInfo; return -1; } } DWORD dwUserSpace = 0; if(!pGetAppConfigValue(_T("UserSpace"), &dwUserSpace)) { dwUserSpace = 0; } AutoCursor l_auto_cursor(IDC_WAIT); m_pWizData->m_BindResult = NdasOpBind( m_pWizData->m_nDiskCount, pConnectionInfo, m_pWizData->m_nBindType, dwUserSpace); l_auto_cursor.Release(); if(m_pWizData->m_BindResult != m_pWizData->m_nDiskCount) // error m_pWizData->dwBindLastError = ::GetLastError(); LPCGUID hostGuid = pGetNdasHostGuid(); for (i = 0; i < m_pWizData->m_nDiskCount; i++ ) { BOOL success = NdasCommNotifyUnitDeviceChange( NDAS_DIC_NDAS_ID, pConnectionInfo[i].Address.NdasId.Id, pConnectionInfo[i].UnitNo, hostGuid); if (!success) { ATLTRACE("NdasCommNotifyUnitDeviceChange failed, error=0x%X\n", GetLastError()); } } delete [] pConnectionInfo; return 0; }