UNPKG

14.8 kBTypeScriptView Raw
1/// <reference types="node" />
2import { Minimatch } from 'minimatch';
3import { Minipass } from 'minipass';
4import { FSOption, Path, PathScurry } from 'path-scurry';
5import { IgnoreLike } from './ignore.js';
6import { Pattern } from './pattern.js';
7export type MatchSet = Minimatch['set'];
8export type GlobParts = Exclude<Minimatch['globParts'], undefined>;
9/**
10 * A `GlobOptions` object may be provided to any of the exported methods, and
11 * must be provided to the `Glob` constructor.
12 *
13 * All options are optional, boolean, and false by default, unless otherwise
14 * noted.
15 *
16 * All resolved options are added to the Glob object as properties.
17 *
18 * If you are running many `glob` operations, you can pass a Glob object as the
19 * `options` argument to a subsequent operation to share the previously loaded
20 * cache.
21 */
22export interface GlobOptions {
23 /**
24 * Set to `true` to always receive absolute paths for
25 * matched files. Set to `false` to always return relative paths.
26 *
27 * When this option is not set, absolute paths are returned for patterns
28 * that are absolute, and otherwise paths are returned that are relative
29 * to the `cwd` setting.
30 *
31 * This does _not_ make an extra system call to get
32 * the realpath, it only does string path resolution.
33 *
34 * Conflicts with {@link withFileTypes}
35 */
36 absolute?: boolean;
37 /**
38 * Set to false to enable {@link windowsPathsNoEscape}
39 *
40 * @deprecated
41 */
42 allowWindowsEscape?: boolean;
43 /**
44 * The current working directory in which to search. Defaults to
45 * `process.cwd()`.
46 *
47 * May be eiher a string path or a `file://` URL object or string.
48 */
49 cwd?: string | URL;
50 /**
51 * Include `.dot` files in normal matches and `globstar`
52 * matches. Note that an explicit dot in a portion of the pattern
53 * will always match dot files.
54 */
55 dot?: boolean;
56 /**
57 * Prepend all relative path strings with `./` (or `.\` on Windows).
58 *
59 * Without this option, returned relative paths are "bare", so instead of
60 * returning `'./foo/bar'`, they are returned as `'foo/bar'`.
61 *
62 * Relative patterns starting with `'../'` are not prepended with `./`, even
63 * if this option is set.
64 */
65 dotRelative?: boolean;
66 /**
67 * Follow symlinked directories when expanding `**`
68 * patterns. This can result in a lot of duplicate references in
69 * the presence of cyclic links, and make performance quite bad.
70 *
71 * By default, a `**` in a pattern will follow 1 symbolic link if
72 * it is not the first item in the pattern, or none if it is the
73 * first item in the pattern, following the same behavior as Bash.
74 */
75 follow?: boolean;
76 /**
77 * string or string[], or an object with `ignore` and `ignoreChildren`
78 * methods.
79 *
80 * If a string or string[] is provided, then this is treated as a glob
81 * pattern or array of glob patterns to exclude from matches. To ignore all
82 * children within a directory, as well as the entry itself, append `'/**'`
83 * to the ignore pattern.
84 *
85 * **Note** `ignore` patterns are _always_ in `dot:true` mode, regardless of
86 * any other settings.
87 *
88 * If an object is provided that has `ignored(path)` and/or
89 * `childrenIgnored(path)` methods, then these methods will be called to
90 * determine whether any Path is a match or if its children should be
91 * traversed, respectively.
92 */
93 ignore?: string | string[] | IgnoreLike;
94 /**
95 * Treat brace expansion like `{a,b}` as a "magic" pattern. Has no
96 * effect if {@link nobrace} is set.
97 *
98 * Only has effect on the {@link hasMagic} function.
99 */
100 magicalBraces?: boolean;
101 /**
102 * Add a `/` character to directory matches. Note that this requires
103 * additional stat calls in some cases.
104 */
105 mark?: boolean;
106 /**
107 * Perform a basename-only match if the pattern does not contain any slash
108 * characters. That is, `*.js` would be treated as equivalent to
109 * `**\/*.js`, matching all js files in all directories.
110 */
111 matchBase?: boolean;
112 /**
113 * Limit the directory traversal to a given depth below the cwd.
114 * Note that this does NOT prevent traversal to sibling folders,
115 * root patterns, and so on. It only limits the maximum folder depth
116 * that the walk will descend, relative to the cwd.
117 */
118 maxDepth?: number;
119 /**
120 * Do not expand `{a,b}` and `{1..3}` brace sets.
121 */
122 nobrace?: boolean;
123 /**
124 * Perform a case-insensitive match. This defaults to `true` on macOS and
125 * Windows systems, and `false` on all others.
126 *
127 * **Note** `nocase` should only be explicitly set when it is
128 * known that the filesystem's case sensitivity differs from the
129 * platform default. If set `true` on case-sensitive file
130 * systems, or `false` on case-insensitive file systems, then the
131 * walk may return more or less results than expected.
132 */
133 nocase?: boolean;
134 /**
135 * Do not match directories, only files. (Note: to match
136 * _only_ directories, put a `/` at the end of the pattern.)
137 */
138 nodir?: boolean;
139 /**
140 * Do not match "extglob" patterns such as `+(a|b)`.
141 */
142 noext?: boolean;
143 /**
144 * Do not match `**` against multiple filenames. (Ie, treat it as a normal
145 * `*` instead.)
146 *
147 * Conflicts with {@link matchBase}
148 */
149 noglobstar?: boolean;
150 /**
151 * Defaults to value of `process.platform` if available, or `'linux'` if
152 * not. Setting `platform:'win32'` on non-Windows systems may cause strange
153 * behavior.
154 */
155 platform?: NodeJS.Platform;
156 /**
157 * Set to true to call `fs.realpath` on all of the
158 * results. In the case of an entry that cannot be resolved, the
159 * entry is omitted. This incurs a slight performance penalty, of
160 * course, because of the added system calls.
161 */
162 realpath?: boolean;
163 /**
164 *
165 * A string path resolved against the `cwd` option, which
166 * is used as the starting point for absolute patterns that start
167 * with `/`, (but not drive letters or UNC paths on Windows).
168 *
169 * Note that this _doesn't_ necessarily limit the walk to the
170 * `root` directory, and doesn't affect the cwd starting point for
171 * non-absolute patterns. A pattern containing `..` will still be
172 * able to traverse out of the root directory, if it is not an
173 * actual root directory on the filesystem, and any non-absolute
174 * patterns will be matched in the `cwd`. For example, the
175 * pattern `/../*` with `{root:'/some/path'}` will return all
176 * files in `/some`, not all files in `/some/path`. The pattern
177 * `*` with `{root:'/some/path'}` will return all the entries in
178 * the cwd, not the entries in `/some/path`.
179 *
180 * To start absolute and non-absolute patterns in the same
181 * path, you can use `{root:''}`. However, be aware that on
182 * Windows systems, a pattern like `x:/*` or `//host/share/*` will
183 * _always_ start in the `x:/` or `//host/share` directory,
184 * regardless of the `root` setting.
185 */
186 root?: string;
187 /**
188 * A [PathScurry](http://npm.im/path-scurry) object used
189 * to traverse the file system. If the `nocase` option is set
190 * explicitly, then any provided `scurry` object must match this
191 * setting.
192 */
193 scurry?: PathScurry;
194 /**
195 * Call `lstat()` on all entries, whether required or not to determine
196 * if it's a valid match. When used with {@link withFileTypes}, this means
197 * that matches will include data such as modified time, permissions, and
198 * so on. Note that this will incur a performance cost due to the added
199 * system calls.
200 */
201 stat?: boolean;
202 /**
203 * An AbortSignal which will cancel the Glob walk when
204 * triggered.
205 */
206 signal?: AbortSignal;
207 /**
208 * Use `\\` as a path separator _only_, and
209 * _never_ as an escape character. If set, all `\\` characters are
210 * replaced with `/` in the pattern.
211 *
212 * Note that this makes it **impossible** to match against paths
213 * containing literal glob pattern characters, but allows matching
214 * with patterns constructed using `path.join()` and
215 * `path.resolve()` on Windows platforms, mimicking the (buggy!)
216 * behavior of Glob v7 and before on Windows. Please use with
217 * caution, and be mindful of [the caveat below about Windows
218 * paths](#windows). (For legacy reasons, this is also set if
219 * `allowWindowsEscape` is set to the exact value `false`.)
220 */
221 windowsPathsNoEscape?: boolean;
222 /**
223 * Return [PathScurry](http://npm.im/path-scurry)
224 * `Path` objects instead of strings. These are similar to a
225 * NodeJS `Dirent` object, but with additional methods and
226 * properties.
227 *
228 * Conflicts with {@link absolute}
229 */
230 withFileTypes?: boolean;
231 /**
232 * An fs implementation to override some or all of the defaults. See
233 * http://npm.im/path-scurry for details about what can be overridden.
234 */
235 fs?: FSOption;
236 /**
237 * Just passed along to Minimatch. Note that this makes all pattern
238 * matching operations slower and *extremely* noisy.
239 */
240 debug?: boolean;
241 /**
242 * Return `/` delimited paths, even on Windows.
243 *
244 * On posix systems, this has no effect. But, on Windows, it means that
245 * paths will be `/` delimited, and absolute paths will be their full
246 * resolved UNC forms, eg instead of `'C:\\foo\\bar'`, it would return
247 * `'//?/C:/foo/bar'`
248 */
249 posix?: boolean;
250 /**
251 * Do not match any children of any matches. For example, the pattern
252 * `**\/foo` would match `a/foo`, but not `a/foo/b/foo` in this mode.
253 *
254 * This is especially useful for cases like "find all `node_modules`
255 * folders, but not the ones in `node_modules`".
256 *
257 * In order to support this, the `Ignore` implementation must support an
258 * `add(pattern: string)` method. If using the default `Ignore` class, then
259 * this is fine, but if this is set to `false`, and a custom `Ignore` is
260 * provided that does not have an `add()` method, then it will throw an
261 * error.
262 *
263 * **Caveat** It *only* ignores matches that would be a descendant of a
264 * previous match, and only if that descendant is matched *after* the
265 * ancestor is encountered. Since the file system walk happens in
266 * indeterminate order, it's possible that a match will already be added
267 * before its ancestor, if multiple or braced patterns are used.
268 *
269 * For example:
270 *
271 * ```ts
272 * const results = await glob([
273 * // likely to match first, since it's just a stat
274 * 'a/b/c/d/e/f',
275 *
276 * // this pattern is more complicated! It must to various readdir()
277 * // calls and test the results against a regular expression, and that
278 * // is certainly going to take a little bit longer.
279 * //
280 * // So, later on, it encounters a match at 'a/b/c/d/e', but it's too
281 * // late to ignore a/b/c/d/e/f, because it's already been emitted.
282 * 'a/[bdf]/?/[a-z]/*',
283 * ], { includeChildMatches: false })
284 * ```
285 *
286 * It's best to only set this to `false` if you can be reasonably sure that
287 * no components of the pattern will potentially match one another's file
288 * system descendants, or if the occasional included child entry will not
289 * cause problems.
290 *
291 * @default true
292 */
293 includeChildMatches?: boolean;
294}
295export type GlobOptionsWithFileTypesTrue = GlobOptions & {
296 withFileTypes: true;
297 absolute?: undefined;
298 mark?: undefined;
299 posix?: undefined;
300};
301export type GlobOptionsWithFileTypesFalse = GlobOptions & {
302 withFileTypes?: false;
303};
304export type GlobOptionsWithFileTypesUnset = GlobOptions & {
305 withFileTypes?: undefined;
306};
307export type Result<Opts> = Opts extends GlobOptionsWithFileTypesTrue ? Path : Opts extends GlobOptionsWithFileTypesFalse ? string : Opts extends GlobOptionsWithFileTypesUnset ? string : string | Path;
308export type Results<Opts> = Result<Opts>[];
309export type FileTypes<Opts> = Opts extends GlobOptionsWithFileTypesTrue ? true : Opts extends GlobOptionsWithFileTypesFalse ? false : Opts extends GlobOptionsWithFileTypesUnset ? false : boolean;
310/**
311 * An object that can perform glob pattern traversals.
312 */
313export declare class Glob<Opts extends GlobOptions> implements GlobOptions {
314 absolute?: boolean;
315 cwd: string;
316 root?: string;
317 dot: boolean;
318 dotRelative: boolean;
319 follow: boolean;
320 ignore?: string | string[] | IgnoreLike;
321 magicalBraces: boolean;
322 mark?: boolean;
323 matchBase: boolean;
324 maxDepth: number;
325 nobrace: boolean;
326 nocase: boolean;
327 nodir: boolean;
328 noext: boolean;
329 noglobstar: boolean;
330 pattern: string[];
331 platform: NodeJS.Platform;
332 realpath: boolean;
333 scurry: PathScurry;
334 stat: boolean;
335 signal?: AbortSignal;
336 windowsPathsNoEscape: boolean;
337 withFileTypes: FileTypes<Opts>;
338 includeChildMatches: boolean;
339 /**
340 * The options provided to the constructor.
341 */
342 opts: Opts;
343 /**
344 * An array of parsed immutable {@link Pattern} objects.
345 */
346 patterns: Pattern[];
347 /**
348 * All options are stored as properties on the `Glob` object.
349 *
350 * See {@link GlobOptions} for full options descriptions.
351 *
352 * Note that a previous `Glob` object can be passed as the
353 * `GlobOptions` to another `Glob` instantiation to re-use settings
354 * and caches with a new pattern.
355 *
356 * Traversal functions can be called multiple times to run the walk
357 * again.
358 */
359 constructor(pattern: string | string[], opts: Opts);
360 /**
361 * Returns a Promise that resolves to the results array.
362 */
363 walk(): Promise<Results<Opts>>;
364 /**
365 * synchronous {@link Glob.walk}
366 */
367 walkSync(): Results<Opts>;
368 /**
369 * Stream results asynchronously.
370 */
371 stream(): Minipass<Result<Opts>, Result<Opts>>;
372 /**
373 * Stream results synchronously.
374 */
375 streamSync(): Minipass<Result<Opts>, Result<Opts>>;
376 /**
377 * Default sync iteration function. Returns a Generator that
378 * iterates over the results.
379 */
380 iterateSync(): Generator<Result<Opts>, void, void>;
381 [Symbol.iterator](): Generator<Result<Opts>, void, void>;
382 /**
383 * Default async iteration function. Returns an AsyncGenerator that
384 * iterates over the results.
385 */
386 iterate(): AsyncGenerator<Result<Opts>, void, void>;
387 [Symbol.asyncIterator](): AsyncGenerator<Result<Opts>, void, void>;
388}
389//# sourceMappingURL=glob.d.ts.map
\No newline at end of file