harnessed 3.9.12 → 3.9.13
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/cli.mjs +1 -8
- package/dist/cli.mjs.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/messages/zh-Hans.json +76 -76
- package/package.json +1 -1
package/dist/index.mjs
CHANGED
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../package.json","../src/index.ts"],"names":[],"mappings":";AAAA,IAAA,eAAA,GAAA;AAAA,EAEE,OAAA,EAAW,QAgGb,CAAA;;;AC7FO,IAAM,UAAU,eAAA,CAAI","file":"index.mjs","sourcesContent":["{\n \"name\": \"harnessed\",\n \"version\": \"3.9.
|
|
1
|
+
{"version":3,"sources":["../package.json","../src/index.ts"],"names":[],"mappings":";AAAA,IAAA,eAAA,GAAA;AAAA,EAEE,OAAA,EAAW,QAgGb,CAAA;;;AC7FO,IAAM,UAAU,eAAA,CAAI","file":"index.mjs","sourcesContent":["{\n \"name\": \"harnessed\",\n \"version\": \"3.9.13\",\n \"description\": \"AI coding harness package manager + composition orchestrator\",\n \"type\": \"module\",\n \"license\": \"Apache-2.0\",\n \"author\": \"easyinplay\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/easyinplay/harnessed.git\"\n },\n \"homepage\": \"https://github.com/easyinplay/harnessed#readme\",\n \"bugs\": \"https://github.com/easyinplay/harnessed/issues\",\n \"keywords\": [\n \"claude-code\",\n \"ai-harness\",\n \"package-manager\",\n \"composition\",\n \"skill-pack\",\n \"mcp\",\n \"orchestrator\"\n ],\n \"engines\": {\n \"node\": \">=22.0.0\"\n },\n \"packageManager\": \"pnpm@10.12.0\",\n \"bin\": {\n \"harnessed\": \"./dist/cli.mjs\"\n },\n \"main\": \"./dist/index.mjs\",\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.mjs\",\n \"default\": \"./dist/index.mjs\"\n },\n \"./schemas\": {\n \"types\": \"./dist/schemas/index.d.ts\",\n \"import\": \"./dist/schemas/index.mjs\"\n },\n \"./package.json\": \"./package.json\"\n },\n \"files\": [\n \"dist\",\n \"manifests\",\n \"messages\",\n \"workflows\",\n \"routing\",\n \"config-templates\",\n \"schemas\",\n \"README.md\",\n \"LICENSE\",\n \"NOTICE\",\n \"THIRD-PARTY-NOTICES.md\"\n ],\n \"scripts\": {\n \"dev\": \"tsup --watch\",\n \"build\": \"tsc --noEmit && tsup\",\n \"build:schema\": \"node ./scripts/build-schema.mjs\",\n \"validate:schema\": \"node ./scripts/validate-schema.mjs\",\n \"typecheck\": \"tsc --noEmit\",\n \"test\": \"vitest run --passWithNoTests\",\n \"test:watch\": \"vitest\",\n \"test:coverage\": \"vitest run --coverage --passWithNoTests\",\n \"bench\": \"vitest bench --run\",\n \"lint\": \"biome check .\",\n \"lint:fix\": \"biome check --write .\",\n \"format\": \"biome format --write .\"\n },\n \"dependencies\": {\n \"@anthropic-ai/claude-agent-sdk\": \"0.3.142\",\n \"@clack/prompts\": \"^0.10.1\",\n \"@sinclair/typebox\": \"^0.34.49\",\n \"ajv\": \"^8.20.0\",\n \"ajv-errors\": \"^3.0.0\",\n \"ajv-formats\": \"^3.0.1\",\n \"commander\": \"^13.0.0\",\n \"diff\": \"^9.0.0\",\n \"expr-eval\": \"^2.0.2\",\n \"picocolors\": \"^1.1.1\",\n \"proper-lockfile\": \"^4.1.2\",\n \"yaml\": \"^2.9.0\"\n },\n \"devDependencies\": {\n \"@biomejs/biome\": \"^2.0.0\",\n \"@types/node\": \"^22.10.0\",\n \"@types/proper-lockfile\": \"^4.1.4\",\n \"@vitest/coverage-v8\": \"^4.0.0\",\n \"tsup\": \"^8.3.0\",\n \"typescript\": \"^5.6.0\",\n \"vitest\": \"^4.0.0\"\n },\n \"pnpm\": {\n \"onlyBuiltDependencies\": [\n \"esbuild\"\n ]\n }\n}\n","// Main library entry — re-exports public APIs.\n// phase 1.1 batch 1: skeleton only; schema validator wired in batch 2 (T3+).\n\nimport pkg from '../package.json' with { type: 'json' }\n\nexport const VERSION = pkg.version\n"]}
|
package/messages/zh-Hans.json
CHANGED
|
@@ -1,92 +1,92 @@
|
|
|
1
1
|
{
|
|
2
|
-
"setup.workflows_not_found": "
|
|
3
|
-
"setup.nothing_to_install": "setup:
|
|
4
|
-
"setup.dry_run.header": "[dry-run] setup
|
|
5
|
-
"setup.dry_run.run_hint": "
|
|
6
|
-
"setup.copy_failed": "
|
|
7
|
-
"setup.step_a_complete": "
|
|
8
|
-
"setup.step_a_render.complete": "
|
|
9
|
-
"setup.step_a_render.warnings_header": "
|
|
10
|
-
"setup.step_c.created": "
|
|
11
|
-
"setup.step_c.already_enabled": "
|
|
12
|
-
"setup.step_c.enabled_backup": "
|
|
13
|
-
"setup.step_c.skipped": "
|
|
14
|
-
"setup.step_d.created": "
|
|
15
|
-
"setup.step_d.already_set": "
|
|
16
|
-
"setup.step_d.enabled_backup": "
|
|
17
|
-
"setup.step_d.skipped": "
|
|
18
|
-
"setup.step_b_complete": "
|
|
19
|
-
"setup.complete": "
|
|
20
|
-
"setup.mcp_hint": "
|
|
21
|
-
"setup.bundled_summary": "
|
|
22
|
-
"setup.bundled_location": "
|
|
23
|
-
"setup.doctor_hint": "
|
|
2
|
+
"setup.workflows_not_found": "error: workflows directory not found at {{path}}",
|
|
3
|
+
"setup.nothing_to_install": "setup: no workflow directories with SKILL.md found — nothing to install",
|
|
4
|
+
"setup.dry_run.header": "[dry-run] setup would install {{count}} workflow(s) to {{path}}:",
|
|
5
|
+
"setup.dry_run.run_hint": " run without --dry-run to execute",
|
|
6
|
+
"setup.copy_failed": " error: failed to copy {{name}}: {{message}}",
|
|
7
|
+
"setup.step_a_complete": "Step A: {{count}} workflows installed to {{path}}",
|
|
8
|
+
"setup.step_a_render.complete": "",
|
|
9
|
+
"setup.step_a_render.warnings_header": " warnings — some capability cmds could not be fully resolved:",
|
|
10
|
+
"setup.step_c.created": "",
|
|
11
|
+
"setup.step_c.already_enabled": "",
|
|
12
|
+
"setup.step_c.enabled_backup": "",
|
|
13
|
+
"setup.step_c.skipped": "",
|
|
14
|
+
"setup.step_d.created": "",
|
|
15
|
+
"setup.step_d.already_set": "",
|
|
16
|
+
"setup.step_d.enabled_backup": "",
|
|
17
|
+
"setup.step_d.skipped": "",
|
|
18
|
+
"setup.step_b_complete": "Upstream components: {{installed}} installed / {{already}} already-installed / {{skipped}} skipped / {{failed}} failed [{{seconds}}s]",
|
|
19
|
+
"setup.complete": "setup complete — {{skills}} workflows + {{manifests}} base manifests",
|
|
20
|
+
"setup.mcp_hint": "Run /mcp in Claude Code to verify MCP server connections.",
|
|
21
|
+
"setup.bundled_summary": "harnessed v3.0 — 23 workflows bundled (<packageRoot>/workflows/)",
|
|
22
|
+
"setup.bundled_location": "",
|
|
23
|
+
"setup.doctor_hint": "Run harnessed doctor to verify your environment.",
|
|
24
24
|
|
|
25
|
-
"agent_teams.missing_header": "\n⚠️ Agent Teams
|
|
26
|
-
"agent_teams.missing_fix": "
|
|
27
|
-
"agent_teams.missing_explanation": "
|
|
28
|
-
"agent_teams.missing_nonblocking": "
|
|
25
|
+
"agent_teams.missing_header": "\n⚠️ Agent Teams not enabled — parallelism upgrade path unavailable",
|
|
26
|
+
"agent_teams.missing_fix": " fix: claude config set env.CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS 1",
|
|
27
|
+
"agent_teams.missing_explanation": " harnessed v3.0 task parallelism uses Subagent or Agent Teams (CC 2.1.133+)",
|
|
28
|
+
"agent_teams.missing_nonblocking": " non-blocking — auto-degrades to subagent fan-out\n",
|
|
29
29
|
|
|
30
|
-
"install.manifest_not_found": "
|
|
31
|
-
"install.manifest_not_found.fix": "
|
|
32
|
-
"install.audit_hint": "
|
|
33
|
-
"install.success": "
|
|
34
|
-
"install.success_with_version": "
|
|
35
|
-
"install.aborted": "
|
|
30
|
+
"install.manifest_not_found": "error: manifest '{{name}}' not found",
|
|
31
|
+
"install.manifest_not_found.fix": " fix: ensure manifests/tools/{{name}}.yaml or manifests/skill-packs/{{name}}.yaml exists",
|
|
32
|
+
"install.audit_hint": " fix: run 'harnessed audit' to inspect manifest issues",
|
|
33
|
+
"install.success": "installed {{name}}",
|
|
34
|
+
"install.success_with_version": "installed {{name}}@{{version}}",
|
|
35
|
+
"install.aborted": "aborted: {{reason}}",
|
|
36
36
|
|
|
37
|
-
"uninstall.dry_run.preview": "[dry-run]
|
|
38
|
-
"uninstall.dry_run.run_hint": "
|
|
39
|
-
"uninstall.confirm.prompt": "
|
|
40
|
-
"uninstall.cancelled": "
|
|
41
|
-
"uninstall.completed": "
|
|
42
|
-
"uninstall.yes_dryrun_conflict": "
|
|
43
|
-
"uninstall.yes_dryrun_conflict.fix": "
|
|
37
|
+
"uninstall.dry_run.preview": "[dry-run] would uninstall '{{name}}' via method '{{method}}'",
|
|
38
|
+
"uninstall.dry_run.run_hint": " run without --dry-run to execute",
|
|
39
|
+
"uninstall.confirm.prompt": "Uninstall '{{name}}'? This cannot be undone.",
|
|
40
|
+
"uninstall.cancelled": "aborted: user cancelled",
|
|
41
|
+
"uninstall.completed": "uninstalled {{name}}",
|
|
42
|
+
"uninstall.yes_dryrun_conflict": "error: --yes is incompatible with --dry-run (dry-run does not mutate)",
|
|
43
|
+
"uninstall.yes_dryrun_conflict.fix": " fix: harnessed uninstall {{name}} --yes (immediate) OR harnessed uninstall {{name}} --dry-run (preview)",
|
|
44
44
|
|
|
45
|
-
"gc.invalid_duration": "
|
|
46
|
-
"gc.invalid_duration.fix": "
|
|
47
|
-
"gc.no_backups": "
|
|
48
|
-
"gc.no_old_snapshots": "
|
|
49
|
-
"gc.summary_will_delete": "
|
|
50
|
-
"gc.summary_deleting": "
|
|
51
|
-
"gc.dry_run_rerun_hint": "\n(dry-run —
|
|
45
|
+
"gc.invalid_duration": "error: invalid --older-than '{{value}}'",
|
|
46
|
+
"gc.invalid_duration.fix": " fix: use format <N>{d|h|m|w} e.g. 30d / 24h / 60m / 4w",
|
|
47
|
+
"gc.no_backups": "no backups found ({{root}} absent) — nothing to gc",
|
|
48
|
+
"gc.no_old_snapshots": "no snapshots older than {{cutoff}} (kept {{keptCount}} most-recent)",
|
|
49
|
+
"gc.summary_will_delete": "would delete {{count}} snapshot(s), ~{{sizeKb}} KB total:",
|
|
50
|
+
"gc.summary_deleting": "deleting {{count}} snapshot(s), ~{{sizeKb}} KB total:",
|
|
51
|
+
"gc.dry_run_rerun_hint": "\n(dry-run — re-run without --dry-run to actually delete)",
|
|
52
52
|
|
|
53
|
-
"doctor.summary.fail": "\
|
|
54
|
-
"doctor.summary.warn": "\
|
|
55
|
-
"doctor.summary.pass": "\
|
|
53
|
+
"doctor.summary.fail": "\nsome checks failed (see fix hints above)",
|
|
54
|
+
"doctor.summary.warn": "\nall checks ok (with warnings — see hints above)",
|
|
55
|
+
"doctor.summary.pass": "\nall checks passed",
|
|
56
56
|
|
|
57
|
-
"backup.no_backups": "
|
|
58
|
-
"backup.no_backups_empty": "
|
|
59
|
-
"backup.total_snapshots": "\n
|
|
57
|
+
"backup.no_backups": "no backups found ({{root}} absent)",
|
|
58
|
+
"backup.no_backups_empty": "no backups found ({{root}} empty)",
|
|
59
|
+
"backup.total_snapshots": "\n{{count}} snapshot(s) total",
|
|
60
60
|
|
|
61
|
-
"rollback.metadata_unreadable": "
|
|
62
|
-
"rollback.metadata_unreadable.fix": "
|
|
63
|
-
"rollback.checksum_mismatch": "
|
|
64
|
-
"rollback.restored": "
|
|
61
|
+
"rollback.metadata_unreadable": "error: cannot read {{path}}: {{message}}",
|
|
62
|
+
"rollback.metadata_unreadable.fix": " fix: run 'harnessed backup list' to see available timestamps",
|
|
63
|
+
"rollback.checksum_mismatch": "error: backup checksum mismatch for {{target}} (expected {{expected}}, got {{actual}})",
|
|
64
|
+
"rollback.restored": "restored {{count}} file(s) from {{timestamp}}",
|
|
65
65
|
|
|
66
|
-
"status.no_installs": "
|
|
67
|
-
"status.summary_installs": "\n
|
|
68
|
-
"status.lock_held": "\nlock:
|
|
69
|
-
"status.lock_held.stale_suffix": " —
|
|
70
|
-
"status.lock_release_hint": "
|
|
71
|
-
"status.lock_free": "\nlock:
|
|
66
|
+
"status.no_installs": "no installs recorded ({{path}} absent or empty)",
|
|
67
|
+
"status.summary_installs": "\n{{count}} install(s) recorded",
|
|
68
|
+
"status.lock_held": "\nlock: held (since {{since}}){{staleSuffix}}",
|
|
69
|
+
"status.lock_held.stale_suffix": " — STALE",
|
|
70
|
+
"status.lock_release_hint": " to release: wait for process to finish or delete {{path}}",
|
|
71
|
+
"status.lock_free": "\nlock: free",
|
|
72
72
|
|
|
73
|
-
"audit_log.no_records_file": "
|
|
74
|
-
"audit_log.no_records_empty": "
|
|
75
|
-
"audit_log.jq_missing": "✗
|
|
76
|
-
"audit_log.tail_invalid": "✗ --tail
|
|
77
|
-
"audit_log.head_invalid": "✗ --head
|
|
73
|
+
"audit_log.no_records_file": "no audit records found ({{path}} does not exist)",
|
|
74
|
+
"audit_log.no_records_empty": "no audit records found (audit.log is empty)",
|
|
75
|
+
"audit_log.jq_missing": "✗ jq not found in PATH — run: harnessed doctor",
|
|
76
|
+
"audit_log.tail_invalid": "✗ --tail must be a positive integer",
|
|
77
|
+
"audit_log.head_invalid": "✗ --head must be a positive integer",
|
|
78
78
|
|
|
79
|
-
"execute_task.require_task": "
|
|
80
|
-
"execute_task.load_phases_failed": "
|
|
81
|
-
"execute_task.precommit_skipped": "⚠️ before-commit
|
|
79
|
+
"execute_task.require_task": "error: --task <text> is required",
|
|
80
|
+
"execute_task.load_phases_failed": "error: failed to load workflows/{{workflow}}/phases.yaml — {{message}}",
|
|
81
|
+
"execute_task.precommit_skipped": "⚠️ before-commit pre-flight skipped ({{message}}); subagent will biome-check at commit time.",
|
|
82
82
|
|
|
83
|
-
"research.require_query": "
|
|
83
|
+
"research.require_query": "error: --query <text> is required",
|
|
84
84
|
|
|
85
|
-
"manifest_add.non_interactive_warn": "[ee-5-gate] WARN: --non-interactive
|
|
86
|
-
"manifest_add.dry_run_preview": "[manifest-add] dry-run
|
|
87
|
-
"manifest_add.empty_answer": "
|
|
88
|
-
"manifest_add.gate_passed_wrote": "[manifest-add] EE-5 gate
|
|
89
|
-
"manifest_add.gate_passed_dry_run": "[manifest-add] EE-5 gate
|
|
85
|
+
"manifest_add.non_interactive_warn": "[ee-5-gate] WARN: --non-interactive skips 5-question prompt (D-03 dry-run-only). plan-phase hard reject still applies.",
|
|
86
|
+
"manifest_add.dry_run_preview": "[manifest-add] dry-run preview for upstream: {{upstream}} → {{path}}",
|
|
87
|
+
"manifest_add.empty_answer": "error: EE-5 gate requires non-empty answer",
|
|
88
|
+
"manifest_add.gate_passed_wrote": "[manifest-add] EE-5 gate passed; wrote {{path}}",
|
|
89
|
+
"manifest_add.gate_passed_dry_run": "[manifest-add] EE-5 gate passed (dry-run); would write {{path}}",
|
|
90
90
|
|
|
91
91
|
"resume.fail": "✗ {{error}}",
|
|
92
92
|
"resume.corrupt": "✗ {{error}}\n path: {{path}}"
|