Partilhar via


CFileFind::IsDirectory

Chamar essa função de membro para determinar se o arquivo for encontrado um diretório.

BOOL IsDirectory( ) const;

Valor de retorno

Diferente de zero se com êxito; se não 0.

Comentários

Um arquivo que é um diretório é marcado com FILE_ATTRIBUTE_DIRECTORY que um atributo de arquivo identificar a estrutura de WIN32_FIND_DATA .

Você deve chamar FindNextFile pelo menos uma vez antes de chamar IsDirectory.

Consulte a função de membro MatchesMask para obter uma lista completa dos atributos de arquivo.

Exemplo

É recursivo até pequenos do programa cada pasta na unidade e as cópias do nome do diretório 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:"));
}

Requisitos

Cabeçalho: afx.h

Consulte também

Referência

Classe de CFileFind

Gráfico de hierarquia