2000-02-18 03:38:33 +08:00
|
|
|
/*
|
|
|
|
* DIRENT.H (formerly DIRLIB.H)
|
|
|
|
*
|
|
|
|
* by M. J. Weinstein Released to public domain 1-Jan-89
|
|
|
|
*
|
|
|
|
* Because I have heard that this feature (opendir, readdir, closedir)
|
|
|
|
* it so useful for programmers coming from UNIX or attempting to port
|
|
|
|
* UNIX code, and because it is reasonably light weight, I have included
|
|
|
|
* it in the Mingw32 package. I have also added an implementation of
|
|
|
|
* rewinddir, seekdir and telldir.
|
|
|
|
* - Colin Peters <colin@bird.fu.is.saga-u.ac.jp>
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that is will be useful but
|
|
|
|
* WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
|
2001-12-05 23:01:06 +08:00
|
|
|
* DISCLAIMED. This includeds but is not limited to warranties of
|
2000-02-18 03:38:33 +08:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
*
|
|
|
|
* $Revision$
|
|
|
|
* $Author$
|
|
|
|
* $Date$
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __STRICT_ANSI__
|
|
|
|
|
|
|
|
#ifndef _DIRENT_H_
|
|
|
|
#define _DIRENT_H_
|
|
|
|
|
|
|
|
/* All the headers include this file. */
|
|
|
|
#include <_mingw.h>
|
|
|
|
|
|
|
|
#include <io.h>
|
|
|
|
|
|
|
|
#ifndef RC_INVOKED
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct dirent
|
|
|
|
{
|
|
|
|
long d_ino; /* Always zero. */
|
|
|
|
unsigned short d_reclen; /* Always zero. */
|
|
|
|
unsigned short d_namlen; /* Length of name in d_name. */
|
2003-06-18 21:54:47 +08:00
|
|
|
char d_name[FILENAME_MAX]; /* File name. */
|
2000-02-18 03:38:33 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is an internal data structure. Good programmers will not use it
|
|
|
|
* except as an argument to one of the functions below.
|
2002-06-13 18:20:48 +08:00
|
|
|
* dd_stat field is now int (was short in older versions).
|
2000-02-18 03:38:33 +08:00
|
|
|
*/
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
/* disk transfer area for this dir */
|
|
|
|
struct _finddata_t dd_dta;
|
|
|
|
|
|
|
|
/* dirent struct to return from dir (NOTE: this makes this thread
|
|
|
|
* safe as long as only one thread uses a particular DIR struct at
|
|
|
|
* a time) */
|
|
|
|
struct dirent dd_dir;
|
|
|
|
|
|
|
|
/* _findnext handle */
|
|
|
|
long dd_handle;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Status of search:
|
|
|
|
* 0 = not started yet (next entry to read is first entry)
|
|
|
|
* -1 = off the end
|
|
|
|
* positive = 0 based index of next entry
|
|
|
|
*/
|
2002-06-13 18:20:48 +08:00
|
|
|
int dd_stat;
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
/* given path for dir with search pattern (struct is extended) */
|
|
|
|
char dd_name[1];
|
|
|
|
} DIR;
|
|
|
|
|
2003-02-11 05:13:34 +08:00
|
|
|
DIR* __cdecl opendir (const char*);
|
|
|
|
struct dirent* __cdecl readdir (DIR*);
|
|
|
|
int __cdecl closedir (DIR*);
|
|
|
|
void __cdecl rewinddir (DIR*);
|
|
|
|
long __cdecl telldir (DIR*);
|
|
|
|
void __cdecl seekdir (DIR*, long);
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2002-06-13 18:20:48 +08:00
|
|
|
|
|
|
|
/* wide char versions */
|
|
|
|
|
|
|
|
struct _wdirent
|
|
|
|
{
|
|
|
|
long d_ino; /* Always zero. */
|
|
|
|
unsigned short d_reclen; /* Always zero. */
|
|
|
|
unsigned short d_namlen; /* Length of name in d_name. */
|
2003-06-18 21:54:47 +08:00
|
|
|
wchar_t d_name[FILENAME_MAX]; /* File name. */
|
2002-06-13 18:20:48 +08:00
|
|
|
/* NOTE: The name in the dirent structure points to the name in the * wfinddata_t structure in the _WDIR. */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is an internal data structure. Good programmers will not use it
|
|
|
|
* except as an argument to one of the functions below.
|
|
|
|
*/
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
/* disk transfer area for this dir */
|
|
|
|
struct _wfinddata_t dd_dta;
|
|
|
|
|
|
|
|
/* dirent struct to return from dir (NOTE: this makes this thread
|
|
|
|
* safe as long as only one thread uses a particular DIR struct at
|
|
|
|
* a time) */
|
|
|
|
struct _wdirent dd_dir;
|
|
|
|
|
|
|
|
/* _findnext handle */
|
|
|
|
long dd_handle;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Status of search:
|
|
|
|
* 0 = not started yet (next entry to read is first entry)
|
|
|
|
* -1 = off the end
|
|
|
|
* positive = 0 based index of next entry
|
|
|
|
*/
|
|
|
|
int dd_stat;
|
|
|
|
|
|
|
|
/* given path for dir with search pattern (struct is extended) */
|
|
|
|
wchar_t dd_name[1];
|
|
|
|
} _WDIR;
|
|
|
|
|
|
|
|
|
|
|
|
|
2003-02-11 05:13:34 +08:00
|
|
|
_WDIR* __cdecl _wopendir (const wchar_t*);
|
|
|
|
struct _wdirent* __cdecl _wreaddir (_WDIR*);
|
|
|
|
int __cdecl _wclosedir (_WDIR*);
|
|
|
|
void __cdecl _wrewinddir (_WDIR*);
|
|
|
|
long __cdecl _wtelldir (_WDIR*);
|
|
|
|
void __cdecl _wseekdir (_WDIR*, long);
|
2002-06-13 18:20:48 +08:00
|
|
|
|
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* Not RC_INVOKED */
|
|
|
|
|
|
|
|
#endif /* Not _DIRENT_H_ */
|
|
|
|
|
|
|
|
#endif /* Not __STRICT_ANSI__ */
|
|
|
|
|