Locating Subdirectory with _dos_findfirst & _dos_findnext

Last reviewed: July 17, 1997
Article ID: Q43144
5.10 6.00 6.00a 6.00ax 7.00 | 5.10 6.00 6.00a | 1.00 1.50
MS-DOS                      | OS/2            | WINDOWS
kbprg

The information in this article applies to:

  • The C Run-time (CRT), included with:

        - Microsoft C for MS-DOS, versions 5.1, 6.0, 6.0a, and 6.0ax
        - Microsoft C for OS/2, versions 5.1, 6.0, and 6.0a
        - Microsoft C/C++ for MS-DOS, version 7.0
        - Microsoft Visual C++ for Windows, versions 1.0 and 1.5
    

SUMMARY

When the attribute argument to the _dos_findfirst() and _dos_findnext() functions is either _A_RDONLY, _A_HIDDEN, _A_SYSTEM, or _A_SUBDIR, the functions will return all normal-attribute files. A normal-attribute file is any file that does not have a read-only, hidden, system, or directory attribute.

Thus, the following function call will return either a normal file or a subdirectory:

   _dos_findfirst( "*.*", _A_SUBDIR, &c_file )

MORE INFORMATION

To verify that the returned c_file is a subdirectory, check the attribute field of the c_file to determine whether the _A_SUBDIR bit is set. If so, then it is a subdirectory. This process may be accomplished by doing a bitwise-and of c_file.attrib with _A_SUBDIR and checking for a nonzero result.

The following program illustrates the use of these functions:

#include <dos.h>
#include <stdio.h>

main() {
        struct find_t c_file;

        _dos_findfirst( "*.*", _A_SUBDIR, &c_file );

        if( c_file.attrib & _A_SUBDIR )
        printf( "Directory listing %s\n", c_file.name );

        while (_dos_findnext(&c_file) == 0)
            if( c_file.attrib & _A_SUBDIR )
            printf( "Directory listing %s\n", c_file.name );
}


Additional reference words: kbinf 5.10 6.00 6.00a 6.00ax 7.00 1.00 1.50
KBCategory: kbprg
KBSubcategory: CRTIss
Keywords : kb16bitonly


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: July 17, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.