CFileFind::IsDirectory
見つかったファイルがディレクトリかどうかを判定するためにこのメンバー関数を呼び出します。
BOOL IsDirectory( ) const;
戻り値
正常終了した場合は 0 以外を返します。それ以外の場合は 0 を返します。
解説
ディレクトリにあるファイルのファイル属性が WIN32_FIND_DATA の構造で指定した FILE_ATTRIBUTE_DIRECTORY でマークされています。
IsDirectoryを呼び出す前に FindNextFile を少なくとも一度呼び出す必要があります。
ファイル属性の完全な一覧については、メンバー関数 MatchesMask を参照してください。
使用例
この小さなプログラムの再帰の C:\ ドライブおよび印刷の任意のディレクトリ ディレクトリの名前。
void Recurse(LPCTSTR pstr)
{
CFileFind finder;
// build a string with wildcards
CString strWildcard(pstr);
strWildcard += _T("\\*.*");
// start working for files
BOOL bWorking = finder.FindFile(strWildcard);
while (bWorking)
{
bWorking = finder.FindNextFile();
// skip . and .. files; otherwise, we'd
// recur infinitely!
if (finder.IsDots())
continue;
// if it's a directory, recursively search it
if (finder.IsDirectory())
{
CString str = finder.GetFilePath();
TRACE(_T("%s\n"), (LPCTSTR)str);
Recurse(str);
}
}
finder.Close();
}
void PrintDirs()
{
Recurse(_T("C:"));
}
必要条件
ヘッダー : afx.h