-
Notifications
You must be signed in to change notification settings - Fork 4
/
package.ts
64 lines (55 loc) · 1.73 KB
/
package.ts
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
import { env } from 'node:process';
import { dirname, join } from 'node:path';
import { existsSync, mkdirSync } from 'node:fs';
import { writable } from 'empathic/access';
import * as find from 'empathic/find';
/**
* Find the closest "package.json" file while walking parent directories.
* @returns The absolute path to a "package.json", if found.
*/
export function up(options?: find.Options): string | undefined {
return find.up('package.json', options);
}
/**
* Construct a path to a `node_modules/.cache/<name>` directory.
*
* This may return `undefined` if:
* 1. no "package.json" could be found
* 2. the nearest "node_modules" directory is not writable
* 3. the "node_modules" parent directory is not writable
*
* > [NOTE]
* > You may define a `CACHE_DIR` environment variable, which will be
* > used (as defined) instead of traversing the filesystem for the
* > closest "package.json" and inferring a "node_modules" location.
*
* @see find-cache-dir for more information.
*
* @param name The name of your module/cache.
* @returns The absolute path of the cache directory, if found.
*/
export function cache(
name: string,
options?: find.Options & { create?: boolean },
): string | undefined {
options ||= {};
let dir = env.CACHE_DIR;
if (!dir || /^(1|0|true|false)$/.test(dir)) {
let pkg = up(options);
if (dir = pkg && dirname(pkg)) {
let mods = join(dir, 'node_modules');
let exists = existsSync(mods);
// exit cuz exists but not writable
// or cuz missing but parent not writable
if (!writable(exists ? mods : dir)) return;
dir = join(mods, '.cache');
}
}
if (dir) {
dir = join(dir, name);
if (options.create && !existsSync(dir)) {
mkdirSync(dir, { recursive: true });
}
return dir;
}
}