* contrib/hbziparch/_features.h
* contrib/hbziparch/_platform.h
* contrib/hbziparch/Aes.cpp
* contrib/hbziparch/Aes.h
* contrib/hbziparch/BaseLibCompressor.cpp
* contrib/hbziparch/BaseLibCompressor.h
* contrib/hbziparch/BytesWriter.h
* contrib/hbziparch/Bzip2Compressor.cpp
* contrib/hbziparch/Bzip2Compressor.h
* contrib/hbziparch/DeflateCompressor.cpp
* contrib/hbziparch/DeflateCompressor.h
* contrib/hbziparch/DirEnumerator.cpp
* contrib/hbziparch/DirEnumerator.h
* contrib/hbziparch/FileFilter.cpp
* contrib/hbziparch/FileFilter.h
* contrib/hbziparch/FileInfo.h
* contrib/hbziparch/Hmac.cpp
* contrib/hbziparch/Hmac.h
* contrib/hbziparch/RandomPool.cpp
* contrib/hbziparch/RandomPool.h
* contrib/hbziparch/Sha1.cpp
* contrib/hbziparch/Sha1.h
* contrib/hbziparch/std_mfc.h
* contrib/hbziparch/std_stl.h
* contrib/hbziparch/Wildcard.cpp
* contrib/hbziparch/Wildcard.h
* contrib/hbziparch/ZipAbstractFile.h
* contrib/hbziparch/ZipAesCryptograph.cpp
* contrib/hbziparch/ZipAesCryptograph.h
* contrib/hbziparch/ZipArchive.cpp
* contrib/hbziparch/ZipArchive.h
* contrib/hbziparch/ZipAutoBuffer.cpp
* contrib/hbziparch/ZipAutoBuffer.h
* contrib/hbziparch/ZipBaseException.h
* contrib/hbziparch/ZipCallback.h
* contrib/hbziparch/ZipCallbackProvider.h
* contrib/hbziparch/ZipCentralDir.cpp
* contrib/hbziparch/ZipCentralDir.h
* contrib/hbziparch/ZipCollections.h
* contrib/hbziparch/ZipCollections_mfc.h
* contrib/hbziparch/ZipCollections_stl.h
* contrib/hbziparch/ZipCompatibility.cpp
* contrib/hbziparch/ZipCompatibility.h
* contrib/hbziparch/ZipCompressor.cpp
* contrib/hbziparch/ZipCompressor.h
* contrib/hbziparch/ZipCrc32Cryptograph.cpp
* contrib/hbziparch/ZipCrc32Cryptograph.h
* contrib/hbziparch/ZipCryptograph.cpp
* contrib/hbziparch/ZipCryptograph.h
* contrib/hbziparch/ZipException.cpp
* contrib/hbziparch/ZipException.h
* contrib/hbziparch/ZipExtraData.cpp
* contrib/hbziparch/ZipExtraData.h
* contrib/hbziparch/ZipExtraField.cpp
* contrib/hbziparch/ZipExtraField.h
* contrib/hbziparch/ZipFile.h
* contrib/hbziparch/ZipFile_mfc.cpp
* contrib/hbziparch/ZipFile_mfc.h
* contrib/hbziparch/ZipFile_stl.cpp
* contrib/hbziparch/ZipFile_stl.h
* contrib/hbziparch/ZipFileHeader.cpp
* contrib/hbziparch/ZipFileHeader.h
* contrib/hbziparch/ZipFileMapping.h
* contrib/hbziparch/ZipFileMapping_lnx.h
* contrib/hbziparch/ZipFileMapping_win.h
* contrib/hbziparch/ZipMemFile.cpp
* contrib/hbziparch/ZipMemFile.h
* contrib/hbziparch/ZipMutex.h
* contrib/hbziparch/ZipMutex_lnx.h
* contrib/hbziparch/ZipMutex_win.h
* contrib/hbziparch/ZipPathComponent.h
* contrib/hbziparch/ZipPlatform.h
* contrib/hbziparch/ZipPlatformComm.cpp
* contrib/hbziparch/ZipStorage.cpp
* contrib/hbziparch/ZipStorage.h
* contrib/hbziparch/ZipString.h
* contrib/hbziparch/ZipString_mfc.h
* contrib/hbziparch/ZipString_stl.h
* contrib/hbziparch/ZipStringStoreSettings.h
+ ZipArchive lib update finished.
; Pass 2/2
; Please test.
199 lines
4.8 KiB
C++
199 lines
4.8 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
// This source file is part of the ZipArchive library source distribution and
|
|
// is Copyrighted 2000 - 2007 by Artpol Software - Tadeusz Dracz
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License
|
|
// as published by the Free Software Foundation; either version 2
|
|
// of the License, or (at your option) any later version.
|
|
//
|
|
// For the licensing details refer to the License.txt file.
|
|
//
|
|
// Web Site: http://www.artpol-software.com
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* \file DirEnumerator.h
|
|
* Includes the ZipArchiveLib::CDirEnumerator class.
|
|
*
|
|
*/
|
|
|
|
#if !defined(ZIPARCHIVE_DIRENUMERATOR_DOT_H)
|
|
#define ZIPARCHIVE_DIRENUMERATOR_DOT_H
|
|
|
|
#if _MSC_VER > 1000
|
|
#pragma once
|
|
#pragma warning( push )
|
|
#pragma warning (disable : 4100) // unreferenced formal parameter
|
|
#if defined ZIP_HAS_DLL
|
|
#pragma warning( disable : 4251 ) // needs to have dll-interface to be used by clients of class
|
|
#endif
|
|
#endif
|
|
|
|
#include "ZipString.h"
|
|
#include "ZipPathComponent.h"
|
|
#include "FileFilter.h"
|
|
|
|
/**
|
|
Includes helper classes. Some of them can be reused in other applications.
|
|
*/
|
|
namespace ZipArchiveLib
|
|
{
|
|
/**
|
|
A base class for processing multiple files in a directory.
|
|
It provides a directory enumeration functionality.
|
|
*/
|
|
class ZIP_API CDirEnumerator
|
|
{
|
|
LPCTSTR m_lpszDirectory;
|
|
LPCTSTR m_lpszFileNameMask;
|
|
bool m_bRecursive;
|
|
CZipString m_szCurrentDirectory;
|
|
protected:
|
|
/**
|
|
Initializes a new CDirEnumerator object.
|
|
|
|
\param lpszDirectory
|
|
A directory to process.
|
|
|
|
\param bRecursive
|
|
The value indicating whether the subfolders of \a lpszDirectory
|
|
should be processed recursively or not.
|
|
|
|
\see
|
|
GetDirectory
|
|
\see
|
|
IsRecursive
|
|
*/
|
|
CDirEnumerator(LPCTSTR lpszDirectory, bool bRecursive = true)
|
|
{
|
|
CZipString dir(lpszDirectory);
|
|
if (dir.IsEmpty())
|
|
m_lpszDirectory = _T(".");
|
|
else
|
|
m_lpszDirectory = lpszDirectory;
|
|
m_bRecursive = bRecursive;
|
|
}
|
|
|
|
/**
|
|
Override this method to perform file processing while enumerating directories.
|
|
This method is not called for directories, but for files only.
|
|
|
|
\param lpszPath
|
|
The full path to the current file.
|
|
|
|
\param info
|
|
A structure containing an information about the current file.
|
|
|
|
\return
|
|
Return \c true to continue the enumeration.
|
|
When you return \c false, the enumeration is aborted.
|
|
|
|
\see
|
|
CFileFilter::Evaluate
|
|
|
|
*/
|
|
virtual bool Process(LPCTSTR lpszPath, const CFileInfo& info) = 0;
|
|
|
|
/**
|
|
This method is called at the beginning of the enumeration process.
|
|
|
|
\see
|
|
OnEnumerationEnd
|
|
*/
|
|
virtual void OnEnumerationBegin(){}
|
|
|
|
/**
|
|
This method is called at the end of the enumeration process.
|
|
|
|
\param bResult
|
|
It is set to \c false, if the #Process method returned \c false (the enumeration
|
|
was aborted). Otherwise, it is set to \c true.
|
|
|
|
\see
|
|
OnEnumerationBegin
|
|
*/
|
|
virtual void OnEnumerationEnd(bool bResult){}
|
|
|
|
/**
|
|
This method is called when an enumeration process enters a new directory.
|
|
|
|
\see
|
|
GetCurrentDirectory
|
|
\see
|
|
ExitDirectory
|
|
*/
|
|
virtual void EnterDirectory(){}
|
|
|
|
/**
|
|
This method is method called when an enumeration process exits a directory.
|
|
|
|
\see
|
|
GetCurrentDirectory
|
|
\see
|
|
EnterDirectory
|
|
*/
|
|
virtual void ExitDirectory(){}
|
|
|
|
public:
|
|
|
|
/**
|
|
Returns the directory being enumerated.
|
|
|
|
\return
|
|
The directory being enumerated (root).
|
|
|
|
\see
|
|
CDirEnumerator::CDirEnumerator
|
|
*/
|
|
LPCTSTR GetDirectory() const {return m_lpszDirectory;}
|
|
|
|
/**
|
|
Returns the value indicating whether the subfolders of the root directory
|
|
are processed recursively or not.
|
|
|
|
\return
|
|
\c true, if the enumeration process is recursive; \c false otherwise.
|
|
|
|
\see
|
|
CDirEnumerator::CDirEnumerator
|
|
*/
|
|
bool IsRecursive() const {return m_bRecursive;}
|
|
|
|
/**
|
|
Returns the directory which the enumeration process is currently processing.
|
|
|
|
\return
|
|
The directory which the enumeration process is currently processing.
|
|
*/
|
|
LPCTSTR GetCurrentDirectory() const {return m_szCurrentDirectory;}
|
|
|
|
/**
|
|
Starts the enumeration process. Calls CFileFilter::Evaluate method for every file or directory found.
|
|
If CFileFilter::Evaluate returns \c true, the file is processed by the #Process method.
|
|
|
|
\param filter
|
|
A filter that decides which directories and/or files should be processed and which should not.
|
|
|
|
\return
|
|
\c false, if the process was aborted (the #Process method returned \c false); \c true otherwise.
|
|
|
|
\see
|
|
CFileFilter::Evaluate
|
|
*/
|
|
bool Start(CFileFilter& filter);
|
|
|
|
virtual ~CDirEnumerator(){}
|
|
private:
|
|
static bool IsDots(LPCTSTR lpszName);
|
|
};
|
|
|
|
}
|
|
|
|
#if _MSC_VER > 1000
|
|
#pragma warning( pop )
|
|
#endif
|
|
|
|
#endif
|
|
|