@nitra/cursor 12.7.0 → 12.8.1
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/.pi-template/extensions/n-cursor-adr/docs/index.md +2 -2
- package/CHANGELOG.md +21 -5
- package/bin/n-cursor.js +1 -1
- package/docs/index.md +3 -3
- package/docs/stryker.config.md +3 -3
- package/lib/docs/index.md +5 -5
- package/lib/docs/llm.md +4 -4
- package/package.json +2 -2
- package/rules/abie/docs/fix.md +8 -8
- package/rules/abie/docs/index.md +3 -3
- package/rules/abie/js/docs/index.md +6 -6
- package/rules/abie/lib/docs/index.md +9 -9
- package/rules/bun/docs/fix.md +5 -5
- package/rules/bun/docs/index.md +3 -3
- package/rules/bun/js/docs/index.md +2 -2
- package/rules/capacitor/docs/fix.md +10 -10
- package/rules/capacitor/docs/index.md +3 -3
- package/rules/capacitor/js/docs/index.md +2 -2
- package/rules/changelog/docs/fix.md +11 -11
- package/rules/changelog/docs/index.md +3 -3
- package/rules/changelog/js/docs/consistency.md +12 -12
- package/rules/changelog/js/docs/index.md +2 -2
- package/rules/changelog/lib/docs/index.md +2 -2
- package/rules/ci4/docs/fix.md +4 -4
- package/rules/ci4/docs/index.md +3 -3
- package/rules/ci4/js/docs/index.md +2 -2
- package/rules/doc-files/docs/index.md +3 -3
- package/rules/doc-files/js/docgen-crc.mjs +2 -8
- package/rules/doc-files/js/docgen-extract.mjs +5 -3
- package/rules/doc-files/js/docgen-files-batch.mjs +18 -3
- package/rules/doc-files/js/docgen-gen.mjs +11 -3
- package/rules/doc-files/js/docgen-judge-measure.mjs +67 -18
- package/rules/doc-files/js/docgen-judge.mjs +8 -1
- package/rules/doc-files/js/docgen-scan.mjs +14 -4
- package/rules/doc-files/js/docs/docgen-crc.md +25 -14
- package/rules/doc-files/js/docs/docgen-extract.md +16 -14
- package/rules/doc-files/js/docs/docgen-files-batch.md +11 -11
- package/rules/doc-files/js/docs/docgen-gen.md +15 -26
- package/rules/doc-files/js/docs/docgen-judge-measure.md +14 -12
- package/rules/doc-files/js/docs/docgen-judge.md +13 -11
- package/rules/doc-files/js/docs/docgen-scan.md +28 -27
- package/rules/doc-files/js/docs/index.md +0 -1
- package/rules/docker/docs/fix.md +6 -6
- package/rules/docker/docs/index.md +3 -3
- package/rules/docker/js/docs/index.md +2 -2
- package/rules/docker/lib/docs/docker-hadolint.md +2 -2
- package/rules/docker/lib/docs/index.md +5 -5
- package/rules/efes/docs/fix.md +8 -8
- package/rules/efes/docs/index.md +3 -3
- package/rules/feedback/docs/fix.md +5 -5
- package/rules/feedback/docs/index.md +3 -3
- package/rules/ga/docs/fix.md +5 -5
- package/rules/ga/docs/index.md +3 -3
- package/rules/ga/js/docs/index.md +3 -3
- package/rules/graphql/docs/fix.md +8 -8
- package/rules/graphql/docs/index.md +3 -3
- package/rules/graphql/docs/main.md +8 -8
- package/rules/graphql/js/docs/index.md +2 -2
- package/rules/graphql/lib/docs/index.md +2 -2
- package/rules/hasura/docs/fix.md +11 -11
- package/rules/hasura/docs/index.md +3 -3
- package/rules/hasura/js/docs/index.md +2 -2
- package/rules/image-avif/docs/fix.md +3 -3
- package/rules/image-avif/docs/index.md +3 -3
- package/rules/image-avif/js/docs/avif_generation.md +6 -6
- package/rules/image-avif/js/docs/index.md +2 -2
- package/rules/image-compress/docs/fix.md +2 -2
- package/rules/image-compress/docs/index.md +3 -3
- package/rules/image-compress/js/docs/index.md +3 -3
- package/rules/{js-lint → js}/docs/fix.md +9 -9
- package/rules/{js-lint → js}/docs/index.md +3 -3
- package/rules/{js-lint → js}/js/docs/check.md +5 -5
- package/rules/{js-lint → js}/js/docs/index.md +4 -4
- package/rules/js-bun-db/docs/fix.md +5 -5
- package/rules/js-bun-db/docs/index.md +3 -3
- package/rules/js-bun-db/js/docs/index.md +2 -2
- package/rules/js-bun-db/lib/docs/index.md +2 -2
- package/rules/js-bun-redis/docs/fix.md +6 -6
- package/rules/js-bun-redis/docs/index.md +3 -3
- package/rules/js-bun-redis/js/docs/index.md +2 -2
- package/rules/js-bun-redis/lib/docs/index.md +2 -2
- package/rules/js-lint-ci/docs/fix.md +3 -3
- package/rules/js-lint-ci/docs/index.md +3 -3
- package/rules/js-lint-ci/js/docs/index.md +2 -2
- package/rules/js-mssql/docs/fix.md +5 -5
- package/rules/js-mssql/docs/index.md +3 -3
- package/rules/js-mssql/js/docs/index.md +2 -2
- package/rules/js-mssql/lib/docs/index.md +2 -2
- package/rules/js-run/docs/fix.md +8 -8
- package/rules/js-run/docs/index.md +3 -3
- package/rules/js-run/js/docs/index.md +2 -2
- package/rules/js-run/lib/docs/index.md +7 -7
- package/rules/k8s/docs/fix.md +4 -4
- package/rules/k8s/docs/index.md +3 -3
- package/rules/k8s/js/docs/index.md +3 -3
- package/rules/nginx-default-tpl/docs/fix.md +7 -7
- package/rules/nginx-default-tpl/docs/index.md +3 -3
- package/rules/nginx-default-tpl/js/docs/index.md +2 -2
- package/rules/nginx-default-tpl/js/docs/template.md +2 -2
- package/rules/npm-module/docs/fix.md +8 -8
- package/rules/npm-module/docs/index.md +3 -3
- package/rules/npm-module/js/docs/header_doc_pointer.md +23 -13
- package/rules/npm-module/js/docs/index.md +5 -5
- package/rules/npm-module/js/docs/rule_meta.md +6 -6
- package/rules/npm-module/js/header_doc_pointer.mjs +1 -3
- package/rules/php/docs/fix.md +6 -6
- package/rules/php/docs/index.md +3 -3
- package/rules/php/js/docs/index.md +3 -3
- package/rules/python/docs/fix.md +11 -11
- package/rules/python/docs/index.md +3 -3
- package/rules/python/docs/main.md +10 -10
- package/rules/python/js/docs/index.md +3 -3
- package/rules/python/main.mjs +2 -1
- package/rules/rego/docs/fix.md +5 -5
- package/rules/rego/docs/index.md +3 -3
- package/rules/rego/js/docs/index.md +3 -3
- package/rules/release/docs/index.md +5 -5
- package/rules/release/lib/docs/index.md +4 -4
- package/rules/rust/docs/fix.md +4 -4
- package/rules/rust/docs/index.md +3 -3
- package/rules/rust/docs/main.md +7 -7
- package/rules/rust/js/docs/index.md +3 -3
- package/rules/rust/lib/docs/index.md +2 -2
- package/rules/rust/main.mjs +7 -1
- package/rules/security/docs/fix.md +6 -6
- package/rules/security/docs/index.md +3 -3
- package/rules/security/js/docs/index.md +4 -4
- package/rules/style-lint/docs/fix.md +3 -3
- package/rules/style-lint/docs/index.md +3 -3
- package/rules/style-lint/js/docs/index.md +3 -3
- package/rules/tauri/docs/fix.md +11 -11
- package/rules/tauri/docs/index.md +3 -3
- package/rules/tauri/js/docs/index.md +3 -3
- package/rules/test/docs/fix.md +5 -5
- package/rules/test/docs/index.md +3 -3
- package/rules/test/js/data/stryker_config/docs/index.md +4 -4
- package/rules/test/js/data/vitest_config/docs/index.md +2 -2
- package/rules/test/js/docs/index.md +7 -7
- package/rules/text/docs/fix.md +11 -11
- package/rules/text/docs/index.md +3 -3
- package/rules/text/docs/main.md +8 -8
- package/rules/text/js/cspell-fix.mjs +7 -2
- package/rules/text/js/docs/cspell-fix.md +8 -8
- package/rules/text/js/docs/index.md +7 -8
- package/rules/text/js/docs/run-v8r.md +3 -3
- package/rules/text/main.mjs +3 -1
- package/rules/tool-surface/docs/index.md +3 -3
- package/rules/tool-surface/meta.json +6 -1
- package/rules/vue/docs/fix.md +6 -6
- package/rules/vue/docs/index.md +3 -3
- package/rules/vue/js/docs/index.md +2 -2
- package/rules/vue/lib/docs/index.md +2 -2
- package/rules/worktree/docs/fix.md +11 -11
- package/rules/worktree/docs/index.md +3 -3
- package/scripts/coverage-classify/docs/index.md +6 -6
- package/scripts/dispatcher/docs/index.md +2 -2
- package/scripts/docs/index.md +16 -16
- package/scripts/lib/docs/index.md +36 -36
- package/scripts/lib/docs/run-lint.md +7 -7
- package/scripts/lib/docs/run-standard-lint.md +7 -5
- package/scripts/lib/fix/analyze-escalation.mjs +4 -1
- package/scripts/lib/fix/docs/analyze-escalation.md +28 -15
- package/scripts/lib/fix/docs/index.md +10 -10
- package/scripts/lib/fix/docs/orchestrator.md +14 -15
- package/scripts/lib/fix/docs/run-conformance-check.md +4 -3
- package/scripts/lib/fix/docs/run-fix-check.md +3 -3
- package/scripts/lib/fix/docs/t0.md +8 -7
- package/scripts/lib/fix/orchestrator.mjs +26 -3
- package/scripts/lib/fix/t0.mjs +4 -1
- package/scripts/lib/run-lint.mjs +1 -3
- package/scripts/utils/docs/index.md +14 -14
- package/skills/doc-aggregate/js/docs/index.md +3 -3
- package/skills/doc-files/.changes/260612-0002.md +1 -0
- package/skills/doc-files/.changes/260612-0006.md +1 -0
- package/skills/doc-files/.changes/260612-0008.md +1 -0
- package/skills/doc-files/.changes/260612-0012.md +1 -0
- package/skills/doc-files/.changes/260612-0031.md +1 -0
- package/skills/doc-files/.changes/260612-0036.md +1 -0
- package/skills/doc-files/.changes/260612-0114.md +1 -0
- package/skills/start-check/js/docs/index.md +2 -2
- package/skills/taze/js/docs/index.md +2 -2
- package/types/bin/n-cursor.d.ts +1 -1
- /package/rules/{js-lint → js}/coverage/coverage.mjs +0 -0
- /package/rules/{js-lint → js}/docs/main.md +0 -0
- /package/rules/{js-lint → js}/js/check.mjs +0 -0
- /package/rules/{js-lint → js}/js/data/tooling/knip-canonical.json +0 -0
- /package/rules/{js-lint → js}/js/data/tooling/oxlint-canonical.json +0 -0
- /package/rules/{js-lint → js}/js/docs/lint-findings.md +0 -0
- /package/rules/{js-lint → js}/js/docs/tooling.md +0 -0
- /package/rules/{js-lint → js}/js/docs/utils_imports.md +0 -0
- /package/rules/{js-lint → js}/js/lint-findings.mjs +0 -0
- /package/rules/{js-lint → js}/js/tooling.mjs +0 -0
- /package/rules/{js-lint → js}/js/utils_imports.mjs +0 -0
- /package/rules/{js-lint/js-lint.mdc → js/js.mdc} +0 -0
- /package/rules/{js-lint → js}/main.mjs +0 -0
- /package/rules/{js-lint → js}/meta.json +0 -0
- /package/rules/{js-lint → js}/policy/jscpd/jscpd.rego +0 -0
- /package/rules/{js-lint → js}/policy/jscpd/target.json +0 -0
- /package/rules/{js-lint → js}/policy/jscpd/template/.jscpd.json.snippet.json +0 -0
- /package/rules/{js-lint → js}/policy/lint_js_yml/lint_js_yml.rego +0 -0
- /package/rules/{js-lint → js}/policy/lint_js_yml/target.json +0 -0
- /package/rules/{js-lint → js}/policy/lint_js_yml/template/lint-js.yml.snippet.yml +0 -0
- /package/rules/{js-lint → js}/policy/package_json/package_json.rego +0 -0
- /package/rules/{js-lint → js}/policy/package_json/target.json +0 -0
- /package/rules/{js-lint → js}/policy/package_json/template/package.json.snippet.json +0 -0
- /package/rules/{js-lint → js}/policy/vscode_extensions/target.json +0 -0
- /package/rules/{js-lint → js}/policy/vscode_extensions/template/extensions.json.snippet.json +0 -0
- /package/rules/{js-lint → js}/policy/vscode_extensions/vscode_extensions.rego +0 -0
|
@@ -6,8 +6,8 @@ resource: npm/rules/release/lib/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/release/lib
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [aggregate.mjs](aggregate.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| --------------------------------- | --------- |
|
|
11
|
+
| [aggregate.mjs](aggregate.md) | JS Module |
|
|
12
12
|
| [change-file.mjs](change-file.md) | JS Module |
|
|
13
|
-
| [fallback.mjs](fallback.md)
|
|
13
|
+
| [fallback.mjs](fallback.md) | JS Module |
|
package/rules/rust/docs/fix.md
CHANGED
|
@@ -13,12 +13,12 @@ docgen:
|
|
|
13
13
|
## Поведінка
|
|
14
14
|
|
|
15
15
|
1. Запуск правила.
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
- Виклик runStandardRule з контекстом.
|
|
17
|
+
- Повернення результату.
|
|
18
18
|
|
|
19
19
|
2. Запуск у режимі CLI.
|
|
20
|
-
|
|
21
|
-
|
|
20
|
+
- Виклик runRuleCli з директорією.
|
|
21
|
+
- Вихід з процесом залежно від результату.
|
|
22
22
|
|
|
23
23
|
## Публічний API
|
|
24
24
|
|
package/rules/rust/docs/index.md
CHANGED
package/rules/rust/docs/main.md
CHANGED
|
@@ -3,24 +3,24 @@ type: JS Module
|
|
|
3
3
|
title: main.mjs
|
|
4
4
|
resource: npm/rules/rust/main.mjs
|
|
5
5
|
docgen:
|
|
6
|
-
crc:
|
|
6
|
+
crc: 93c44fd7
|
|
7
7
|
model: omlx/gemma-4-e4b-it-OptiQ-4bit
|
|
8
|
-
score:
|
|
8
|
+
score: 100
|
|
9
9
|
---
|
|
10
10
|
|
|
11
11
|
## Огляд
|
|
12
12
|
|
|
13
|
-
Модуль надає
|
|
13
|
+
Модуль надає інструменти для забезпечення якості коду Rust. Він дозволяє виконати перевірку коду на відповідність заданим Lint-правилам або запустити повну оркестрацію форматування та аналізу коду через `cargo`. Функціонал реалізується через публічні функції `run` та `lint`.
|
|
14
14
|
|
|
15
15
|
## Поведінка
|
|
16
16
|
|
|
17
|
-
run виконує перевірку коду Rust
|
|
18
|
-
lint запускає оркестрацію перевірки Rust,
|
|
17
|
+
run виконує перевірку коду Rust відповідно до політик.
|
|
18
|
+
lint запускає оркестрацію перевірки коду Rust, використовуючи `cargo` для виконання `rustfmt` та `clippy`.
|
|
19
19
|
|
|
20
20
|
## Публічний API
|
|
21
21
|
|
|
22
|
-
run —
|
|
23
|
-
lint —
|
|
22
|
+
run — виконує основну логіку правила, включаючи перевірку аспектів застосування, логіки та посилань.
|
|
23
|
+
lint — забезпечує точку входу для статичного аналізу коду Rust.
|
|
24
24
|
|
|
25
25
|
## Гарантії поведінки
|
|
26
26
|
|
|
@@ -6,7 +6,7 @@ resource: npm/rules/rust/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/rust/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ------------------------- | --------- |
|
|
11
11
|
| [applies.mjs](applies.md) | JS Module |
|
|
12
|
-
| [lint.mjs](lint.md)
|
|
12
|
+
| [lint.mjs](lint.md) | JS Module |
|
package/rules/rust/main.mjs
CHANGED
|
@@ -75,7 +75,13 @@ function runRustLint(cwd = process.cwd(), opts = {}) {
|
|
|
75
75
|
if (!runCargo('cargo clippy --fix', cargo, fixArgs, pass, fail)) return reporter.getExitCode()
|
|
76
76
|
}
|
|
77
77
|
|
|
78
|
-
runCargo(
|
|
78
|
+
runCargo(
|
|
79
|
+
'cargo clippy -D warnings',
|
|
80
|
+
cargo,
|
|
81
|
+
['clippy', '--all-targets', '--all-features', '--', '-D', 'warnings'],
|
|
82
|
+
pass,
|
|
83
|
+
fail
|
|
84
|
+
)
|
|
79
85
|
return reporter.getExitCode()
|
|
80
86
|
}
|
|
81
87
|
|
|
@@ -12,14 +12,14 @@ docgen:
|
|
|
12
12
|
## Поведінка
|
|
13
13
|
|
|
14
14
|
1. Запуск правила.
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
- Передача контексту прогону.
|
|
16
|
+
- Виклик `runStandardRule` з використанням шляху модуля.
|
|
17
17
|
2. Виконання правила.
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
- Виклик `runStandardRule` з контекстом.
|
|
19
|
+
- Виконання операції `applies → JS-concerns → policy → mdc-refs`.
|
|
20
20
|
3. Вихід з CLI.
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
- Перевірка режиму запуску через `isRunAsCli`.
|
|
22
|
+
- Якщо запущено через CLI, повернення коду виходу з `runRuleCli` для встановлення `process.exitCode`.
|
|
23
23
|
|
|
24
24
|
## Публічний API
|
|
25
25
|
|
|
@@ -6,8 +6,8 @@ resource: npm/rules/security/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/security/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [lint.mjs](lint.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ------------------------------------- | --------- |
|
|
11
|
+
| [lint.mjs](lint.md) | JS Module |
|
|
12
12
|
| [sample_secret.mjs](sample_secret.md) | JS Module |
|
|
13
|
-
| [trufflehog.mjs](trufflehog.md)
|
|
13
|
+
| [trufflehog.mjs](trufflehog.md) | JS Module |
|
|
@@ -6,7 +6,7 @@ resource: npm/rules/style-lint/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/style-lint/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [lint.mjs](lint.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ------------------------- | --------- |
|
|
11
|
+
| [lint.mjs](lint.md) | JS Module |
|
|
12
12
|
| [tooling.mjs](tooling.md) | JS Module |
|
package/rules/tauri/docs/fix.md
CHANGED
|
@@ -14,18 +14,18 @@ docgen:
|
|
|
14
14
|
## Поведінка
|
|
15
15
|
|
|
16
16
|
1. Запуск правила.
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
- Приймає контекст прогону.
|
|
18
|
+
- Виконує застосування JS-занепокоєних.
|
|
19
|
+
- Застосовує політику.
|
|
20
|
+
- Генерує посилання MDC.
|
|
21
|
+
- Повертає результат прогону.
|
|
22
22
|
2. Запуск правила у режимі CLI.
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
23
|
+
- Виконується як повний еквівалент команди `npx @nitra/cursor fix <id>`.
|
|
24
|
+
- Виконує завантаження конфігурації.
|
|
25
|
+
- Виконує перевірку дозволених записів.
|
|
26
|
+
- Генерує зведену інформацію.
|
|
27
|
+
- Виконує перевірку.
|
|
28
|
+
- Визначає код виходу процесу.
|
|
29
29
|
|
|
30
30
|
## Публічний API
|
|
31
31
|
|
|
@@ -6,7 +6,7 @@ resource: npm/rules/tauri/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/tauri/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| --------------------------------------------------- | --------- |
|
|
11
11
|
| [cargo_mutants_config.mjs](cargo_mutants_config.md) | JS Module |
|
|
12
|
-
| [tooling.mjs](tooling.md)
|
|
12
|
+
| [tooling.mjs](tooling.md) | JS Module |
|
package/rules/test/docs/fix.md
CHANGED
|
@@ -12,12 +12,12 @@ docgen:
|
|
|
12
12
|
## Поведінка
|
|
13
13
|
|
|
14
14
|
1. Запуск правила.
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
15
|
+
- Передача контексту прогону.
|
|
16
|
+
- Виклик `runStandardRule` з використанням шляху до модуля.
|
|
17
|
+
- Повернення результату.
|
|
18
18
|
2. Запуск у режимі CLI.
|
|
19
|
-
|
|
20
|
-
|
|
19
|
+
- Виклик `runRuleCli` з використанням шляху до модуля.
|
|
20
|
+
- Встановлення коду виходу процесу на результат.
|
|
21
21
|
|
|
22
22
|
## Публічний API
|
|
23
23
|
|
package/rules/test/docs/index.md
CHANGED
|
@@ -6,8 +6,8 @@ resource: npm/rules/test/js/data/stryker_config/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/test/js/data/stryker_config
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [stryker-vue-macros-ignorer.mjs](stryker-vue-macros-ignorer.md)
|
|
12
|
-
| [stryker.config.baseline.mjs](stryker.config.baseline.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ----------------------------------------------------------------- | --------- |
|
|
11
|
+
| [stryker-vue-macros-ignorer.mjs](stryker-vue-macros-ignorer.md) | JS Module |
|
|
12
|
+
| [stryker.config.baseline.mjs](stryker.config.baseline.md) | JS Module |
|
|
13
13
|
| [stryker.config.vue.baseline.mjs](stryker.config.vue.baseline.md) | JS Module |
|
|
@@ -6,6 +6,6 @@ resource: npm/rules/test/js/data/vitest_config/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/test/js/data/vitest_config
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ------------------------------------------------------ | --------- |
|
|
11
11
|
| [vitest.config.baseline.js](vitest.config.baseline.md) | JS Module |
|
|
@@ -6,11 +6,11 @@ resource: npm/rules/test/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/test/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [cargo_mutants_config.mjs](cargo_mutants_config.md)
|
|
12
|
-
| [location.mjs](location.md)
|
|
13
|
-
| [no-process-chdir.mjs](no-process-chdir.md)
|
|
14
|
-
| [no-relative-fs-path.mjs](no-relative-fs-path.md)
|
|
15
|
-
| [stryker_config.mjs](stryker_config.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ----------------------------------------------------------- | --------- |
|
|
11
|
+
| [cargo_mutants_config.mjs](cargo_mutants_config.md) | JS Module |
|
|
12
|
+
| [location.mjs](location.md) | JS Module |
|
|
13
|
+
| [no-process-chdir.mjs](no-process-chdir.md) | JS Module |
|
|
14
|
+
| [no-relative-fs-path.mjs](no-relative-fs-path.md) | JS Module |
|
|
15
|
+
| [stryker_config.mjs](stryker_config.md) | JS Module |
|
|
16
16
|
| [vitest-config-pool-forks.mjs](vitest-config-pool-forks.md) | JS Module |
|
package/rules/text/docs/fix.md
CHANGED
|
@@ -12,18 +12,18 @@ docgen:
|
|
|
12
12
|
## Поведінка
|
|
13
13
|
|
|
14
14
|
1. Запуск правила.
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
15
|
+
- Приймає контекст прогону.
|
|
16
|
+
- Виконує застосування JS-занепокоєних.
|
|
17
|
+
- Застосовує політику.
|
|
18
|
+
- Генерує посилання MDC.
|
|
19
|
+
- Повертає результат прогону.
|
|
20
20
|
2. Виконання у режимі CLI.
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
21
|
+
- Виконується як автономний скрипт.
|
|
22
|
+
- Виконує повний еквівалент команди `npx @nitra/cursor fix <id>`.
|
|
23
|
+
- Виконує завантаження конфігурації.
|
|
24
|
+
- Виконує перевірку дозволених записів.
|
|
25
|
+
- Генерує зведену інформацію.
|
|
26
|
+
- Визначає код виходу процесу.
|
|
27
27
|
|
|
28
28
|
## Публічний API
|
|
29
29
|
|
package/rules/text/docs/index.md
CHANGED
package/rules/text/docs/main.md
CHANGED
|
@@ -3,26 +3,26 @@ type: JS Module
|
|
|
3
3
|
title: main.mjs
|
|
4
4
|
resource: npm/rules/text/main.mjs
|
|
5
5
|
docgen:
|
|
6
|
-
crc:
|
|
6
|
+
crc: 8a0470de
|
|
7
7
|
model: omlx/gemma-4-e4b-it-OptiQ-4bit
|
|
8
8
|
score: 90
|
|
9
9
|
---
|
|
10
10
|
|
|
11
11
|
## Огляд
|
|
12
12
|
|
|
13
|
-
CLI
|
|
13
|
+
Цей модуль є CLI-обгорткою над канонічним `lint-text` (text.mdc) та викликається через `n-cursor lint text` (оркестраторний адаптер `lint`). Він автоматично встановлює необхідні інструменти (`shellcheck`, `dotenv-linter`) через `ensureTool` (brew/scoop/GitHub Release per-platform) та перевіряє наявність `patch` (для авто-фіксу shellcheck). Функція `runLintTextCli` послідовно виконує: 1) перевірку правопису з `@nitra/cspell-dict` (`cspell .`); 2) авто-фікс та фінальну перевірку `.sh` файлів (`shellcheck`); 3) авто-фікс та фінальну перевірку `.env*` файлів (`dotenv-linter`); 4) авто-фікс Markdown-документів (`markdownlint-cli2 --fix "**\/*.md" "**\/*.mdc"`); 5) schema-валідацію JSON/YAML/TOML через `v8r`. При першому ненульовому коді з ланцюжка повертається код виходу, і наступні кроки не запускаються. Конфігурації, на які спирається код: meta.json.
|
|
14
14
|
|
|
15
15
|
## Поведінка
|
|
16
16
|
|
|
17
|
-
run
|
|
18
|
-
runLintTextCli
|
|
19
|
-
lint
|
|
17
|
+
run виконує стандартну перевірку, використовуючи контекст прогону.
|
|
18
|
+
runLintTextCli виконує повний ланцюжок перевірок тексту (cspell, shellcheck, dotenv-linter, markdownlint, v8r), автоматично встановлюючи необхідні інструменти, і повертає код першого порушення.
|
|
19
|
+
lint делегує виклик `runLintTextCli` для виконання повного ланцюжка перевірок тексту.
|
|
20
20
|
|
|
21
21
|
## Публічний API
|
|
22
22
|
|
|
23
|
-
run —
|
|
24
|
-
runLintTextCli —
|
|
25
|
-
lint —
|
|
23
|
+
run — Основна точка входу правила, що виконує перевірку логіки (JS-занепокоєння $\rightarrow$ політика $\rightarrow$ маркування повідомлень).
|
|
24
|
+
runLintTextCli — Публічний інтерфейс командного рядка для лінтингу тексту, що серіалізує через блокування та усуває дублікати на основі стану Git.
|
|
25
|
+
lint — Координатор, що передає завдання лінтингу тексту до `runLintTextCli`.
|
|
26
26
|
|
|
27
27
|
## Гарантії поведінки
|
|
28
28
|
|
|
@@ -143,12 +143,17 @@ export function runCspellText(cwd = process.cwd(), readOnly = false, llmFix = fa
|
|
|
143
143
|
const words = unknownWords(first.out)
|
|
144
144
|
const batch = words.slice(0, MAX_CLASSIFY_WORDS)
|
|
145
145
|
if (words.length > MAX_CLASSIFY_WORDS) {
|
|
146
|
-
process.stdout.write(
|
|
146
|
+
process.stdout.write(
|
|
147
|
+
`ℹ️ cspell: класифікація перших ${MAX_CLASSIFY_WORDS}/${words.length} слів (решта — наступний прогін)\n`
|
|
148
|
+
)
|
|
147
149
|
}
|
|
148
150
|
|
|
149
151
|
let text
|
|
150
152
|
try {
|
|
151
|
-
text = callLlm([{ role: 'user', content: classifyPrompt(batch) }], model, {
|
|
153
|
+
text = callLlm([{ role: 'user', content: classifyPrompt(batch) }], model, {
|
|
154
|
+
caller: 'cspell-classify',
|
|
155
|
+
maxTokens: 4000
|
|
156
|
+
})
|
|
152
157
|
} catch (error) {
|
|
153
158
|
process.stdout.write(`⚠️ cspell: omlx-класифікація впала (${error.message}) — без авто-словника\n`)
|
|
154
159
|
process.stdout.write(first.out)
|
|
@@ -3,26 +3,26 @@ type: JS Module
|
|
|
3
3
|
title: cspell-fix.mjs
|
|
4
4
|
resource: npm/rules/text/js/cspell-fix.mjs
|
|
5
5
|
docgen:
|
|
6
|
-
crc:
|
|
6
|
+
crc: e00c233e
|
|
7
7
|
model: omlx/gemma-4-e4b-it-OptiQ-4bit
|
|
8
8
|
score: 100
|
|
9
9
|
---
|
|
10
10
|
|
|
11
11
|
## Огляд
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
Модуль інтегрує cspell у ланцюжку lint-text для класифікації невідомих слів згідно зі схемою docs/specs/2026-06-15-opportunistic-llm-fix-tier.md. Він виявляє невідомі слова, класифікує їх за допомогою LLM у межах omlx-класифікації. Валідні слова автоматично дописуються до `.cspell.json#words` (відповідно до конфігурацій .cspell.json та meta.json). Невалідні знахідки залишаються для ручного рев'ю. Процес є read-only (нуль мутацій), оскільки fix-режим не переписує файли, а лише класифікує знахідки. Після дописування словника виконується re-detect. Гейт-механізм гарантує, що cspell поверне ненульовий код, якщо нерозкласифіковані або потенційні одруки залишилися.
|
|
14
14
|
|
|
15
15
|
## Поведінка
|
|
16
16
|
|
|
17
|
-
unknownWords витягує унікальні
|
|
18
|
-
appendWordsToDict
|
|
19
|
-
runCspellText запускає cspell
|
|
17
|
+
unknownWords витягує унікальні «Unknown word» з виводу cspell.
|
|
18
|
+
appendWordsToDict дописує класифіковані валідні слова у `.cspell.json#words`, сортуючи та усуваючи дублікати.
|
|
19
|
+
runCspellText запускає cspell, класифікує знахідки за допомогою LLM (якщо `llmFix` встановлено), дописує валідні слова у словник та повторно запускає cspell для перевірки, повертаючи код виходу.
|
|
20
20
|
|
|
21
21
|
## Публічний API
|
|
22
22
|
|
|
23
|
-
unknownWords — Збирає унікальні слова, які не були знайдені у
|
|
24
|
-
appendWordsToDict — Додає зібрані слова до
|
|
25
|
-
runCspellText — Виконує перевірку тексту за допомогою cspell
|
|
23
|
+
unknownWords — Збирає унікальні слова, які не були знайдені у cspell.
|
|
24
|
+
appendWordsToDict — Додає зібрані слова до словника `.cspell.json` у відсортованому та унікальному вигляді.
|
|
25
|
+
runCspellText — Виконує перевірку тексту за допомогою cspell для формування словника за новою схемою.
|
|
26
26
|
|
|
27
27
|
## Гарантії поведінки
|
|
28
28
|
|
|
@@ -6,12 +6,11 @@ resource: npm/rules/text/js/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/text/js
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [cspell-fix.mjs](cspell-fix.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ----------------------------------------------- | --------- |
|
|
11
|
+
| [cspell-fix.mjs](cspell-fix.md) | JS Module |
|
|
12
12
|
| [forbidden-prettier.mjs](forbidden-prettier.md) | JS Module |
|
|
13
|
-
| [formatting.mjs](formatting.md)
|
|
14
|
-
| [
|
|
15
|
-
| [run-
|
|
16
|
-
| [run-
|
|
17
|
-
| [run-v8r.mjs](run-v8r.md) | JS Module |
|
|
13
|
+
| [formatting.mjs](formatting.md) | JS Module |
|
|
14
|
+
| [run-dotenv-linter.mjs](run-dotenv-linter.md) | JS Module |
|
|
15
|
+
| [run-shellcheck.mjs](run-shellcheck.md) | JS Module |
|
|
16
|
+
| [run-v8r.mjs](run-v8r.md) | JS Module |
|
|
@@ -20,9 +20,9 @@ runV8rWithGlobs — послідовно запускає перевірку к
|
|
|
20
20
|
|
|
21
21
|
## Публічний API
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
- DEFAULT_V8R_GLOBS — Містить стандартні шаблони для пошуку файлів, які обробляє v8r.
|
|
24
|
+
- V8R_CATALOG_PATH — Вказує на розташування файлу `v8r-catalog.json` у корені пакета.
|
|
25
|
+
- runV8rWithGlobs — Виконує послідовні запуски v8r для файлів, знайдених за шаблонами, повертаючи код завершення.
|
|
26
26
|
|
|
27
27
|
## Гарантії поведінки
|
|
28
28
|
|
package/rules/text/main.mjs
CHANGED
|
@@ -132,7 +132,9 @@ function runLintTextSteps(readOnly = false, llmFix = false) {
|
|
|
132
132
|
const dotenvCode = runDotenvLinter(process.cwd(), readOnly)
|
|
133
133
|
if (dotenvCode !== 0) return dotenvCode
|
|
134
134
|
|
|
135
|
-
const mdArgs = readOnly
|
|
135
|
+
const mdArgs = readOnly
|
|
136
|
+
? ['markdownlint-cli2', '**/*.md', '**/*.mdc']
|
|
137
|
+
: ['markdownlint-cli2', '--fix', '**/*.md', '**/*.mdc']
|
|
136
138
|
const markdownlintCode = runLintStep('markdownlint', 'bunx', mdArgs)
|
|
137
139
|
if (markdownlintCode !== 0) return markdownlintCode
|
|
138
140
|
|
|
@@ -6,7 +6,7 @@ resource: npm/rules/tool-surface/
|
|
|
6
6
|
|
|
7
7
|
# npm/rules/tool-surface
|
|
8
8
|
|
|
9
|
-
| Файл
|
|
10
|
-
|
|
11
|
-
| [fix.mjs](fix.md)
|
|
9
|
+
| Файл | Тип |
|
|
10
|
+
| ------------------- | --------- |
|
|
11
|
+
| [fix.mjs](fix.md) | JS Module |
|
|
12
12
|
| [main.mjs](main.md) | JS Module |
|
|
@@ -1 +1,6 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"auto": {
|
|
3
|
+
"predicate": "depInAnyPackageJson",
|
|
4
|
+
"arg": ["vue", "react", "svelte", "@angular/core", "preact", "solid-js", "@tauri-apps/api", "@capacitor/core"]
|
|
5
|
+
}
|
|
6
|
+
}
|
package/rules/vue/docs/fix.md
CHANGED
|
@@ -12,13 +12,13 @@ docgen:
|
|
|
12
12
|
## Поведінка
|
|
13
13
|
|
|
14
14
|
1. Запуск правила.
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
15
|
+
- Приймає контекст прогону.
|
|
16
|
+
- Використовує runStandardRule для застосування політики.
|
|
17
|
+
- Повертає результат прогону.
|
|
18
18
|
2. Запуск у режимі CLI.
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
- Викликається через `import + run`.
|
|
20
|
+
- Виконує повний еквівалент `npx @nitra/cursor fix <id>`.
|
|
21
|
+
- Визначає вихідний код процесу на основі результату.
|
|
22
22
|
|
|
23
23
|
## Публічний API
|
|
24
24
|
|
package/rules/vue/docs/index.md
CHANGED