| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- // DirObject.cpp : implementation file
- //
- #include "stdafx.h"
- #include "DirObject.h"
- #include "FileObject.h"
- // CDirObject
- IMPLEMENT_DYNAMIC(CDirObject, CBaseObject)
- CDirObject::CDirObject(const CString& dirPath)
- : CBaseObject(dirPath)
- {
- CFileFind fileFind;
- BOOL bWorking = fileFind.FindFile(dirPath+_T("\\*.*"));
- while (bWorking)
- {
- bWorking = fileFind.FindNextFile();
- if (fileFind.IsDots())
- continue;
- if (fileFind.IsDirectory())
- {
- CDirObject* pDirObject = new CDirObject(fileFind.GetFilePath());
- m_dirArray.Add(pDirObject);
- }
- else
- {
- CFileObject* pFileObject = new CFileObject(fileFind.GetFilePath());
- m_fileArray.Add(pFileObject);
- }
- }
- }
- CDirObject::~CDirObject()
- {
- INT_PTR dirCount = m_dirArray.GetCount();
- for (INT_PTR dirIndex = 0; dirIndex < dirCount; dirIndex++)
- delete m_dirArray.GetAt(dirIndex);
- INT_PTR fileCount = m_fileArray.GetCount();
- for (INT_PTR fileIndex = 0; fileIndex < fileCount; fileIndex++)
- delete m_fileArray.GetAt(fileIndex);
- }
- // CDirObject member functions
- ULONGLONG CDirObject::GetSizeOnDisc()
- {
- ULONGLONG sectorSize = 0;
- INT_PTR dirCount = m_dirArray.GetCount();
- for (INT_PTR dirIndex = 0; dirIndex < dirCount; dirIndex++)
- sectorSize += m_dirArray.GetAt(dirIndex)->GetSizeOnDisc();
- INT_PTR fileCount = m_fileArray.GetCount();
- for (INT_PTR fileIndex = 0; fileIndex < fileCount; fileIndex++)
- sectorSize += m_fileArray.GetAt(fileIndex)->GetSizeOnDisc();
- return sectorSize;
- }
|