CFileFind::IsDirectory
更新 : 2007 年 11 月
検索したファイルがディレクトリかどうかを確認します。
BOOL IsDirectory( ) const;
戻り値
正常終了した場合は 0 以外を返します。それ以外の場合は 0 を返します。
解説
ディレクトリには FILE_ATTRIBUTE_DIRECTORY 属性が設定されています。このファイル属性は、WIN32_FIND_DATA 構造体で認識されます。
IsDirectory を呼び出す前に、少なくとも 1 回は 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