1 | /// <reference types="node" />
|
2 | import { Minimatch } from 'minimatch';
|
3 | import { Minipass } from 'minipass';
|
4 | import { FSOption, Path, PathScurry } from 'path-scurry';
|
5 | import { IgnoreLike } from './ignore.js';
|
6 | import { Pattern } from './pattern.js';
|
7 | export type MatchSet = Minimatch['set'];
|
8 | export 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 | */
|
22 | export 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 | }
|
295 | export type GlobOptionsWithFileTypesTrue = GlobOptions & {
|
296 | withFileTypes: true;
|
297 | absolute?: undefined;
|
298 | mark?: undefined;
|
299 | posix?: undefined;
|
300 | };
|
301 | export type GlobOptionsWithFileTypesFalse = GlobOptions & {
|
302 | withFileTypes?: false;
|
303 | };
|
304 | export type GlobOptionsWithFileTypesUnset = GlobOptions & {
|
305 | withFileTypes?: undefined;
|
306 | };
|
307 | export type Result<Opts> = Opts extends GlobOptionsWithFileTypesTrue ? Path : Opts extends GlobOptionsWithFileTypesFalse ? string : Opts extends GlobOptionsWithFileTypesUnset ? string : string | Path;
|
308 | export type Results<Opts> = Result<Opts>[];
|
309 | export 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 | */
|
313 | export 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 { 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 |