Index: src/ch/CustomCopyDlg.cpp =================================================================== diff -u -rd5c3edd0d167db9b5d47d04248820fda49499a5e -r2e4eacb299f21d06196fe13140b4b0d095abdca9 --- src/ch/CustomCopyDlg.cpp (.../CustomCopyDlg.cpp) (revision d5c3edd0d167db9b5d47d04248820fda49499a5e) +++ src/ch/CustomCopyDlg.cpp (.../CustomCopyDlg.cpp) (revision 2e4eacb299f21d06196fe13140b4b0d095abdca9) @@ -17,6 +17,7 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #include "stdafx.h" +#include #include "resource.h" #include "CustomCopyDlg.h" #include "structs.h" @@ -25,6 +26,9 @@ #include "FilterDlg.h" #include "StringHelpers.h" #include "ch.h" +#include "CfgProperties.h" +#include "../libchengine/TTaskDefinition.h" +#include "../libchengine/TTaskConfigBufferSizes.h" #ifdef _DEBUG #define new DEBUG_NEW @@ -36,47 +40,28 @@ // CCustomCopyDlg dialog -CCustomCopyDlg::CCustomCopyDlg() :ictranslate::CLanguageDialog(CCustomCopyDlg::IDD) +CCustomCopyDlg::CCustomCopyDlg() : + ictranslate::CLanguageDialog(IDD_CUSTOM_COPY_DIALOG) { - //{{AFX_DATA_INIT(CCustomCopyDlg) - m_ucCount = 1; - m_bOnlyCreate = FALSE; - m_bIgnoreFolders = FALSE; - m_bFilters = FALSE; - m_bAdvanced = FALSE; - m_bForceDirectories = FALSE; - //}}AFX_DATA_INIT - -// m_ccData.m_astrPaths.RemoveAll(); // unneeded -// m_ccData.m_strDestPath.Empty(); - - m_ccData.m_iOperation=0; - m_ccData.m_iPriority=THREAD_PRIORITY_NORMAL; - m_ccData.m_ucCount=1; + GetConfig().ExtractSubConfig(BRANCH_TASK_SETTINGS, m_tTaskDefinition.GetConfiguration()); +} - // m_ccData.m_bsSizes stays uninitialized - // m_ccData.m_afFilters - this too - - m_ccData.m_bIgnoreFolders=false; - m_ccData.m_bForceDirectories=false; - m_ccData.m_bCreateStructure=false; - - m_bActualisation=false; +CCustomCopyDlg::CCustomCopyDlg(const chengine::TTaskDefinition& rTaskDefinition) : + ictranslate::CLanguageDialog(IDD_CUSTOM_COPY_DIALOG), + m_tTaskDefinition(rTaskDefinition) +{ } void CCustomCopyDlg::DoDataExchange(CDataExchange* pDX) { CLanguageDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CCustomCopyDlg) DDX_Control(pDX, IDC_DESTPATH_COMBOBOXEX, m_ctlDstPath); - DDX_Control(pDX, IDC_COUNT_SPIN, m_ctlCountSpin); DDX_Control(pDX, IDC_FILTERS_LIST, m_ctlFilters); DDX_Control(pDX, IDC_BUFFERSIZES_LIST, m_ctlBufferSizes); DDX_Control(pDX, IDC_OPERATION_COMBO, m_ctlOperation); DDX_Control(pDX, IDC_PRIORITY_COMBO, m_ctlPriority); DDX_Control(pDX, IDC_FILES_LIST, m_ctlFiles); - DDX_Text(pDX, IDC_COUNT_EDIT, m_ucCount); - DDV_MinMaxByte(pDX, m_ucCount, 1, 255); DDX_Check(pDX, IDC_ONLYSTRUCTURE_CHECK, m_bOnlyCreate); DDX_Check(pDX, IDC_IGNOREFOLDERS_CHECK, m_bIgnoreFolders); DDX_Check(pDX, IDC_FORCEDIRECTORIES_CHECK, m_bForceDirectories); @@ -85,7 +70,6 @@ //}}AFX_DATA_MAP } - BEGIN_MESSAGE_MAP(CCustomCopyDlg,ictranslate::CLanguageDialog) //{{AFX_MSG_MAP(CCustomCopyDlg) ON_BN_CLICKED(IDC_ADDDIR_BUTTON, OnAddDirectoryButton) @@ -105,6 +89,8 @@ ON_BN_CLICKED(IDC_IMPORT_BUTTON, OnImportButton) ON_BN_CLICKED(IDC_IGNOREFOLDERS_CHECK, OnIgnorefoldersCheck) ON_BN_CLICKED(IDC_FORCEDIRECTORIES_CHECK, OnForcedirectoriesCheck) + ON_BN_CLICKED(IDC_EXPORT_BUTTON, OnExportButtonClicked) + ON_WM_SIZE() //}}AFX_MSG_MAP END_MESSAGE_MAP() @@ -114,12 +100,62 @@ { CLanguageDialog::OnInitDialog(); + // set dialog icon + HICON hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); + SetIcon(hIcon, FALSE); + + AddResizableControl(IDC_001_STATIC, 0.0, 0.0, 1.0, 0.0); + AddResizableControl(IDC_FILES_LIST, 0.0, 0.0, 1.0, 0.5); + AddResizableControl(IDC_ADDFILE_BUTTON, 1.0, 0.0, 0.0, 0.0); + AddResizableControl(IDC_ADDDIR_BUTTON, 1.0, 0.0, 0.0, 0.0); + AddResizableControl(IDC_REMOVEFILEFOLDER_BUTTON, 1.0, 0.0, 0.0, 0.0); + AddResizableControl(IDC_IMPORT_BUTTON, 1.0, 0.0, 0.0, 0.0); + + AddResizableControl(IDC_002_STATIC, 0.0, 0.5, 1.0, 0.0); + AddResizableControl(IDC_DESTPATH_COMBOBOXEX, 0.0, 0.5, 1.0, 0.0); + AddResizableControl(IDC_DESTBROWSE_BUTTON, 1.0, 0.5, 0.0, 0.0); + + AddResizableControl(IDC_BAR1_STATIC, 0.0, 0.5, 0.5, 0.0); + AddResizableControl(IDC_007_STATIC, 0.5, 0.5, 0.0, 0.0); + AddResizableControl(IDC_BAR2_STATIC, 0.5, 0.5, 0.5, 0.0); + + AddResizableControl(IDC_003_STATIC, 0.0, 0.5, 0.5, 0.0); + AddResizableControl(IDC_004_STATIC, 0.5, 0.5, 0.5, 0.0); + + AddResizableControl(IDC_OPERATION_COMBO, 0.0, 0.5, 0.5, 0.0); + AddResizableControl(IDC_PRIORITY_COMBO, 0.5, 0.5, 0.5, 0.0); + + AddResizableControl(IDC_006_STATIC, 0.0, 0.5, 1.0, 0.0); + AddResizableControl(IDC_BUFFERSIZES_LIST, 0.0, 0.5, 1.0, 0.0); + AddResizableControl(IDC_BUFFERSIZES_BUTTON, 1.0, 0.5, 0.0, 0.0); + + AddResizableControl(IDC_FILTERS_CHECK, 0.0, 0.5, 0.0, 0.0); + AddResizableControl(IDC_BAR3_STATIC, 0.0, 0.5, 1.0, 0.0); + AddResizableControl(IDC_FILTERS_LIST, 0.0, 0.5, 1.0, 0.5); + AddResizableControl(IDC_ADDFILTER_BUTTON, 1.0, 0.5, 0.0, 0.0); + AddResizableControl(IDC_REMOVEFILTER_BUTTON, 1.0, 0.5, 0.0, 0.0); + + AddResizableControl(IDC_ADVANCED_CHECK, 0.0, 1.0, 0.0, 0.0); + AddResizableControl(IDC_BAR4_STATIC, 0.0, 1.0, 1.0, 0.0); + + AddResizableControl(IDC_IGNOREFOLDERS_CHECK, 0.0, 1.0, 1.0, 0.0); + AddResizableControl(IDC_ONLYSTRUCTURE_CHECK, 0.0, 1.0, 1.0, 0.0); + AddResizableControl(IDC_FORCEDIRECTORIES_CHECK, 0.0, 1.0, 1.0, 0.0); + + AddResizableControl(IDC_BAR5_STATIC, 0.0, 1.0, 1.0, 0.0); + AddResizableControl(IDOK, 1.0, 1.0, 0.0, 0.0); + AddResizableControl(IDCANCEL, 1.0, 1.0, 0.0, 0.0); + AddResizableControl(IDC_HELP_BUTTON, 1.0, 1.0, 0.0, 0.0); + AddResizableControl(IDC_EXPORT_BUTTON, 0.0, 1.0, 0.0, 0.0); + + InitializeResizableControls(); + // make this dialog on top SetWindowPos(&wndNoTopMost, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE /*| SWP_SHOWWINDOW*/); // paths' listbox - init images - system image list - SHFILEINFO sfi; - HIMAGELIST hImageList = (HIMAGELIST)SHGetFileInfo(_T("C:\\"), FILE_ATTRIBUTE_NORMAL, &sfi, sizeof(SHFILEINFO), + SHFILEINFO sfi; + HIMAGELIST hImageList = (HIMAGELIST)SHGetFileInfo(_T("C:\\"), FILE_ATTRIBUTE_NORMAL, &sfi, sizeof(SHFILEINFO), SHGFI_SYSICONINDEX | SHGFI_SMALLICON); m_ilImages.Attach(hImageList); @@ -131,8 +167,7 @@ rc.right-=GetSystemMetrics(SM_CXEDGE)*2; // some styles - m_ctlFiles.SetExtendedStyle(m_ctlFiles.GetExtendedStyle() | LVS_EX_FULLROWSELECT); - m_ctlFilters.SetExtendedStyle(m_ctlFiles.GetExtendedStyle() | LVS_EX_FULLROWSELECT); + m_ctlFilters.SetExtendedStyle(m_ctlFilters.GetExtendedStyle() | LVS_EX_FULLROWSELECT); // paths' listbox - add one column LVCOLUMN lvc; @@ -142,8 +177,10 @@ m_ctlFiles.InsertColumn(1, &lvc); // fill paths' listbox - for (int i=0;iLoadString(IDS_CCDCOPY_STRING)); - m_ctlOperation.AddString(GetResManager()->LoadString(IDS_CCDMOVE_STRING)); + m_ctlOperation.AddString(GetResManager().LoadString(IDS_CCDCOPY_STRING)); + m_ctlOperation.AddString(GetResManager().LoadString(IDS_CCDMOVE_STRING)); // copying/moving - m_ctlOperation.SetCurSel(m_ccData.m_iOperation); + m_ctlOperation.SetCurSel(m_tTaskDefinition.GetOperationType() == chengine::eOperation_Move ? 1 : 0); // fill priority combo - for (int i=0;i<7;i++) + for (int stIndex=0;stIndex<7;stIndex++) { - m_ctlPriority.AddString(GetResManager()->LoadString(IDS_PRIORITY0_STRING+i)); + m_ctlPriority.AddString(GetResManager().LoadString(IDS_PRIORITY0_STRING+stIndex)); } - m_ctlPriority.SetCurSel(PriorityToIndex(m_ccData.m_iPriority)); + m_ctlPriority.SetCurSel(PriorityToIndex(chengine::GetTaskPropValue(m_tTaskDefinition.GetConfiguration()))); - // count of copies - m_ucCount=m_ccData.m_ucCount; - m_ctlCountSpin.SetRange(1, 255); - // fill buffer sizes listbox SetBuffersizesString(); // list width m_ctlFilters.GetWindowRect(&rc); - rc.right-=GetSystemMetrics(SM_CXEDGE)*2; + rc.right -= GetSystemMetrics(SM_CXEDGE)*2; // filter - some columns in a header lvc.mask=LVCF_FMT | LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvc.fmt=LVCFMT_LEFT; // mask lvc.iSubItem=-1; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRMASK_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRMASK_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.15*rc.Width()); m_ctlFilters.InsertColumn(1, &lvc); // exclude mask lvc.iSubItem=0; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDREXCLUDEMASK_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDREXCLUDEMASK_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.15*rc.Width()); m_ctlFilters.InsertColumn(2, &lvc); // size lvc.iSubItem=1; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRSIZE_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRSIZE_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.3*rc.Width()); m_ctlFilters.InsertColumn(3, &lvc); // time lvc.iSubItem=2; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRDATE_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRDATE_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.3*rc.Width()); m_ctlFilters.InsertColumn(4, &lvc); // attributes lvc.iSubItem=3; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRATTRIB_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRATTRIB_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.1*rc.Width()); m_ctlFilters.InsertColumn(5, &lvc); // -attributes lvc.iSubItem=4; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDREXCLUDEATTRIB_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDREXCLUDEATTRIB_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.1*rc.Width()); m_ctlFilters.InsertColumn(6, &lvc); - - m_bFilters = !m_ccData.m_afFilters.IsEmpty(); + m_bFilters = !m_tTaskDefinition.GetFilters().IsEmpty(); + // other custom flags - m_bAdvanced=(m_ccData.m_bIgnoreFolders | m_ccData.m_bCreateStructure); - m_bIgnoreFolders=m_ccData.m_bIgnoreFolders; - m_bForceDirectories=m_ccData.m_bForceDirectories; - m_bOnlyCreate=m_ccData.m_bCreateStructure; + m_bIgnoreFolders = chengine::GetTaskPropValue(m_tTaskDefinition.GetConfiguration()); + m_bForceDirectories = chengine::GetTaskPropValue(m_tTaskDefinition.GetConfiguration()); + m_bOnlyCreate = chengine::GetTaskPropValue(m_tTaskDefinition.GetConfiguration()); + m_bAdvanced = (m_bIgnoreFolders | m_bForceDirectories | m_bOnlyCreate); UpdateData(FALSE); @@ -262,29 +294,21 @@ UpdateData(TRUE); // count the width of a list - CRect rc; - m_ctlFiles.GetWindowRect(&rc); - rc.right-=GetSystemMetrics(SM_CXEDGE)*2; + UpdateFilesListCtrlHeaderWidth(); - // change the width of a column - LVCOLUMN lvc; - lvc.mask=LVCF_WIDTH; - lvc.cx=rc.Width(); - m_ctlFiles.SetColumn(0, &lvc); - // operation int iPos=m_ctlOperation.GetCurSel(); m_ctlOperation.ResetContent(); - m_ctlOperation.AddString(GetResManager()->LoadString(IDS_CCDCOPY_STRING)); - m_ctlOperation.AddString(GetResManager()->LoadString(IDS_CCDMOVE_STRING)); + m_ctlOperation.AddString(GetResManager().LoadString(IDS_CCDCOPY_STRING)); + m_ctlOperation.AddString(GetResManager().LoadString(IDS_CCDMOVE_STRING)); m_ctlOperation.SetCurSel(iPos); // priority combo iPos=m_ctlPriority.GetCurSel(); m_ctlPriority.ResetContent(); for (int i=0;i<7;i++) { - m_ctlPriority.AddString(GetResManager()->LoadString(IDS_PRIORITY0_STRING+i)); + m_ctlPriority.AddString(GetResManager().LoadString(IDS_PRIORITY0_STRING+i)); } m_ctlPriority.SetCurSel(iPos); @@ -294,95 +318,101 @@ // filter section (filter, size, date, attributes) while(m_ctlFilters.DeleteColumn(0)); // delete all columns + CRect rc; + m_ctlFilters.GetWindowRect(&rc); + rc.right -= GetSystemMetrics(SM_CXEDGE) * 2; + + LVCOLUMN lvc; lvc.mask=LVCF_FMT | LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvc.fmt=LVCFMT_LEFT; // mask lvc.iSubItem=-1; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRMASK_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRMASK_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.15*rc.Width()); m_ctlFilters.InsertColumn(1, &lvc); // exclude mask lvc.iSubItem=0; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDREXCLUDEMASK_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDREXCLUDEMASK_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.15*rc.Width()); m_ctlFilters.InsertColumn(2, &lvc); // size lvc.iSubItem=1; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRSIZE_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRSIZE_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.3*rc.Width()); m_ctlFilters.InsertColumn(3, &lvc); // time lvc.iSubItem=2; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRDATE_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRDATE_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.3*rc.Width()); m_ctlFilters.InsertColumn(4, &lvc); // attributes lvc.iSubItem=3; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDRATTRIB_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDRATTRIB_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.1*rc.Width()); m_ctlFilters.InsertColumn(5, &lvc); // -attributes lvc.iSubItem=4; - lvc.pszText=(PTSTR)GetResManager()->LoadString(IDS_HDREXCLUDEATTRIB_STRING); + lvc.pszText=(PTSTR)GetResManager().LoadString(IDS_HDREXCLUDEATTRIB_STRING); lvc.cchTextMax=lstrlen(lvc.pszText); lvc.cx=static_cast(0.1*rc.Width()); m_ctlFilters.InsertColumn(6, &lvc); // refresh the entries in filters' list + const chengine::TFileFiltersArray& afFilters = m_tTaskDefinition.GetFilters(); m_ctlFilters.DeleteAllItems(); - for (size_t i=0;i(stIndex)); } } void CCustomCopyDlg::OnAddDirectoryButton() { CString strPath; - if (BrowseForFolder(GetResManager()->LoadString(IDS_BROWSE_STRING), &strPath)) + if (BrowseForFolder(GetResManager().LoadString(IDS_BROWSE_STRING), &strPath)) AddPath(strPath); } void CCustomCopyDlg::OnAddFilesButton() { - CFileDialog dlg(TRUE, NULL, NULL, OFN_ALLOWMULTISELECT | OFN_ENABLESIZING | OFN_EXPLORER | OFN_FILEMUSTEXIST | OFN_NODEREFERENCELINKS | OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, GetResManager()->LoadString(IDS_FILEDLGALLFILTER_STRING), this); + CFileDialog dlg(TRUE, nullptr, nullptr, OFN_ALLOWMULTISELECT | OFN_ENABLESIZING | OFN_EXPLORER | OFN_FILEMUSTEXIST | OFN_NODEREFERENCELINKS | OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, GetResManager().LoadString(IDS_FILEDLGALLFILTER_STRING), this); - TCHAR *pszBuffer=new TCHAR[65535]; + TCHAR *pszBuffer = new TCHAR[65535]; memset(pszBuffer, 0, 65535*sizeof(TCHAR)); dlg.m_ofn.lpstrFile=pszBuffer; dlg.m_ofn.nMaxFile=65535; - if (dlg.DoModal() == IDOK) + if(dlg.DoModal() == IDOK) { + pszBuffer[65534] = _T('\0'); // first element is the path CString strPath=pszBuffer; - int iOffset=_tcslen(pszBuffer)+1; + size_t stOffset = _tcslen(pszBuffer) + 1; // get filenames - if (pszBuffer[iOffset] == _T('\0')) + if(pszBuffer[stOffset] == _T('\0')) AddPath(strPath); else { - if (strPath.Right(1) != _T("\\")) - strPath+=_T("\\"); - while (pszBuffer[iOffset] != _T('\0')) + if(strPath.Right(1) != _T("\\")) + strPath += _T("\\"); + while(pszBuffer[stOffset] != _T('\0')) { - AddPath(strPath+CString(pszBuffer+iOffset)); - iOffset+=_tcslen(pszBuffer+iOffset)+1; + AddPath(strPath + CString(pszBuffer + stOffset)); + stOffset += _tcslen(pszBuffer + stOffset) + 1; } } } @@ -393,66 +423,39 @@ void CCustomCopyDlg::OnRemoveButton() { - POSITION pos; - int iItem; while (true) { - pos = m_ctlFiles.GetFirstSelectedItemPosition(); - if (pos == NULL) + POSITION pos = m_ctlFiles.GetFirstSelectedItemPosition(); + if (pos == nullptr) break; - else - { - iItem=m_ctlFiles.GetNextSelectedItem(pos); - m_ctlFiles.DeleteItem(iItem); - } + + int iItem = m_ctlFiles.GetNextSelectedItem(pos); + m_ctlFiles.DeleteItem(iItem); } } void CCustomCopyDlg::OnBrowseButton() { CString strPath; - if (BrowseForFolder(GetResManager()->LoadString(IDS_DSTFOLDERBROWSE_STRING), &strPath)) + if (BrowseForFolder(GetResManager().LoadString(IDS_DSTFOLDERBROWSE_STRING), &strPath)) { - SetComboPath(strPath); -// m_strDest=strPath; //** + m_ctlDstPath.SetPath(strPath); } } void CCustomCopyDlg::OnOK() { UpdateData(TRUE); - // copy files from listctrl to an array - m_ccData.m_astrPaths.RemoveAll(); - CString strPath; + if(!HasBasicTaskData()) + { + MsgBox(IDS_MISSINGDATA_STRING); + return; + } - for (int i=0;iLoadString(IDS_BSEDEFAULT_STRING)); - fmt.SetParam(_t("%size"), GetSizeString(m_ccData.m_bsSizes.m_uiDefaultSize, szSize, 64, true)); - m_ctlBufferSizes.AddString(fmt); + chengine::TBufferSizes bsSizes = GetTaskPropBufferSizes(m_tTaskDefinition.GetConfiguration()); + + fmt.SetFormat(GetResManager().LoadString(IDS_BSEDEFAULT_STRING)); + fmt.SetParam(_T("%size"), GetSizeString(bsSizes.GetDefaultSize(), true)); + m_ctlBufferSizes.AddString(fmt.ToString()); - if (!m_ccData.m_bsSizes.m_bOnlyDefault) + if (!bsSizes.IsOnlyDefault()) { - fmt.SetFormat(GetResManager()->LoadString(IDS_BSEONEDISK_STRING)); - fmt.SetParam(_t("%size"), GetSizeString(m_ccData.m_bsSizes.m_uiOneDiskSize, szSize, 64, true)); - m_ctlBufferSizes.AddString(fmt); + fmt.SetFormat(GetResManager().LoadString(IDS_BSEONEDISK_STRING)); + fmt.SetParam(_T("%size"), GetSizeString(bsSizes.GetOneDiskSize(), true)); + m_ctlBufferSizes.AddString(fmt.ToString()); - fmt.SetFormat(GetResManager()->LoadString(IDS_BSETWODISKS_STRING)); - fmt.SetParam(_t("%size"), GetSizeString(m_ccData.m_bsSizes.m_uiTwoDisksSize, szSize, 64, true)); - m_ctlBufferSizes.AddString(fmt); + fmt.SetFormat(GetResManager().LoadString(IDS_BSETWODISKS_STRING)); + fmt.SetParam(_T("%size"), GetSizeString(bsSizes.GetTwoDisksSize(), true)); + m_ctlBufferSizes.AddString(fmt.ToString()); - fmt.SetFormat(GetResManager()->LoadString(IDS_BSECD_STRING)); - fmt.SetParam(_t("%size"), GetSizeString(m_ccData.m_bsSizes.m_uiCDSize, szSize, 64, true)); - m_ctlBufferSizes.AddString(fmt); + fmt.SetFormat(GetResManager().LoadString(IDS_BSECD_STRING)); + fmt.SetParam(_T("%size"), GetSizeString(bsSizes.GetCDSize(), true)); + m_ctlBufferSizes.AddString(fmt.ToString()); - fmt.SetFormat(GetResManager()->LoadString(IDS_BSELAN_STRING)); - fmt.SetParam(_t("%size"), GetSizeString(m_ccData.m_bsSizes.m_uiLANSize, szSize, 64, true)); - m_ctlBufferSizes.AddString(fmt); + fmt.SetFormat(GetResManager().LoadString(IDS_BSELAN_STRING)); + fmt.SetParam(_T("%size"), GetSizeString(bsSizes.GetLANSize(), true)); + m_ctlBufferSizes.AddString(fmt.ToString()); } } -void CCustomCopyDlg::OnChangebufferButton() +void CCustomCopyDlg::OnChangebufferButton() { - CBufferSizeDlg dlg; - dlg.m_bsSizes=m_ccData.m_bsSizes; - if (dlg.DoModal() == IDOK) + chengine::TBufferSizes tBufferSizes = GetTaskPropBufferSizes(m_tTaskDefinition.GetConfiguration()); + + CBufferSizeDlg dlg(&tBufferSizes); + if(dlg.DoModal() == IDOK) { - m_ccData.m_bsSizes=dlg.m_bsSizes; + SetTaskPropBufferSizes(m_tTaskDefinition.GetConfiguration(), dlg.GetBufferSizes()); SetBuffersizesString(); } } @@ -529,195 +534,180 @@ void CCustomCopyDlg::OnAddfilterButton() { CFilterDlg dlg; - CString strData; - for (size_t i=0;im_bUseMask) - dlg.m_astrAddMask.Add(pFilter->GetCombinedMask(strData)); - if(pFilter->m_bUseExcludeMask) - dlg.m_astrAddExcludeMask.Add(pFilter->GetCombinedExcludeMask(strData)); - } + const chengine::TFileFilter& rFilter = afFilters.GetAt(i); + if(rFilter.GetUseMask()) + dlg.m_astrAddMask.Add(rFilter.GetCombinedMask().c_str()); + if(rFilter.GetUseExcludeMask()) + dlg.m_astrAddExcludeMask.Add(rFilter.GetCombinedExcludeMask().c_str()); } - if (dlg.DoModal() == IDOK) + if(dlg.DoModal() == IDOK) { - if (dlg.m_ffFilter.m_bUseMask || dlg.m_ffFilter.m_bUseExcludeMask || dlg.m_ffFilter.m_bUseSize - || dlg.m_ffFilter.m_bUseDate || dlg.m_ffFilter.m_bUseAttributes) + if(dlg.m_ffFilter.GetUseMask() || dlg.m_ffFilter.GetUseExcludeMask() || dlg.m_ffFilter.GetUseSize1() || dlg.m_ffFilter.GetUseDateTime1() || dlg.m_ffFilter.GetUseAttributes()) { - m_ccData.m_afFilters.Add(dlg.m_ffFilter); + afFilters.Add(dlg.m_ffFilter); AddFilter(dlg.m_ffFilter); } else MsgBox(IDS_EMPTYFILTER_STRING, MB_OK | MB_ICONINFORMATION); } } -void CCustomCopyDlg::AddFilter(const CFileFilter &rFilter, int iPos) +void CCustomCopyDlg::AddFilter(const chengine::TFileFilter &rFilter, int iPos) { LVITEM lvi; - TCHAR szLoaded[1024]; - TCHAR szData[64]; + CString strLoaded; lvi.mask=LVIF_TEXT; lvi.iItem=(iPos == -1) ? m_ctlFilters.GetItemCount() : iPos; ///////////////////// lvi.iSubItem=0; - if (rFilter.m_bUseMask) + if (rFilter.GetUseMask()) { - CString strData; - rFilter.GetCombinedMask(strData); - _tcscpy(szLoaded, strData); + string::TString strData = rFilter.GetCombinedMask(); + strLoaded = strData.c_str(); } else - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERMASKEMPTY_STRING)); + strLoaded = GetResManager().LoadString(IDS_FILTERMASKEMPTY_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.InsertItem(&lvi); ///////////////////// lvi.iSubItem=1; - if (rFilter.m_bUseExcludeMask) + if(rFilter.GetUseExcludeMask()) { - CString strData; - rFilter.GetCombinedExcludeMask(strData); - _tcscpy(szLoaded, strData); + string::TString strData = rFilter.GetCombinedExcludeMask(); + strLoaded = strData.c_str(); } else - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERMASKEMPTY_STRING)); + strLoaded = GetResManager().LoadString(IDS_FILTERMASKEMPTY_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.SetItem(&lvi); ///////////////// lvi.iSubItem=2; - if (rFilter.m_bUseSize) + if (rFilter.GetUseSize1()) { - _sntprintf(szLoaded, 1024, _T("%s %s"), GetResManager()->LoadString(IDS_LT_STRING+rFilter.m_iSizeType1), GetSizeString(rFilter.m_ullSize1, szData, 64, true)); - szLoaded[1023] = _T('\0'); - if (rFilter.m_bUseSize2) + strLoaded.Format(_T("%s %s"), GetResManager().LoadString(IDS_LT_STRING+rFilter.GetSizeType1()), (PCTSTR)GetSizeString(rFilter.GetSize1(), true)); + if (rFilter.GetUseSize2()) { - _tcscat(szLoaded, GetResManager()->LoadString(IDS_AND_STRING)); - CString strLoaded2; - strLoaded2.Format(_T("%s %s"), GetResManager()->LoadString(IDS_LT_STRING+rFilter.m_iSizeType2), GetSizeString(rFilter.m_ullSize2, szData, 64, true)); - _tcscat(szLoaded, strLoaded2); + strLoaded += GetResManager().LoadString(IDS_AND_STRING); + strLoaded.AppendFormat(_T("%s %s"), GetResManager().LoadString(IDS_LT_STRING+rFilter.GetSizeType2()), (PCTSTR)GetSizeString(rFilter.GetSize2(), true)); } } else - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERSIZE_STRING)); + strLoaded = GetResManager().LoadString(IDS_FILTERSIZE_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.SetItem(&lvi); /////////////////// lvi.iSubItem=3; - if (rFilter.m_bUseDate) + if (rFilter.GetUseDateTime1()) { - _sntprintf(szLoaded, 1024, _T("%s %s"), GetResManager()->LoadString(IDS_DATECREATED_STRING+rFilter.m_iDateType), GetResManager()->LoadString(IDS_LT_STRING+rFilter.m_iDateType1)); - szLoaded[1023] = _T('\0'); - if (rFilter.m_bDate1) - _tcscat(szLoaded, rFilter.m_tDate1.Format(_T(" %x"))); - if (rFilter.m_bTime1) - _tcscat(szLoaded, rFilter.m_tTime1.Format(_T(" %X"))); + strLoaded.Format(_T("%s %s"), GetResManager().LoadString(IDS_DATECREATED_STRING+rFilter.GetDateType()), GetResManager().LoadString(IDS_LT_STRING+rFilter.GetDateCmpType1())); - if (rFilter.m_bUseDate2) + string::TString strFmtDateTime = rFilter.GetDateTime1().Format(rFilter.GetUseDate1(), rFilter.GetUseTime1()); + strLoaded += strFmtDateTime.c_str(); + + if (rFilter.GetUseDateTime2()) { - _tcscat(szLoaded, GetResManager()->LoadString(IDS_AND_STRING)); - _tcscat(szLoaded, GetResManager()->LoadString(IDS_LT_STRING+rFilter.m_iDateType2)); - if (rFilter.m_bDate2) - _tcscat(szLoaded, rFilter.m_tDate2.Format(_T(" %x"))); - if (rFilter.m_bTime2) - _tcscat(szLoaded, rFilter.m_tTime2.Format(_T(" %X"))); + strLoaded += GetResManager().LoadString(IDS_AND_STRING); + strLoaded += GetResManager().LoadString(IDS_LT_STRING + rFilter.GetDateCmpType2()); + + strFmtDateTime = rFilter.GetDateTime2().Format(rFilter.GetUseDate2(), rFilter.GetUseTime2()); + strLoaded += strFmtDateTime.c_str(); } } else - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERDATE_STRING)); + strLoaded = GetResManager().LoadString(IDS_FILTERDATE_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.SetItem(&lvi); ///////////////////// lvi.iSubItem=4; - szLoaded[0]=_T('\0'); - if (rFilter.m_bUseAttributes) + strLoaded.Empty(); + if(rFilter.GetUseAttributes()) { - if (rFilter.m_iArchive == 1) - _tcscat(szLoaded, _T("A")); - if (rFilter.m_iReadOnly == 1) - _tcscat(szLoaded, _T("R")); - if (rFilter.m_iHidden == 1) - _tcscat(szLoaded, _T("H")); - if (rFilter.m_iSystem == 1) - _tcscat(szLoaded, _T("S")); - if (rFilter.m_iDirectory == 1) - _tcscat(szLoaded, _T("D")); + if(rFilter.GetArchive() == 1) + strLoaded += L"A"; + if(rFilter.GetReadOnly() == 1) + strLoaded += _T("R"); + if(rFilter.GetHidden() == 1) + strLoaded += _T("H"); + if(rFilter.GetSystem() == 1) + strLoaded += _T("S"); + if(rFilter.GetDirectory() == 1) + strLoaded += _T("D"); } - if (!rFilter.m_bUseAttributes || szLoaded[0] == _T('\0')) - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERATTRIB_STRING)); + if (!rFilter.GetUseAttributes() || strLoaded.IsEmpty()) + strLoaded = GetResManager().LoadString(IDS_FILTERATTRIB_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.SetItem(&lvi); ///////////////////// lvi.iSubItem=5; - szLoaded[0]=_T('\0'); - if (rFilter.m_bUseAttributes) + strLoaded.Empty(); + if(rFilter.GetUseAttributes()) { - if (rFilter.m_iArchive == 0) - _tcscat(szLoaded, _T("A")); - if (rFilter.m_iReadOnly == 0) - _tcscat(szLoaded, _T("R")); - if (rFilter.m_iHidden == 0) - _tcscat(szLoaded, _T("H")); - if (rFilter.m_iSystem == 0) - _tcscat(szLoaded, _T("S")); - if (rFilter.m_iDirectory == 0) - _tcscat(szLoaded, _T("D")); + if(rFilter.GetArchive() == 0) + strLoaded += _T("A"); + if(rFilter.GetReadOnly() == 0) + strLoaded += _T("R"); + if(rFilter.GetHidden() == 0) + strLoaded += _T("H"); + if(rFilter.GetSystem() == 0) + strLoaded += _T("S"); + if(rFilter.GetDirectory() == 0) + strLoaded += _T("D"); } - if (!rFilter.m_bUseAttributes || szLoaded[0] == _T('0')) - _tcscpy(szLoaded, GetResManager()->LoadString(IDS_FILTERATTRIB_STRING)); + if(!rFilter.GetUseAttributes() || strLoaded.IsEmpty()) + strLoaded = GetResManager().LoadString(IDS_FILTERATTRIB_STRING); - lvi.pszText=szLoaded; + lvi.pszText = (PTSTR)(PCTSTR)strLoaded; lvi.cchTextMax=lstrlen(lvi.pszText); m_ctlFilters.SetItem(&lvi); } void CCustomCopyDlg::OnRemovefilterButton() { - POSITION pos; - int iItem; - while (true) + chengine::TFileFiltersArray& afFilters = m_tTaskDefinition.GetFilters(); + + while(true) { - pos=m_ctlFilters.GetFirstSelectedItemPosition(); - if (pos == NULL) + POSITION pos = m_ctlFilters.GetFirstSelectedItemPosition(); + if (pos == nullptr) break; - else - { - iItem=m_ctlFilters.GetNextSelectedItem(pos); - m_ctlFilters.DeleteItem(iItem); - m_ccData.m_afFilters.RemoveAt(iItem); - } + + int iItem = m_ctlFilters.GetNextSelectedItem(pos); + m_ctlFilters.DeleteItem(iItem); + afFilters.RemoveAt(iItem); } } void CCustomCopyDlg::OnDestroy() { - m_ctlFiles.SetImageList(NULL, LVSIL_SMALL); + m_ctlFiles.SetImageList(nullptr, LVSIL_SMALL); m_ilImages.Detach(); CLanguageDialog::OnDestroy(); @@ -753,28 +743,23 @@ void CCustomCopyDlg::OnDblclkFiltersList(NMHDR* /*pNMHDR*/, LRESULT* pResult) { - POSITION pos=m_ctlFilters.GetFirstSelectedItemPosition(); - if (pos != NULL) + POSITION pos = m_ctlFilters.GetFirstSelectedItemPosition(); + if(pos != nullptr) { - int iItem=m_ctlFilters.GetNextSelectedItem(pos); + chengine::TFileFiltersArray& afFilters = m_tTaskDefinition.GetFilters(); + + int iItem = m_ctlFilters.GetNextSelectedItem(pos); CFilterDlg dlg; - const CFileFilter* pFilter = m_ccData.m_afFilters.GetAt(iItem); - BOOST_ASSERT(pFilter); - if(pFilter) - dlg.m_ffFilter = *pFilter; + const chengine::TFileFilter& rFilter = afFilters.GetAt(iItem); + dlg.m_ffFilter = rFilter; - CString strData; - for (size_t i=0;im_bUseMask && i != iItem) - dlg.m_astrAddMask.Add(pFilter->GetCombinedMask(strData)); - if (pFilter->m_bUseExcludeMask && i != iItem) - dlg.m_astrAddExcludeMask.Add(pFilter->GetCombinedExcludeMask(strData)); - } + const chengine::TFileFilter& rLoopFilter = afFilters.GetAt(stIndex); + if(rLoopFilter.GetUseMask() && boost::numeric_cast(stIndex) != iItem) + dlg.m_astrAddMask.Add(rLoopFilter.GetCombinedMask().c_str()); + if (rLoopFilter.GetUseExcludeMask() && boost::numeric_cast(stIndex) != iItem) + dlg.m_astrAddExcludeMask.Add(rLoopFilter.GetCombinedExcludeMask().c_str()); } if (dlg.DoModal() == IDOK) @@ -784,10 +769,10 @@ //m_ccData.m_afFilters.RemoveAt(iItem); // insert new if needed - if (dlg.m_ffFilter.m_bUseMask || dlg.m_ffFilter.m_bUseExcludeMask || dlg.m_ffFilter.m_bUseSize - || dlg.m_ffFilter.m_bUseDate || dlg.m_ffFilter.m_bUseAttributes) + if (dlg.m_ffFilter.GetUseMask() || dlg.m_ffFilter.GetUseExcludeMask() || dlg.m_ffFilter.GetUseSize1() + || dlg.m_ffFilter.GetUseDateTime1() || dlg.m_ffFilter.GetUseAttributes()) { - m_ccData.m_afFilters.SetAt(iItem, dlg.m_ffFilter); + afFilters.SetAt(iItem, dlg.m_ffFilter); AddFilter(dlg.m_ffFilter, iItem); } } @@ -798,44 +783,20 @@ void CCustomCopyDlg::OnDblclkBuffersizesList() { - int iItem=m_ctlBufferSizes.GetCurSel(); - if (iItem != LB_ERR) + int iItem = m_ctlBufferSizes.GetCurSel(); + if(iItem != LB_ERR) { - CBufferSizeDlg dlg; - dlg.m_bsSizes=m_ccData.m_bsSizes; - dlg.m_iActiveIndex=iItem; - if (dlg.DoModal() == IDOK) + chengine::TBufferSizes tBufferSizes = GetTaskPropBufferSizes(m_tTaskDefinition.GetConfiguration()); + CBufferSizeDlg dlg(&tBufferSizes, (chengine::TBufferSizes::EBufferType)iItem); + + if(dlg.DoModal() == IDOK) { - m_ccData.m_bsSizes=dlg.m_bsSizes; + SetTaskPropBufferSizes(m_tTaskDefinition.GetConfiguration(), dlg.GetBufferSizes()); SetBuffersizesString(); } } } -void CCustomCopyDlg::SetComboPath(LPCTSTR lpszText) -{ - _ASSERTE(lpszText); - if(!lpszText) - return; - - // set current select to -1 - m_ctlDstPath.SetCurSel(-1); - - SHFILEINFO sfi; - sfi.iIcon=-1; - - COMBOBOXEXITEM cbi; - TCHAR szPath[_MAX_PATH]; - - cbi.mask=CBEIF_TEXT | CBEIF_IMAGE; - cbi.iItem=-1; - _tcscpy(szPath, lpszText); - cbi.pszText=szPath; - SHGetFileInfo(cbi.pszText, FILE_ATTRIBUTE_NORMAL, &sfi, sizeof(sfi), SHGFI_SMALLICON | SHGFI_SYSICONINDEX); - cbi.iImage=sfi.iIcon; - m_ctlDstPath.SetItem(&cbi); -} - void CCustomCopyDlg::UpdateComboIcon() { // get text from combo @@ -886,36 +847,90 @@ void CCustomCopyDlg::OnImportButton() { - CFileDialog dlg(TRUE, NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, GetResManager()->LoadString(IDS_FLTALLFILTER_STRING)); - if (dlg.DoModal() == IDOK) + boost::shared_array spBuffer; + + CFileDialog dlg(TRUE, nullptr, nullptr, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, GetResManager().LoadString(IDS_FLTALLFILTER_STRING)); + if(dlg.DoModal() == IDOK) { + unsigned long ulSize = 0; UINT uiCount=0; - CString strData; try { CFile file(dlg.GetPathName(), CFile::modeRead); - CArchive ar(&file, CArchive::load); - while (ar.ReadString(strData)) + // load files max 1MB in size; + unsigned long long ullSize = file.GetLength(); + if(ullSize > 1*1024*1024 || ullSize < 2) { - strData.TrimLeft(_T("\" \t")); - strData.TrimRight(_T("\" \t")); - AddPath(strData); - uiCount++; + AfxMessageBox(GetResManager().LoadString(IDS_IMPORTERROR_STRING)); + return; } - ar.Close(); + ulSize = boost::numeric_cast(ullSize); + spBuffer.reset(new BYTE[ulSize + 3]); // guarantee that we have null at the end of the string (3 bytes to compensate for possible odd number of bytes and for unicode) + memset(spBuffer.get(), 0, ulSize + 3); + + ulSize = file.Read(spBuffer.get(), ulSize); file.Close(); } - catch(CException* e) + catch(...) { - e->Delete(); + AfxMessageBox(GetResManager().LoadString(IDS_IMPORTERROR_STRING)); + return; } + // parse text from buffer (there is no point processing files with size < 3 - stIndex.e. "c:") + if(!spBuffer || ulSize < 3) + { + AfxMessageBox(GetResManager().LoadString(IDS_IMPORTERROR_STRING)); + return; + } + + // which format? + CString strData; + if(spBuffer[0] == 0xff && spBuffer[1] == 0xfe) + { + // utf-16 (native) + strData = (wchar_t*)(spBuffer.get() + 2); + + } + else if(ulSize >= 3 && spBuffer[0] == 0xef && spBuffer[1] == 0xbb && spBuffer[2] == 0xbf) + { + boost::shared_array spWideBuffer(new wchar_t[ulSize + 1]); + memset(spWideBuffer.get(), 0, (ulSize + 1) * sizeof(wchar_t)); + + // utf-8 - needs conversion + int iRes = MultiByteToWideChar(CP_UTF8, MB_ERR_INVALID_CHARS, (char*)(spBuffer.get() + 3), ulSize - 3, spWideBuffer.get(), ulSize); + if(iRes == 0) + return; // failed to convert + + spWideBuffer[iRes] = L'\0'; + strData = spWideBuffer.get(); + } + else + { + // assuming ansi + strData = (char*)spBuffer.get(); + } + + CString strToken; + int iPos = 0; + strToken = strData.Tokenize(_T("\n"), iPos); + while(strToken != _T("")) + { + strToken.TrimLeft(_T("\" \t\r\n")); + strToken.TrimRight(_T("\" \t\r\n")); + + AddPath(strToken); + uiCount++; + + strToken = strData.Tokenize(_T("\n"), iPos); + } + // report - ictranslate::CFormat fmt(GetResManager()->LoadString(IDS_IMPORTREPORT_STRING)); - fmt.SetParam(_t("%count"), uiCount); - AfxMessageBox(fmt); + ictranslate::CFormat fmt(GetResManager().LoadString(IDS_IMPORTREPORT_STRING)); + fmt.SetParam(_T("%count"), uiCount); + AfxMessageBox(fmt.ToString()); } } @@ -932,3 +947,100 @@ GetDlgItem(IDC_FORCEDIRECTORIES_CHECK)->EnableWindow(!m_bIgnoreFolders); } + +void CCustomCopyDlg::OnExportButtonClicked() +{ + UpdateData(TRUE); + + if (!HasBasicTaskData()) + { + MsgBox(IDS_MISSINGDATA_STRING); + return; + } + + UpdateInternalTaskDefinition(); + + CFileDialog dlg(FALSE, _T("xml"), _T("Task"), OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, GetResManager().LoadString(IDS_FLTALLFILTER_STRING)); + if (dlg.DoModal() == IDOK) + { + CString strError; + try + { + m_tTaskDefinition.Store(chcore::PathFromString(dlg.GetPathName())); + } + catch (const std::exception& e) + { + strError = e.what(); + } + + if (!strError.IsEmpty()) + { + ictranslate::CFormat fmt; + fmt.SetFormat(GetResManager().LoadString(IDS_EXPORTING_TASK_FAILED)); + fmt.SetParam(_T("%reason"), strError); + + AfxMessageBox(fmt.ToString(), MB_OK | MB_ICONERROR); + } + } +} + +void CCustomCopyDlg::UpdateInternalTaskDefinition() +{ + CString strDstPath; + m_ctlDstPath.GetWindowText(strDstPath); + + // copy files from listctrl to an array + m_tTaskDefinition.ClearSourcePaths(); + + // dest path + m_tTaskDefinition.SetDestinationPath(chcore::PathFromString(strDstPath)); + + for (int i = 0; i < m_ctlFiles.GetItemCount(); i++) + { + m_tTaskDefinition.AddSourcePath(chcore::PathFromString(m_ctlFiles.GetItemText(i, 0))); + } + + // operation type + m_tTaskDefinition.SetOperationType(m_ctlOperation.GetCurSel() == 0 ? chengine::eOperation_Copy : chengine::eOperation_Move); + + // priority + chengine::SetTaskPropValue(m_tTaskDefinition.GetConfiguration(), IndexToPriority(m_ctlPriority.GetCurSel())); + + chengine::SetTaskPropValue(m_tTaskDefinition.GetConfiguration(), (m_bIgnoreFolders != 0)); + chengine::SetTaskPropValue(m_tTaskDefinition.GetConfiguration(), (m_bForceDirectories != 0)); + chengine::SetTaskPropValue(m_tTaskDefinition.GetConfiguration(), (m_bOnlyCreate != 0)); +} + +bool CCustomCopyDlg::HasBasicTaskData() +{ + CString strDstPath; + m_ctlDstPath.GetWindowText(strDstPath); + + if (strDstPath.IsEmpty() || m_ctlFiles.GetItemCount() == 0) + return false; + + return true; +} + +void CCustomCopyDlg::UpdateFilesListCtrlHeaderWidth() +{ + CRect rc; + m_ctlFiles.GetWindowRect(&rc); + rc.right -= GetSystemMetrics(SM_CXEDGE) * 2; + + // change the width of a column + LVCOLUMN lvc; + lvc.mask = LVCF_WIDTH; + lvc.cx = rc.Width(); + m_ctlFiles.SetColumn(0, &lvc); +} + +void CCustomCopyDlg::OnSize(UINT nType, int /*cx*/, int /*cy*/) +{ + if(nType == SIZE_RESTORED || nType == SIZE_MAXIMIZED) + { + CWnd* pWnd = GetDlgItem(IDC_FILES_LIST); + if(pWnd) + UpdateFilesListCtrlHeaderWidth(); + } +}