leerness 1.9.130 → 1.9.131

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 CHANGED
@@ -1,5 +1,34 @@
1
1
  # Changelog
2
2
 
3
+ ## 1.9.131 — 2026-05-20
4
+
5
+ **brainstorm 회수 범위에 3 archive 파일 통합** — 과거에 제거됐던 ideas 가 새 brainstorm 시 다시 후보로 노출.
6
+
7
+ ### Added — brainstorm + archive 통합
8
+ - `hits.archive: { decisions: [], lessons: [], plan: [] }` 추가
9
+ - 3 archive 파일 (`.harness/decisions.archive.md`, `lessons.archive.md`, `plan.archive.md`) 본문 키워드 매칭
10
+ - entry 구조: `{ date, target, originalHeader, preview, line }`
11
+ - 텍스트 모드: `🗑 archive 후보 (N)` 섹션 + 복원 안내 라인
12
+ - `_brainstormFor` (helper) + `brainstormCmd` (CLI) 양쪽 동일 구현
13
+
14
+ ### 사용 시나리오
15
+ 사용자: `leerness brainstorm "PostgreSQL"`
16
+ → 응답에 과거 archive 후보 포함:
17
+ ```
18
+ 🗑 archive 후보 (2) — 과거에 제거됐던 ideas; 복원 검토 가능 (1.9.131)
19
+ - 🧠 .harness/decisions.archive.md:4 — 2026-05-20 "PostgreSQL"
20
+ - 💡 .harness/lessons.archive.md:4 — 2026-05-20 "PostgreSQL"
21
+ → 복원: leerness memory restore <decisions|lessons|plan> <target>
22
+ ```
23
+
24
+ ### brainstorm 누적 source 진화
25
+ | 라운드 | source |
26
+ |---|---|
27
+ | (기존) | decisions / skills / tasks / rules / evidence / lessons / code |
28
+ | 1.9.72 | skillHistory / taskLogFails |
29
+ | 1.9.116 | lessonsExplicit / planMilestones |
30
+ | **1.9.131** | **archive (decisions/lessons/plan)** |
31
+
3
32
  ## 1.9.130 — 2026-05-20 🎉 **60 라운드 자율 모드 마일스톤**
4
33
 
5
34
  **JSON 4종 통합에 `memorySurface.archive` 필드 추가** + 60 라운드 자율 누적 보고서.
package/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  > **AI 코딩 에이전트의 거짓 완료·중복·망각·충돌을 막아주는 검수·기억·협업 CLI 하네스.**
4
4
 
5
- [![npm](https://img.shields.io/badge/npm-leerness-blue)](https://www.npmjs.com/package/leerness) [![version](https://img.shields.io/badge/version-1.9.130-green)]() [![tests](https://img.shields.io/badge/e2e-219%2F219-success)]() [![mcp](https://img.shields.io/badge/MCP--tools-40_🎉-blue)]() [![json](https://img.shields.io/badge/--json-19_commands-blueviolet)]() [![rounds](https://img.shields.io/badge/autonomous--rounds-60_🎉-blueviolet)]() [![handoff](https://img.shields.io/badge/handoff--auto--recovery-7-blueviolet)]() [![license](https://img.shields.io/badge/license-MIT-lightgrey)]()
5
+ [![npm](https://img.shields.io/badge/npm-leerness-blue)](https://www.npmjs.com/package/leerness) [![version](https://img.shields.io/badge/version-1.9.131-green)]() [![tests](https://img.shields.io/badge/e2e-219%2F219-success)]() [![mcp](https://img.shields.io/badge/MCP--tools-40_🎉-blue)]() [![json](https://img.shields.io/badge/--json-19_commands-blueviolet)]() [![rounds](https://img.shields.io/badge/autonomous--rounds-61-blueviolet)]() [![brainstorm](https://img.shields.io/badge/brainstorm--sources-11-blueviolet)]() [![license](https://img.shields.io/badge/license-MIT-lightgrey)]()
6
6
 
7
7
  ```
8
8
  ╔══════════════════════════════════════════════════════════════╗
@@ -12,7 +12,7 @@
12
12
  ║ ██║ ██╔══╝ ██╔══╝ ██╔══██╗██║╚██╗██║██╔══╝ ╚════██║ ║
13
13
  ║ ███████╗███████╗███████╗██║ ██║██║ ╚████║███████╗███████║ ║
14
14
  ║ ╚══════╝╚══════╝╚══════╝╚═╝ ╚═╝╚═╝ ╚═══╝╚══════╝╚══════╝ ║
15
- ║ v1.9.130 AI Agent Reliability Harness ║
15
+ ║ v1.9.131 AI Agent Reliability Harness ║
16
16
  ║ verify · remember · orchestrate · audit · prevent drift ║
17
17
  ╚══════════════════════════════════════════════════════════════╝
18
18
  ```
package/bin/harness.js CHANGED
@@ -6,7 +6,7 @@ const path = require('path');
6
6
  const cp = require('child_process');
7
7
  const readline = require('readline');
8
8
 
9
- const VERSION = '1.9.130';
9
+ const VERSION = '1.9.131';
10
10
  const MARK = '<!-- leerness:managed -->';
11
11
  const README_START = '<!-- leerness:project-readme:start -->';
12
12
  const README_END = '<!-- leerness:project-readme:end -->';
@@ -331,6 +331,7 @@ leerness audit . --fix # 누락 메타 자동 보강
331
331
  - 1.9.128+ \`leerness memory restore <surface> <target>\` + MCP **40 도구 🎉** (\`leerness_memory_restore\`) — archive → active 복귀 (DELETE→RESTORE cycle 완성). **MCP 40 도구 마일스톤**.
332
332
  - 1.9.129+ handoff **7번째 자동 회수** — \`🗑 최근 24h archive\` (D/L/P 카운트 + 복원 후보 안내). DELETE 활동 자동 인지.
333
333
  - 1.9.130+ 🎉 **60 라운드 자율 모드 마일스톤** — JSON 4종 (handoff/memory status/session close/health) \`memorySurface.archive\` 필드 통합. MCP 40 / handoff auto-recovery 7 / DELETE-RESTORE cycle 완성.
334
+ - 1.9.131+ \`brainstorm\` 회수 범위에 3 archive 파일 (decisions/lessons/plan archive) 통합 — 과거 제거된 ideas 가 새 brainstorm 시 다시 후보로 노출. \`hits.archive\` 필드 + 복원 안내 라인.
334
335
 
335
336
  ---
336
337
 
@@ -4268,7 +4269,7 @@ function _banner(opts = {}) {
4268
4269
  lines.push('');
4269
4270
  for (const ln of lines) log(ln);
4270
4271
  if (opts.quickStart) {
4271
- log(C.bold(C.cyan(' ✨ 빠른 시작 (1.9.130+ 🎉 60 라운드 마일스톤 archive 필드 통합 — 60 라운드 자율 누적)')));
4272
+ log(C.bold(C.cyan(' ✨ 빠른 시작 (1.9.131+ brainstorm + archive 통합 — 61 라운드 자율 누적)')));
4272
4273
  log(' ' + C.green('npx leerness@latest init .') + C.dim(' # 신규 프로젝트 + 외부 AI CLI 설정'));
4273
4274
  log(' ' + C.green('npx leerness handoff .') + C.dim(' # 컨텍스트 + lessons + 매칭 skill + history hit + brainstorm hits + 헤드라인'));
4274
4275
  log(' ' + C.green('npx leerness handoff . --quiet') + C.dim(' # 자동화/CI 모드 (1.9.99) — 자동 회수 라인 비활성'));
@@ -5713,6 +5714,36 @@ function _brainstormFor(root, topic) {
5713
5714
  }
5714
5715
  }
5715
5716
  }
5717
+ // 1.9.131: 3 archive 파일 (decisions/lessons/plan) hits — DELETE 5종 archive 도 brainstorm 후보로
5718
+ // archived ideas 가 새 brainstorm 시점에 다시 후보로 노출 → "이전에 검토한 건데 다시 볼까?"
5719
+ hits.archive = { decisions: [], lessons: [], plan: [] };
5720
+ const archiveSources_bsFor = [
5721
+ { key: 'decisions', file: 'decisions.archive.md' },
5722
+ { key: 'lessons', file: 'lessons.archive.md' },
5723
+ { key: 'plan', file: 'plan.archive.md' }
5724
+ ];
5725
+ for (const src of archiveSources_bsFor) {
5726
+ const fp = path.join(root, '.harness', src.file);
5727
+ if (!exists(fp)) continue;
5728
+ const txt = read(fp);
5729
+ const blocks = txt.split(/\n(?=## 제거 )/);
5730
+ for (const b of blocks) {
5731
+ const m = b.match(/^## 제거 (\d{4}-\d{2}-\d{2})\s*\(target:\s*"([^"]*)"\)/);
5732
+ if (!m) continue;
5733
+ if (matches(b)) {
5734
+ const headerMatch = b.match(/^### (.+)$/m);
5735
+ const idx = txt.indexOf(b);
5736
+ const lineNo = idx >= 0 ? txt.slice(0, idx).split('\n').length : 0;
5737
+ hits.archive[src.key].push({
5738
+ date: m[1],
5739
+ target: m[2],
5740
+ originalHeader: headerMatch ? headerMatch[1].trim() : null,
5741
+ preview: b.slice(0, 220).replace(/\n+/g, ' '),
5742
+ line: lineNo
5743
+ });
5744
+ }
5745
+ }
5746
+ }
5716
5747
  // 1.9.25: --include-code 옵션 — 소스 본문 검색 추가 (모순 감지 핵심)
5717
5748
  if (has('--include-code')) {
5718
5749
  const codeDirs = ['src', 'tests', 'bin', 'lib'];
@@ -5908,6 +5939,35 @@ function brainstormCmd(root, topic) {
5908
5939
  }
5909
5940
  }
5910
5941
  }
5942
+ // 1.9.131: 3 archive 파일 hits (brainstormCmd 변종) — DELETE 5종 archive 도 brainstorm 후보로
5943
+ if (!hits.archive) hits.archive = { decisions: [], lessons: [], plan: [] };
5944
+ const archiveSources_bsCmd = [
5945
+ { key: 'decisions', file: 'decisions.archive.md' },
5946
+ { key: 'lessons', file: 'lessons.archive.md' },
5947
+ { key: 'plan', file: 'plan.archive.md' }
5948
+ ];
5949
+ for (const src of archiveSources_bsCmd) {
5950
+ const fp = path.join(root, '.harness', src.file);
5951
+ if (!exists(fp)) continue;
5952
+ const txt = read(fp);
5953
+ const blocks = txt.split(/\n(?=## 제거 )/);
5954
+ for (const b of blocks) {
5955
+ const m = b.match(/^## 제거 (\d{4}-\d{2}-\d{2})\s*\(target:\s*"([^"]*)"\)/);
5956
+ if (!m) continue;
5957
+ if (matches(b)) {
5958
+ const headerMatch = b.match(/^### (.+)$/m);
5959
+ const idx = txt.indexOf(b);
5960
+ const lineNo = idx >= 0 ? txt.slice(0, idx).split('\n').length : 0;
5961
+ hits.archive[src.key].push({
5962
+ date: m[1],
5963
+ target: m[2],
5964
+ originalHeader: headerMatch ? headerMatch[1].trim() : null,
5965
+ preview: b.slice(0, 220).replace(/\n+/g, ' '),
5966
+ line: lineNo
5967
+ });
5968
+ }
5969
+ }
5970
+ }
5911
5971
  // 1.9.116: lessons.md + plan.md milestone hits (Memory Surface 5종 완전 통합)
5912
5972
  if (!hits.lessonsExplicit) hits.lessonsExplicit = [];
5913
5973
  if (!hits.planMilestones) hits.planMilestones = [];
@@ -5976,6 +6036,22 @@ function brainstormCmd(root, topic) {
5976
6036
  log(`\n## 📜 task-log 실패 라인 (${hits.taskLogFails.length}) — 1.9.67 인덱스 + brainstorm`);
5977
6037
  hits.taskLogFails.slice(0, 5).forEach(t => log(` - .harness/task-log.md:${t.line || '?'} — ${t.title}`));
5978
6038
  }
6039
+ // 1.9.131: 3 archive 파일 hits — DELETE 5종 archive 도 brainstorm 후보
6040
+ if (hits.archive) {
6041
+ const archiveTotal = (hits.archive.decisions?.length || 0) + (hits.archive.lessons?.length || 0) + (hits.archive.plan?.length || 0);
6042
+ if (archiveTotal > 0) {
6043
+ log(`\n## 🗑 archive 후보 (${archiveTotal}) — 과거에 제거됐던 ideas; 복원 검토 가능 (1.9.131)`);
6044
+ for (const [key, label, emoji] of [['decisions', 'decisions.archive.md', '🧠'], ['lessons', 'lessons.archive.md', '💡'], ['plan', 'plan.archive.md', '🗺']]) {
6045
+ const items = hits.archive[key] || [];
6046
+ if (items.length) {
6047
+ for (const a of items.slice(0, 3)) {
6048
+ log(` - ${emoji} .harness/${label}:${a.line || '?'} — ${a.date} "${a.target}"${a.originalHeader ? ' (orig: ' + a.originalHeader.slice(0, 80) + ')' : ''}`);
6049
+ }
6050
+ }
6051
+ }
6052
+ log(` → 복원: leerness memory restore <decisions|lessons|plan> <target>`);
6053
+ }
6054
+ }
5979
6055
 
5980
6056
  log(`\n## 💡 시작 전 권장 액션`);
5981
6057
  log(` 1. 위 자원을 모두 검토 후 plan add 또는 task add로 새 작업 등록`);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "leerness",
3
- "version": "1.9.130",
3
+ "version": "1.9.131",
4
4
  "description": "Leerness: 비파괴 마이그레이션, 자동 버전 감지·업데이트, 계획/진행/핸드오프 자동화, 게으름·시크릿·인코딩 자동 가드, Claude Code 슬래시 통합을 갖춘 한국어 우선 AI 개발 하네스.",
5
5
  "keywords": [
6
6
  "leerness",