@nitra/cursor 3.18.1 → 3.19.0
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/CHANGELOG.md +12 -0
- package/package.json +1 -1
- package/rules/image-compress/meta.json +1 -1
- package/rules/npm-module/js/package_structure.mjs +40 -9
- package/rules/npm-module/npm-module.mdc +2 -0
- package/rules/npm-module/policy/npm_publish_yml/npm_publish_yml.rego +2 -2
- package/rules/npm-module/policy/npm_publish_yml/template/npm-publish.yml.snippet.yml +14 -3
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [3.19.0] - 2026-06-03
|
|
4
|
+
|
|
5
|
+
### Changed
|
|
6
|
+
|
|
7
|
+
- image-compress переведено на glob-активацію (**/*.{png,jpg,jpeg,gif,svg}) замість залежності від bun — у проєктах без растрів/SVG правило більше не додається автоматично; globToRegex отримав підтримку brace-альтернатив {a,b,c}
|
|
8
|
+
|
|
9
|
+
## [3.18.2] - 2026-06-03
|
|
10
|
+
|
|
11
|
+
### Changed
|
|
12
|
+
|
|
13
|
+
- npm-publish.yml канон: workflow робить release+publish одним job (release-publish) — крок n-cursor release перед публікацією, contents: write + persist-credentials. Оновлено template, rego-референси та тести.
|
|
14
|
+
|
|
3
15
|
## [3.18.1] - 2026-06-03
|
|
4
16
|
|
|
5
17
|
### Fixed
|
package/package.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{ "auto":
|
|
1
|
+
{ "auto": { "glob": "**/*.{png,jpg,jpeg,gif,svg}" } }
|
|
@@ -224,11 +224,11 @@ function checkPublishWorkflow(passFn, failFn, cwd) {
|
|
|
224
224
|
}
|
|
225
225
|
|
|
226
226
|
/**
|
|
227
|
-
* Перетворює glob-патерн (як у npm `files`) у `RegExp`
|
|
228
|
-
* Підтримує globstar (нуль або більше сегментів), `*`
|
|
229
|
-
* (один символ без `/`)
|
|
230
|
-
*
|
|
231
|
-
*
|
|
227
|
+
* Перетворює glob-патерн (як у npm `files` чи `meta.json:auto.glob`) у `RegExp`
|
|
228
|
+
* з якорями `^` / `$`. Підтримує globstar (нуль або більше сегментів), `*`
|
|
229
|
+
* (символи без `/`), `?` (один символ без `/`) і brace-альтернативи `{a,b,c}`
|
|
230
|
+
* (наприклад `*.{png,jpg,svg}` → `(?:png|jpg|svg)`). Клас `[…]` не
|
|
231
|
+
* підтримується — у негативних патернах `files` цього достатньо.
|
|
232
232
|
* @param {string} glob posix-шлях у glob-нотації
|
|
233
233
|
* @returns {RegExp} `RegExp` з якорями `^` / `$`
|
|
234
234
|
*/
|
|
@@ -237,11 +237,42 @@ export function globToRegex(glob) {
|
|
|
237
237
|
const tokens = parts.map(p => {
|
|
238
238
|
if (p === '**') return '__GLOBSTAR__'
|
|
239
239
|
let out = ''
|
|
240
|
+
let braceDepth = 0
|
|
240
241
|
for (const c of p) {
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
242
|
+
switch (c) {
|
|
243
|
+
case '*': {
|
|
244
|
+
out += '[^/]*'
|
|
245
|
+
continue
|
|
246
|
+
}
|
|
247
|
+
case '?': {
|
|
248
|
+
out += '[^/]'
|
|
249
|
+
continue
|
|
250
|
+
}
|
|
251
|
+
case '{': {
|
|
252
|
+
out += '(?:'
|
|
253
|
+
braceDepth++
|
|
254
|
+
continue
|
|
255
|
+
}
|
|
256
|
+
case '}': {
|
|
257
|
+
if (braceDepth > 0) {
|
|
258
|
+
out += ')'
|
|
259
|
+
braceDepth--
|
|
260
|
+
continue
|
|
261
|
+
}
|
|
262
|
+
break
|
|
263
|
+
}
|
|
264
|
+
case ',': {
|
|
265
|
+
if (braceDepth > 0) {
|
|
266
|
+
out += '|'
|
|
267
|
+
continue
|
|
268
|
+
}
|
|
269
|
+
break
|
|
270
|
+
}
|
|
271
|
+
default: {
|
|
272
|
+
break
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
out += REGEX_SPECIAL_IN_GLOB.has(c) ? `\\${c}` : c
|
|
245
276
|
}
|
|
246
277
|
return out
|
|
247
278
|
})
|
|
@@ -65,6 +65,8 @@ bunx -p typescript tsc src/**/*.js --declaration --allowJs --emitDeclarationOnly
|
|
|
65
65
|
|
|
66
66
|
**`npm-publish.yml`:** push у **`main`**, **`on.push.paths`** з **`npm/**`**, **`JS-DevTools/npm-publish@v4.1.5`**, **`with.package: npm/package.json`**, **`permissions.id-token: write`** (OIDC на npm).
|
|
67
67
|
|
|
68
|
+
Workflow робить **release + publish** одним job (`release-publish`): крок **`Release (bump + CHANGELOG + tag)`** (`node npm/bin/n-cursor.js release` — агрегує change-файли, bump `version`, генерує секцію `CHANGELOG.md`, ставить git-тег) виконується **перед** публікацією. Тому потрібні **`permissions.contents: write`** і **`persist-credentials: true`** з **`fetch-depth: 0`** на `checkout` (release пушить commit-back версії та тег), а також локальний composite **`./.github/actions/setup-bun-deps`** і крок `Configure git identity`. Це узгоджено з **`n-changelog`**: `version`/`CHANGELOG.md` змінює лише `n-cursor release` у CI на `main`. Програмна перевірка (`npm_module.npm_publish_yml`) лишається subset-of — enforce-ить `on.push.paths`/`branches`, `id-token: write` і наявність publish-кроку; додаткові кроки (release, git identity) дозволені.
|
|
69
|
+
|
|
68
70
|
- Канон: [npm-publish.yml.snippet.yml](./policy/npm_publish_yml/template/npm-publish.yml.snippet.yml)
|
|
69
71
|
|
|
70
72
|
## Канонічні конфіги
|
|
@@ -22,11 +22,11 @@ expected_paths := {p | some p in data.template.snippet.on.push.paths}
|
|
|
22
22
|
|
|
23
23
|
expected_branches := {b | some b in data.template.snippet.on.push.branches}
|
|
24
24
|
|
|
25
|
-
expected_permissions := data.template.snippet.jobs
|
|
25
|
+
expected_permissions := data.template.snippet.jobs["release-publish"].permissions
|
|
26
26
|
|
|
27
27
|
# Required publish-step (за маркером): expected `with.package` value з template.
|
|
28
28
|
expected_publish_with_package := s.with.package if {
|
|
29
|
-
some s in data.template.snippet.jobs
|
|
29
|
+
some s in data.template.snippet.jobs["release-publish"].steps
|
|
30
30
|
contains(object.get(s, "uses", ""), publish_action_marker)
|
|
31
31
|
}
|
|
32
32
|
|
|
@@ -12,22 +12,33 @@ concurrency:
|
|
|
12
12
|
cancel-in-progress: true
|
|
13
13
|
|
|
14
14
|
jobs:
|
|
15
|
-
publish:
|
|
15
|
+
release-publish:
|
|
16
16
|
runs-on: ubuntu-latest
|
|
17
17
|
permissions:
|
|
18
|
-
contents:
|
|
18
|
+
contents: write # commit-back версії + git-тег
|
|
19
19
|
id-token: write # КРИТИЧНО для OIDC!
|
|
20
20
|
|
|
21
21
|
steps:
|
|
22
22
|
- uses: actions/checkout@v6
|
|
23
23
|
with:
|
|
24
|
-
persist-credentials:
|
|
24
|
+
persist-credentials: true # release пушить commit-back + тег
|
|
25
|
+
fetch-depth: 0
|
|
26
|
+
|
|
27
|
+
- uses: ./.github/actions/setup-bun-deps
|
|
25
28
|
|
|
26
29
|
- uses: actions/setup-node@v6
|
|
27
30
|
with:
|
|
28
31
|
node-version: '24' # includes npm@11.6.0
|
|
29
32
|
registry-url: 'https://registry.npmjs.org'
|
|
30
33
|
|
|
34
|
+
- name: Configure git identity
|
|
35
|
+
run: |
|
|
36
|
+
git config user.name "github-actions[bot]"
|
|
37
|
+
git config user.email "github-actions[bot]@users.noreply.github.com"
|
|
38
|
+
|
|
39
|
+
- name: Release (bump + CHANGELOG + tag)
|
|
40
|
+
run: node npm/bin/n-cursor.js release
|
|
41
|
+
|
|
31
42
|
- name: Publish package
|
|
32
43
|
uses: JS-DevTools/npm-publish@v4.1.5
|
|
33
44
|
with:
|