@nemigo/helpers 0.0.4 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/explorer.d.ts +14 -0
- package/dist/explorer.js +21 -0
- package/dist/lens.d.ts +64 -0
- package/dist/lens.js +50 -0
- package/dist/script.d.ts +13 -0
- package/dist/script.js +14 -0
- package/package.json +18 -3
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { PathLike, Stats } from "node:fs";
|
|
2
|
+
/**
|
|
3
|
+
* Проверяет существование пути и его тип (файл или папка) через {@link stat}
|
|
4
|
+
*
|
|
5
|
+
* @param path - Путь для проверки
|
|
6
|
+
* @param [expected] - Ожидаемый тип: `"file"` (файл) или `"folder"` (папка)
|
|
7
|
+
* @param [strict=false] - Если `true`, выбрасывает ошибку, если путь не существует
|
|
8
|
+
*
|
|
9
|
+
* @returns {@link Stats}, если путь существует и соответствует ожидаемому типу (если указан). Иначе возвращает `null`, если `strict = false`
|
|
10
|
+
* @throws {Error} Если `strict = true` и путь не существует или не соответствует ожидаемому типу
|
|
11
|
+
*/
|
|
12
|
+
declare function exists(path: PathLike, expected?: "file" | "folder", strict?: boolean): Promise<Stats | null>;
|
|
13
|
+
declare function exists(path: PathLike, expected: "file" | "folder" | undefined, strict: true): Promise<Stats>;
|
|
14
|
+
export { exists };
|
package/dist/explorer.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { stat } from "node:fs/promises";
|
|
2
|
+
async function exists(path, expected, strict = false) {
|
|
3
|
+
let existed;
|
|
4
|
+
try {
|
|
5
|
+
existed = await stat(path);
|
|
6
|
+
}
|
|
7
|
+
catch {
|
|
8
|
+
if (strict) {
|
|
9
|
+
throw new Error(`Путь "${path}" не существует или к нему нет доступа`);
|
|
10
|
+
}
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
if (expected === "file" && existed.isDirectory()) {
|
|
14
|
+
throw new Error(`Ожидалось, что "${path}" будет файлом`);
|
|
15
|
+
}
|
|
16
|
+
else if (expected === "folder" && existed.isFile()) {
|
|
17
|
+
throw new Error(`Ожидалось, что "${path}" будет папкой`);
|
|
18
|
+
}
|
|
19
|
+
return existed;
|
|
20
|
+
}
|
|
21
|
+
export { exists };
|
package/dist/lens.d.ts
ADDED
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Режим работы линзы:
|
|
3
|
+
* - `"exclude"` (исключение)
|
|
4
|
+
* - `"include"` (включение)
|
|
5
|
+
*/
|
|
6
|
+
export type LensMode = "exclude" | "include";
|
|
7
|
+
export type LensSchema<O> = {
|
|
8
|
+
[K in keyof O]?: boolean;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Конфигурация для {@link Lens}
|
|
12
|
+
*/
|
|
13
|
+
export interface LensConfig<O> {
|
|
14
|
+
/**
|
|
15
|
+
* Режим работы линзы {@link LensMode}
|
|
16
|
+
*
|
|
17
|
+
* @default "exclude"
|
|
18
|
+
*/
|
|
19
|
+
mode?: LensMode;
|
|
20
|
+
/**
|
|
21
|
+
* Схема, определяющая, какие ключи включить или исключить
|
|
22
|
+
*
|
|
23
|
+
* @default {}
|
|
24
|
+
*/
|
|
25
|
+
schema?: LensSchema<O>;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Линза для фильтрации на основе схемы и режима
|
|
29
|
+
*
|
|
30
|
+
* @template O - Тип объект для схемы, с которой работает линза
|
|
31
|
+
*/
|
|
32
|
+
export declare class Lens<O> {
|
|
33
|
+
/**
|
|
34
|
+
* Режим работы линзы {@link LensMode}
|
|
35
|
+
*
|
|
36
|
+
* @default "exclude"
|
|
37
|
+
*/
|
|
38
|
+
_mode: LensMode;
|
|
39
|
+
/**
|
|
40
|
+
* Схема, определяющая, какие ключи включить или исключить
|
|
41
|
+
*
|
|
42
|
+
* @default {}
|
|
43
|
+
*/
|
|
44
|
+
_schema: LensSchema<O>;
|
|
45
|
+
/**
|
|
46
|
+
* Создаёт экземпляр линзы
|
|
47
|
+
*
|
|
48
|
+
* @param config - Конфигурация линзы {@link LensConfig}
|
|
49
|
+
*/
|
|
50
|
+
constructor(config: LensConfig<O>);
|
|
51
|
+
/**
|
|
52
|
+
* Пересборка под другую конфигурацию
|
|
53
|
+
*
|
|
54
|
+
* @param config - Конфигурация линзы {@link LensConfig}
|
|
55
|
+
*/
|
|
56
|
+
reconstruct(config: LensConfig<O>): void;
|
|
57
|
+
/**
|
|
58
|
+
* Проверяет, должен ли ключ быть включён в результат
|
|
59
|
+
*
|
|
60
|
+
* @param key - Ключ для проверки
|
|
61
|
+
* @returns `true`, если ключ должен быть включён, иначе `false`
|
|
62
|
+
*/
|
|
63
|
+
get(key: keyof O): boolean;
|
|
64
|
+
}
|
package/dist/lens.js
ADDED
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Линза для фильтрации на основе схемы и режима
|
|
3
|
+
*
|
|
4
|
+
* @template O - Тип объект для схемы, с которой работает линза
|
|
5
|
+
*/
|
|
6
|
+
export class Lens {
|
|
7
|
+
/**
|
|
8
|
+
* Режим работы линзы {@link LensMode}
|
|
9
|
+
*
|
|
10
|
+
* @default "exclude"
|
|
11
|
+
*/
|
|
12
|
+
_mode;
|
|
13
|
+
/**
|
|
14
|
+
* Схема, определяющая, какие ключи включить или исключить
|
|
15
|
+
*
|
|
16
|
+
* @default {}
|
|
17
|
+
*/
|
|
18
|
+
_schema;
|
|
19
|
+
/**
|
|
20
|
+
* Создаёт экземпляр линзы
|
|
21
|
+
*
|
|
22
|
+
* @param config - Конфигурация линзы {@link LensConfig}
|
|
23
|
+
*/
|
|
24
|
+
constructor(config) {
|
|
25
|
+
this.reconstruct(config);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Пересборка под другую конфигурацию
|
|
29
|
+
*
|
|
30
|
+
* @param config - Конфигурация линзы {@link LensConfig}
|
|
31
|
+
*/
|
|
32
|
+
reconstruct(config) {
|
|
33
|
+
this._mode = config.mode ?? "exclude";
|
|
34
|
+
this._schema = config.schema ?? {};
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Проверяет, должен ли ключ быть включён в результат
|
|
38
|
+
*
|
|
39
|
+
* @param key - Ключ для проверки
|
|
40
|
+
* @returns `true`, если ключ должен быть включён, иначе `false`
|
|
41
|
+
*/
|
|
42
|
+
get(key) {
|
|
43
|
+
if (this._mode === "exclude") {
|
|
44
|
+
// Если в конфиге есть ключ в режиме исключения, то key false. Если нет — то true
|
|
45
|
+
return !this._schema[key];
|
|
46
|
+
}
|
|
47
|
+
// Если в конфиге есть ключ, то key true. Если нет — то false
|
|
48
|
+
return !!this._schema[key];
|
|
49
|
+
}
|
|
50
|
+
}
|
package/dist/script.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ищет значение флага в массиве аргументов процесса
|
|
3
|
+
*
|
|
4
|
+
* @param cmd - Команда, которой скрипт был запущен (`process.argv`)
|
|
5
|
+
* @param name - Имя флага, который нужно найти
|
|
6
|
+
* @param [strict=true] - Если `true`, выбрасывает ошибку, если флаг не найден. Если `false`, возвращает `null`
|
|
7
|
+
*
|
|
8
|
+
* @returns Значение флага (или `null`, если флаг не найден и `strict = false`)
|
|
9
|
+
* @throws {Error} Если `strict = true` и флаг не найден
|
|
10
|
+
*/
|
|
11
|
+
declare function getProcessFlag(cmd: string[], name: string, strict: boolean): string | null;
|
|
12
|
+
declare function getProcessFlag(cmd: string[], name: string, strict?: true): string;
|
|
13
|
+
export { getProcessFlag };
|
package/dist/script.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
function getProcessFlag(cmd, name, strict = true) {
|
|
2
|
+
const argv = cmd.slice(2);
|
|
3
|
+
const index = argv.indexOf(name);
|
|
4
|
+
if (index > -1) {
|
|
5
|
+
const value = argv[index + 1];
|
|
6
|
+
if (value)
|
|
7
|
+
return value;
|
|
8
|
+
}
|
|
9
|
+
if (strict) {
|
|
10
|
+
throw new Error(`Флаг "${name}" не найден`);
|
|
11
|
+
}
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
export { getProcessFlag };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nemigo/helpers",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.7",
|
|
4
4
|
"private": false,
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Vlad Logvin",
|
|
@@ -12,13 +12,28 @@
|
|
|
12
12
|
"check": "tsc --noemit",
|
|
13
13
|
"lint": "eslint ./",
|
|
14
14
|
"test": "vitest --run",
|
|
15
|
-
"format": "prettier --write ./"
|
|
16
|
-
"publish": "npm publish"
|
|
15
|
+
"format": "prettier --write ./"
|
|
17
16
|
},
|
|
18
17
|
"exports": {
|
|
18
|
+
"./explorer": {
|
|
19
|
+
"types": "./dist/explorer.d.ts",
|
|
20
|
+
"default": "./dist/explorer.js"
|
|
21
|
+
},
|
|
22
|
+
"./lens": {
|
|
23
|
+
"types": "./dist/lens.d.ts",
|
|
24
|
+
"default": "./dist/lens.js"
|
|
25
|
+
},
|
|
19
26
|
"./msgpack": {
|
|
20
27
|
"types": "./dist/msgpack.d.ts",
|
|
21
28
|
"default": "./dist/msgpack.js"
|
|
29
|
+
},
|
|
30
|
+
"./random": {
|
|
31
|
+
"types": "./dist/random.d.ts",
|
|
32
|
+
"default": "./dist/random.js"
|
|
33
|
+
},
|
|
34
|
+
"./script": {
|
|
35
|
+
"types": "./dist/script.d.ts",
|
|
36
|
+
"default": "./dist/script.js"
|
|
22
37
|
}
|
|
23
38
|
},
|
|
24
39
|
"dependencies": {
|