aboutsummaryrefslogtreecommitdiff
path: root/win32/common/dirent.h
blob: 9df230711876413a7f4f6b85e1b51ca17e62426a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
/*

 * 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

 *  DISCLAIMED. This includeds but is not limited to warranties of

 *  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. */

	char*		d_name;		/* File name. */

	/* NOTE: The name in the dirent structure points to the name in the

	 *       finddata_t structure in the DIR. */

};



/*

 * This is an internal data structure. Good programmers will not use it

 * except as an argument to one of the functions below.

 * dd_stat field is now int (was short in older versions).

 */

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

	 */

	int			dd_stat;



	/* given path for dir with search pattern (struct is extended) */

	char			dd_name[1];

} DIR;



DIR*		opendir (const char*);

struct dirent*	readdir (DIR*);

int		closedir (DIR*);

void		rewinddir (DIR*);

long		telldir (DIR*);

void		seekdir (DIR*, long);





/* 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. */

	wchar_t*	d_name;		/* File name. */

	/* 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;







_WDIR*		_wopendir (const wchar_t*);

struct _wdirent* _wreaddir (_WDIR*);

int		_wclosedir (_WDIR*);

void		_wrewinddir (_WDIR*);

long		_wtelldir (_WDIR*);

void		_wseekdir (_WDIR*, long);





#ifdef	__cplusplus

}

#endif



#endif	/* Not RC_INVOKED */



#endif	/* Not _DIRENT_H_ */



#endif	/* Not __STRICT_ANSI__ */