@pennyfarthing/core 9.2.0 → 9.3.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/package.json +36 -32
- package/LICENSE +0 -14
- package/README.md +0 -218
- package/pennyfarthing-dist/agents/README.md +0 -348
- package/pennyfarthing-dist/agents/architect.md +0 -180
- package/pennyfarthing-dist/agents/dev.md +0 -169
- package/pennyfarthing-dist/agents/devops.md +0 -203
- package/pennyfarthing-dist/agents/handoff.md +0 -235
- package/pennyfarthing-dist/agents/orchestrator.md +0 -182
- package/pennyfarthing-dist/agents/pm.md +0 -152
- package/pennyfarthing-dist/agents/reviewer-preflight.md +0 -129
- package/pennyfarthing-dist/agents/reviewer.md +0 -197
- package/pennyfarthing-dist/agents/sm-file-summary.md +0 -79
- package/pennyfarthing-dist/agents/sm-finish.md +0 -82
- package/pennyfarthing-dist/agents/sm-handoff.md +0 -129
- package/pennyfarthing-dist/agents/sm-setup.md +0 -251
- package/pennyfarthing-dist/agents/sm.md +0 -294
- package/pennyfarthing-dist/agents/tea.md +0 -161
- package/pennyfarthing-dist/agents/tech-writer.md +0 -226
- package/pennyfarthing-dist/agents/testing-runner.md +0 -184
- package/pennyfarthing-dist/agents/ux-designer.md +0 -236
- package/pennyfarthing-dist/agents/workflow-status-check.md +0 -96
- package/pennyfarthing-dist/commands/architect.md +0 -9
- package/pennyfarthing-dist/commands/benchmark-control.md +0 -69
- package/pennyfarthing-dist/commands/benchmark.md +0 -485
- package/pennyfarthing-dist/commands/brainstorming.md +0 -91
- package/pennyfarthing-dist/commands/check.md +0 -156
- package/pennyfarthing-dist/commands/chore.md +0 -218
- package/pennyfarthing-dist/commands/close-epic.md +0 -139
- package/pennyfarthing-dist/commands/continue-session.md +0 -218
- package/pennyfarthing-dist/commands/create-branches-from-story.md +0 -358
- package/pennyfarthing-dist/commands/create-theme.md +0 -29
- package/pennyfarthing-dist/commands/dev.md +0 -9
- package/pennyfarthing-dist/commands/devops.md +0 -9
- package/pennyfarthing-dist/commands/fix-blocker.md +0 -22
- package/pennyfarthing-dist/commands/git-cleanup.md +0 -57
- package/pennyfarthing-dist/commands/health-check.md +0 -143
- package/pennyfarthing-dist/commands/help.md +0 -264
- package/pennyfarthing-dist/commands/job-fair.md +0 -102
- package/pennyfarthing-dist/commands/list-themes.md +0 -21
- package/pennyfarthing-dist/commands/new-work.md +0 -23
- package/pennyfarthing-dist/commands/orchestrator.md +0 -9
- package/pennyfarthing-dist/commands/parallel-work.md +0 -73
- package/pennyfarthing-dist/commands/party-mode.md +0 -77
- package/pennyfarthing-dist/commands/patch.md +0 -210
- package/pennyfarthing-dist/commands/permissions.md +0 -193
- package/pennyfarthing-dist/commands/pm.md +0 -9
- package/pennyfarthing-dist/commands/prime.md +0 -136
- package/pennyfarthing-dist/commands/release.md +0 -58
- package/pennyfarthing-dist/commands/repo-status.md +0 -49
- package/pennyfarthing-dist/commands/retro.md +0 -200
- package/pennyfarthing-dist/commands/reviewer.md +0 -9
- package/pennyfarthing-dist/commands/run-ci.md +0 -116
- package/pennyfarthing-dist/commands/set-theme.md +0 -56
- package/pennyfarthing-dist/commands/setup.md +0 -65
- package/pennyfarthing-dist/commands/show-theme.md +0 -21
- package/pennyfarthing-dist/commands/sm.md +0 -9
- package/pennyfarthing-dist/commands/solo.md +0 -447
- package/pennyfarthing-dist/commands/sprint-planning.md +0 -109
- package/pennyfarthing-dist/commands/sprint.md +0 -142
- package/pennyfarthing-dist/commands/standalone.md +0 -194
- package/pennyfarthing-dist/commands/start-epic.md +0 -168
- package/pennyfarthing-dist/commands/sync-epic-to-jira.md +0 -184
- package/pennyfarthing-dist/commands/sync-work-with-sprint.md +0 -373
- package/pennyfarthing-dist/commands/tea.md +0 -9
- package/pennyfarthing-dist/commands/tech-writer.md +0 -9
- package/pennyfarthing-dist/commands/theme-maker.md +0 -676
- package/pennyfarthing-dist/commands/update-domain-docs.md +0 -83
- package/pennyfarthing-dist/commands/ux-designer.md +0 -9
- package/pennyfarthing-dist/commands/work.md +0 -25
- package/pennyfarthing-dist/commands/workflow.md +0 -21
- package/pennyfarthing-dist/guides/agent-behavior.md +0 -90
- package/pennyfarthing-dist/guides/agent-coordination.md +0 -480
- package/pennyfarthing-dist/guides/agent-tag-taxonomy.md +0 -432
- package/pennyfarthing-dist/guides/agent-template-strategic.md +0 -148
- package/pennyfarthing-dist/guides/agent-template-tactical.md +0 -162
- package/pennyfarthing-dist/guides/hooks.md +0 -230
- package/pennyfarthing-dist/guides/measurement-framework.md +0 -210
- package/pennyfarthing-dist/guides/patterns/approval-gates-pattern.md +0 -766
- package/pennyfarthing-dist/guides/patterns/fan-out-fan-in-pattern.md +0 -574
- package/pennyfarthing-dist/guides/patterns/helper-delegation-pattern.md +0 -488
- package/pennyfarthing-dist/guides/patterns/tdd-flow-pattern.md +0 -402
- package/pennyfarthing-dist/guides/permission-protocol.md +0 -188
- package/pennyfarthing-dist/guides/persona-loading.md +0 -46
- package/pennyfarthing-dist/guides/prompt-patterns.md +0 -338
- package/pennyfarthing-dist/guides/scale-levels.md +0 -114
- package/pennyfarthing-dist/guides/session-artifacts.md +0 -193
- package/pennyfarthing-dist/guides/session-schema.md +0 -346
- package/pennyfarthing-dist/guides/skill-schema.md +0 -412
- package/pennyfarthing-dist/guides/workflow-schema.md +0 -257
- package/pennyfarthing-dist/guides/workflow-step-schema.md +0 -512
- package/pennyfarthing-dist/guides/worktree-mode.md +0 -113
- package/pennyfarthing-dist/guides/xml-tags.md +0 -627
- package/pennyfarthing-dist/output-styles/teaching.md +0 -33
- package/pennyfarthing-dist/output-styles/terse.md +0 -20
- package/pennyfarthing-dist/output-styles/verbose.md +0 -28
- package/pennyfarthing-dist/personas/themes/a-team.yaml +0 -331
- package/pennyfarthing-dist/personas/themes/alice-in-wonderland.yaml +0 -324
- package/pennyfarthing-dist/personas/themes/battlestar-galactica.yaml +0 -282
- package/pennyfarthing-dist/personas/themes/blade-runner.yaml +0 -289
- package/pennyfarthing-dist/personas/themes/catch-22.yaml +0 -304
- package/pennyfarthing-dist/personas/themes/control.yaml +0 -201
- package/pennyfarthing-dist/personas/themes/cowboy-bebop.yaml +0 -315
- package/pennyfarthing-dist/personas/themes/discworld.yaml +0 -334
- package/pennyfarthing-dist/personas/themes/doctor-who.yaml +0 -284
- package/pennyfarthing-dist/personas/themes/dune.yaml +0 -301
- package/pennyfarthing-dist/personas/themes/firefly.yaml +0 -320
- package/pennyfarthing-dist/personas/themes/game-of-thrones.yaml +0 -284
- package/pennyfarthing-dist/personas/themes/harry-potter.yaml +0 -316
- package/pennyfarthing-dist/personas/themes/hitchhikers-guide.yaml +0 -323
- package/pennyfarthing-dist/personas/themes/lord-of-the-rings.yaml +0 -326
- package/pennyfarthing-dist/personas/themes/mad-max.yaml +0 -349
- package/pennyfarthing-dist/personas/themes/mash.yaml +0 -329
- package/pennyfarthing-dist/personas/themes/princess-bride.yaml +0 -344
- package/pennyfarthing-dist/personas/themes/sandman.yaml +0 -282
- package/pennyfarthing-dist/personas/themes/star-trek-tng.yaml +0 -358
- package/pennyfarthing-dist/personas/themes/star-wars.yaml +0 -297
- package/pennyfarthing-dist/personas/themes/the-expanse.yaml +0 -337
- package/pennyfarthing-dist/personas/themes/the-matrix.yaml +0 -342
- package/pennyfarthing-dist/personas/themes/watchmen.yaml +0 -285
- package/pennyfarthing-dist/personas/themes/west-wing.yaml +0 -285
- package/pennyfarthing-dist/personas/themes/x-files.yaml +0 -296
- package/pennyfarthing-dist/scripts/README.md +0 -87
- package/pennyfarthing-dist/scripts/core/README.md +0 -25
- package/pennyfarthing-dist/scripts/core/agent-session.sh +0 -390
- package/pennyfarthing-dist/scripts/core/check-context.sh +0 -194
- package/pennyfarthing-dist/scripts/core/handoff-marker.sh +0 -112
- package/pennyfarthing-dist/scripts/core/phase-check-start.sh +0 -90
- package/pennyfarthing-dist/scripts/core/prime.sh +0 -30
- package/pennyfarthing-dist/scripts/cyclist/is-cyclist.sh +0 -21
- package/pennyfarthing-dist/scripts/git/README.md +0 -25
- package/pennyfarthing-dist/scripts/git/create-feature-branches.sh +0 -267
- package/pennyfarthing-dist/scripts/git/git-status-all.sh +0 -152
- package/pennyfarthing-dist/scripts/git/install-git-hooks.sh +0 -79
- package/pennyfarthing-dist/scripts/git/release.sh +0 -246
- package/pennyfarthing-dist/scripts/git/worktree-manager.sh +0 -497
- package/pennyfarthing-dist/scripts/health/drift-detection.sh +0 -156
- package/pennyfarthing-dist/scripts/hooks/README.md +0 -32
- package/pennyfarthing-dist/scripts/hooks/__pycache__/question_reflector_check.cpython-314.pyc +0 -0
- package/pennyfarthing-dist/scripts/hooks/bell-mode-hook.sh +0 -106
- package/pennyfarthing-dist/scripts/hooks/context-circuit-breaker.sh +0 -95
- package/pennyfarthing-dist/scripts/hooks/context-warning.sh +0 -65
- package/pennyfarthing-dist/scripts/hooks/otel-auto-config.sh +0 -35
- package/pennyfarthing-dist/scripts/hooks/post-merge.sh +0 -150
- package/pennyfarthing-dist/scripts/hooks/pre-commit.sh +0 -102
- package/pennyfarthing-dist/scripts/hooks/pre-edit-check.sh +0 -71
- package/pennyfarthing-dist/scripts/hooks/pre-push.sh +0 -42
- package/pennyfarthing-dist/scripts/hooks/question-reflector-check.sh +0 -20
- package/pennyfarthing-dist/scripts/hooks/question_reflector_check.py +0 -499
- package/pennyfarthing-dist/scripts/hooks/schema-validation.sh +0 -30
- package/pennyfarthing-dist/scripts/hooks/session-start.sh +0 -97
- package/pennyfarthing-dist/scripts/hooks/session-stop.sh +0 -65
- package/pennyfarthing-dist/scripts/hooks/sprint-yaml-validation.sh +0 -78
- package/pennyfarthing-dist/scripts/hooks/welcome-hook.sh +0 -94
- package/pennyfarthing-dist/scripts/jira/README.md +0 -36
- package/pennyfarthing-dist/scripts/jira/create-jira-epic.sh +0 -95
- package/pennyfarthing-dist/scripts/jira/create-jira-story.sh +0 -91
- package/pennyfarthing-dist/scripts/jira/jira-claim-story.sh +0 -22
- package/pennyfarthing-dist/scripts/jira/jira-lib.sh +0 -464
- package/pennyfarthing-dist/scripts/jira/jira-reconcile.sh +0 -260
- package/pennyfarthing-dist/scripts/jira/jira-sync-story.sh +0 -18
- package/pennyfarthing-dist/scripts/jira/jira-sync.sh +0 -16
- package/pennyfarthing-dist/scripts/jira/sync-epic-jira.sh +0 -16
- package/pennyfarthing-dist/scripts/jira/sync-epic-to-jira.sh +0 -16
- package/pennyfarthing-dist/scripts/lib/README.md +0 -29
- package/pennyfarthing-dist/scripts/lib/background-tasks.sh +0 -177
- package/pennyfarthing-dist/scripts/lib/checkpoint.sh +0 -136
- package/pennyfarthing-dist/scripts/lib/common.sh +0 -212
- package/pennyfarthing-dist/scripts/lib/file-lock.sh +0 -269
- package/pennyfarthing-dist/scripts/lib/find-root.sh +0 -58
- package/pennyfarthing-dist/scripts/lib/logging.sh +0 -186
- package/pennyfarthing-dist/scripts/lib/retry.sh +0 -76
- package/pennyfarthing-dist/scripts/maintenance/migrate-theme-schema.mjs +0 -102
- package/pennyfarthing-dist/scripts/maintenance/sidecar-health.sh +0 -91
- package/pennyfarthing-dist/scripts/misc/README.md +0 -44
- package/pennyfarthing-dist/scripts/misc/add-short-names.sh +0 -13
- package/pennyfarthing-dist/scripts/misc/add_short_names.py +0 -226
- package/pennyfarthing-dist/scripts/misc/backlog.sh +0 -77
- package/pennyfarthing-dist/scripts/misc/check-status.sh +0 -247
- package/pennyfarthing-dist/scripts/misc/find-related-work.sh +0 -231
- package/pennyfarthing-dist/scripts/misc/generate-skill-docs.sh +0 -107
- package/pennyfarthing-dist/scripts/misc/log-skill-usage.sh +0 -74
- package/pennyfarthing-dist/scripts/misc/migrate-bmad-workflow.sh +0 -10
- package/pennyfarthing-dist/scripts/misc/migrate_bmad_workflow.py +0 -319
- package/pennyfarthing-dist/scripts/misc/repo-scan.sh +0 -141
- package/pennyfarthing-dist/scripts/misc/repo-utils.sh +0 -778
- package/pennyfarthing-dist/scripts/misc/run-ci.sh +0 -212
- package/pennyfarthing-dist/scripts/misc/run-timestamp.sh +0 -7
- package/pennyfarthing-dist/scripts/misc/session-cleanup.sh +0 -319
- package/pennyfarthing-dist/scripts/misc/skill-usage-report.sh +0 -193
- package/pennyfarthing-dist/scripts/misc/statusline.sh +0 -259
- package/pennyfarthing-dist/scripts/misc/uninstall.sh +0 -275
- package/pennyfarthing-dist/scripts/misc/validate-subagent-frontmatter.sh +0 -160
- package/pennyfarthing-dist/scripts/portraits/generate-portraits.py +0 -417
- package/pennyfarthing-dist/scripts/portraits/generate-portraits.sh +0 -54
- package/pennyfarthing-dist/scripts/sprint/README.md +0 -29
- package/pennyfarthing-dist/scripts/sprint/archive-story.sh +0 -133
- package/pennyfarthing-dist/scripts/sprint/available-stories.sh +0 -91
- package/pennyfarthing-dist/scripts/sprint/check-story.sh +0 -158
- package/pennyfarthing-dist/scripts/sprint/get-epic-field.sh +0 -52
- package/pennyfarthing-dist/scripts/sprint/get-story-field.sh +0 -63
- package/pennyfarthing-dist/scripts/sprint/list-future.sh +0 -145
- package/pennyfarthing-dist/scripts/sprint/new-sprint.sh +0 -110
- package/pennyfarthing-dist/scripts/sprint/promote-epic.sh +0 -148
- package/pennyfarthing-dist/scripts/sprint/sprint-common.sh +0 -415
- package/pennyfarthing-dist/scripts/sprint/sprint-info.sh +0 -33
- package/pennyfarthing-dist/scripts/sprint/sprint-metrics.sh +0 -230
- package/pennyfarthing-dist/scripts/sprint/sprint-status.sh +0 -134
- package/pennyfarthing-dist/scripts/sprint/validate-sprint-yaml.sh +0 -139
- package/pennyfarthing-dist/scripts/story/README.md +0 -23
- package/pennyfarthing-dist/scripts/story/create-story.sh +0 -19
- package/pennyfarthing-dist/scripts/story/size-story.sh +0 -18
- package/pennyfarthing-dist/scripts/story/story-template.sh +0 -18
- package/pennyfarthing-dist/scripts/test/README.md +0 -23
- package/pennyfarthing-dist/scripts/test/ensure-swebench-data.sh +0 -59
- package/pennyfarthing-dist/scripts/test/ground-truth-judge.py +0 -220
- package/pennyfarthing-dist/scripts/test/swebench-judge.py +0 -374
- package/pennyfarthing-dist/scripts/test/test-cache.sh +0 -165
- package/pennyfarthing-dist/scripts/test/test-setup.sh +0 -337
- package/pennyfarthing-dist/scripts/tests/check.test.sh +0 -582
- package/pennyfarthing-dist/scripts/tests/dev-story-workflow-import.test.sh +0 -515
- package/pennyfarthing-dist/scripts/tests/epics-and-stories-workflow-import.test.sh +0 -599
- package/pennyfarthing-dist/scripts/tests/handoff-phase-update.test.sh +0 -332
- package/pennyfarthing-dist/scripts/tests/implementation-readiness-workflow-import.test.sh +0 -573
- package/pennyfarthing-dist/scripts/tests/migrate-bmad-workflow.test.sh +0 -859
- package/pennyfarthing-dist/scripts/tests/prd-workflow-import.test.sh +0 -662
- package/pennyfarthing-dist/scripts/tests/project-context-workflow-import.test.sh +0 -589
- package/pennyfarthing-dist/scripts/tests/test-character-voice.sh +0 -106
- package/pennyfarthing-dist/scripts/tests/test-drift-detection.sh +0 -597
- package/pennyfarthing-dist/scripts/tests/test-post-merge-hook.sh +0 -514
- package/pennyfarthing-dist/scripts/tests/test-session-checkpoint.sh +0 -517
- package/pennyfarthing-dist/scripts/tests/test-solo-command.sh +0 -331
- package/pennyfarthing-dist/scripts/tests/ux-design-workflow-import.test.sh +0 -647
- package/pennyfarthing-dist/scripts/theme/README.md +0 -22
- package/pennyfarthing-dist/scripts/theme/compute-theme-tiers.sh +0 -13
- package/pennyfarthing-dist/scripts/theme/compute_theme_tiers.py +0 -402
- package/pennyfarthing-dist/scripts/theme/list-themes.sh +0 -30
- package/pennyfarthing-dist/scripts/theme/update-theme-tiers.sh +0 -97
- package/pennyfarthing-dist/scripts/validation/validate-agent-schema.sh +0 -576
- package/pennyfarthing-dist/scripts/workflow/README.md +0 -28
- package/pennyfarthing-dist/scripts/workflow/check.py +0 -502
- package/pennyfarthing-dist/scripts/workflow/check.sh +0 -24
- package/pennyfarthing-dist/scripts/workflow/finish-story.sh +0 -154
- package/pennyfarthing-dist/scripts/workflow/fix-session-phase.sh +0 -222
- package/pennyfarthing-dist/scripts/workflow/get-workflow-type.py +0 -61
- package/pennyfarthing-dist/scripts/workflow/get-workflow-type.sh +0 -13
- package/pennyfarthing-dist/scripts/workflow/list-workflows.sh +0 -124
- package/pennyfarthing-dist/scripts/workflow/phase-owner.sh +0 -34
- package/pennyfarthing-dist/scripts/workflow/resume-workflow.sh +0 -157
- package/pennyfarthing-dist/scripts/workflow/show-workflow.sh +0 -132
- package/pennyfarthing-dist/scripts/workflow/start-workflow.sh +0 -250
- package/pennyfarthing-dist/scripts/workflow/workflow-status.sh +0 -161
- package/pennyfarthing-dist/skills/agentic-patterns/SKILL.md +0 -246
- package/pennyfarthing-dist/skills/changelog/SKILL.md +0 -385
- package/pennyfarthing-dist/skills/code-review/SKILL.md +0 -172
- package/pennyfarthing-dist/skills/context-engineering/SKILL.md +0 -277
- package/pennyfarthing-dist/skills/cyclist/SKILL.md +0 -88
- package/pennyfarthing-dist/skills/dev-patterns/SKILL.md +0 -461
- package/pennyfarthing-dist/skills/finalize-run/SKILL.md +0 -261
- package/pennyfarthing-dist/skills/jira/SKILL.md +0 -508
- package/pennyfarthing-dist/skills/judge/SKILL.md +0 -644
- package/pennyfarthing-dist/skills/just/SKILL.md +0 -414
- package/pennyfarthing-dist/skills/mermaid/SKILL.md +0 -256
- package/pennyfarthing-dist/skills/otel/skill.md +0 -227
- package/pennyfarthing-dist/skills/permissions/skill.md +0 -175
- package/pennyfarthing-dist/skills/persona-benchmark/SKILL.md +0 -187
- package/pennyfarthing-dist/skills/skill-registry.schema.json +0 -107
- package/pennyfarthing-dist/skills/skill-registry.yaml +0 -393
- package/pennyfarthing-dist/skills/sprint/scripts/archive-story.sh +0 -101
- package/pennyfarthing-dist/skills/sprint/scripts/available-stories.sh +0 -97
- package/pennyfarthing-dist/skills/sprint/scripts/check-story.sh +0 -164
- package/pennyfarthing-dist/skills/sprint/scripts/create-jira-epic.sh +0 -101
- package/pennyfarthing-dist/skills/sprint/scripts/new-sprint.sh +0 -116
- package/pennyfarthing-dist/skills/sprint/scripts/promote-epic.sh +0 -164
- package/pennyfarthing-dist/skills/sprint/scripts/sprint-info.sh +0 -39
- package/pennyfarthing-dist/skills/sprint/scripts/sprint-status.sh +0 -147
- package/pennyfarthing-dist/skills/sprint/scripts/sync-epic-jira.sh +0 -93
- package/pennyfarthing-dist/skills/sprint/skill.md +0 -465
- package/pennyfarthing-dist/skills/story/scripts/create-story.sh +0 -159
- package/pennyfarthing-dist/skills/story/scripts/size-story.sh +0 -198
- package/pennyfarthing-dist/skills/story/scripts/story-template.sh +0 -162
- package/pennyfarthing-dist/skills/story/skill.md +0 -219
- package/pennyfarthing-dist/skills/systematic-debugging/SKILL.md +0 -446
- package/pennyfarthing-dist/skills/testing/SKILL.md +0 -121
- package/pennyfarthing-dist/skills/testing/references/troubleshooting.md +0 -124
- package/pennyfarthing-dist/skills/theme/skill.md +0 -141
- package/pennyfarthing-dist/skills/theme-creation/SKILL.md +0 -178
- package/pennyfarthing-dist/skills/workflow/scripts/list-workflows.sh +0 -91
- package/pennyfarthing-dist/skills/workflow/scripts/resume-workflow.sh +0 -163
- package/pennyfarthing-dist/skills/workflow/scripts/show-workflow.sh +0 -138
- package/pennyfarthing-dist/skills/workflow/scripts/start-workflow.sh +0 -273
- package/pennyfarthing-dist/skills/workflow/scripts/workflow-status.sh +0 -167
- package/pennyfarthing-dist/skills/workflow/skill.md +0 -345
- package/pennyfarthing-dist/skills/yq/SKILL.md +0 -272
- package/pennyfarthing-dist/templates/LEADERBOARD.schema.yaml +0 -187
- package/pennyfarthing-dist/templates/LEADERBOARD.template.md +0 -59
- package/pennyfarthing-dist/templates/agent-scopes.yaml.template +0 -276
- package/pennyfarthing-dist/templates/pennyfarthing-settings.yaml.template +0 -61
- package/pennyfarthing-dist/templates/persona-config.yaml.template +0 -22
- package/pennyfarthing-dist/templates/preferences.yaml.template +0 -15
- package/pennyfarthing-dist/templates/settings.local.json.template +0 -110
- package/pennyfarthing-dist/templates/setup-env.sh.template +0 -18
- package/pennyfarthing-dist/templates/shared-context.md.template +0 -70
- package/pennyfarthing-dist/templates/sidecar/decisions.md.template +0 -40
- package/pennyfarthing-dist/templates/sidecar/gotchas.md.template +0 -37
- package/pennyfarthing-dist/templates/sidecar/patterns.md.template +0 -34
- package/pennyfarthing-dist/workflows/agent-docs.yaml +0 -70
- package/pennyfarthing-dist/workflows/architecture/steps/step-01-initialize.md +0 -113
- package/pennyfarthing-dist/workflows/architecture/steps/step-01b-continue.md +0 -105
- package/pennyfarthing-dist/workflows/architecture/steps/step-02-context.md +0 -127
- package/pennyfarthing-dist/workflows/architecture/steps/step-03-patterns.md +0 -145
- package/pennyfarthing-dist/workflows/architecture/steps/step-04-components.md +0 -150
- package/pennyfarthing-dist/workflows/architecture/steps/step-05-interfaces.md +0 -145
- package/pennyfarthing-dist/workflows/architecture/steps/step-06-risks.md +0 -154
- package/pennyfarthing-dist/workflows/architecture/steps/step-07-document.md +0 -172
- package/pennyfarthing-dist/workflows/architecture/templates/architecture-decision.md +0 -102
- package/pennyfarthing-dist/workflows/architecture.yaml +0 -65
- package/pennyfarthing-dist/workflows/bdd.yaml +0 -60
- package/pennyfarthing-dist/workflows/brainstorming/brain-methods.csv +0 -62
- package/pennyfarthing-dist/workflows/brainstorming/checklist.md +0 -44
- package/pennyfarthing-dist/workflows/brainstorming/instructions.md +0 -736
- package/pennyfarthing-dist/workflows/brainstorming/workflow.yaml +0 -49
- package/pennyfarthing-dist/workflows/code-review/checklist.md +0 -23
- package/pennyfarthing-dist/workflows/code-review/instructions.md +0 -234
- package/pennyfarthing-dist/workflows/code-review/workflow.yaml +0 -51
- package/pennyfarthing-dist/workflows/dev-story/checklist.md +0 -80
- package/pennyfarthing-dist/workflows/dev-story/instructions.xml +0 -410
- package/pennyfarthing-dist/workflows/dev-story/workflow.yaml +0 -50
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-01-validate-prerequisites.md +0 -281
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-02-design-epics.md +0 -256
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-03-create-stories.md +0 -298
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-04-final-validation.md +0 -177
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-05-import-to-future.md +0 -145
- package/pennyfarthing-dist/workflows/epics-and-stories/templates/epics-template.md +0 -57
- package/pennyfarthing-dist/workflows/epics-and-stories/workflow.yaml +0 -28
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-01-analyze.md +0 -103
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-02-categorize.md +0 -147
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-03-execute.md +0 -215
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-04-verify.md +0 -97
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-05-complete.md +0 -78
- package/pennyfarthing-dist/workflows/git-cleanup.yaml +0 -59
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-01-document-discovery.md +0 -211
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-02-prd-analysis.md +0 -199
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-03-epic-coverage-validation.md +0 -202
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-04-ux-alignment.md +0 -162
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-05-epic-quality-review.md +0 -280
- package/pennyfarthing-dist/workflows/implementation-readiness/steps/step-06-final-assessment.md +0 -158
- package/pennyfarthing-dist/workflows/implementation-readiness/templates/readiness-report-template.md +0 -4
- package/pennyfarthing-dist/workflows/implementation-readiness/workflow.yaml +0 -40
- package/pennyfarthing-dist/workflows/interactive-debug/steps/step-01-connect.md +0 -257
- package/pennyfarthing-dist/workflows/interactive-debug/steps/step-02-explore.md +0 -107
- package/pennyfarthing-dist/workflows/interactive-debug/steps/step-03-fix.md +0 -127
- package/pennyfarthing-dist/workflows/interactive-debug/steps/step-04-commit.md +0 -122
- package/pennyfarthing-dist/workflows/interactive-debug/workflow.yaml +0 -51
- package/pennyfarthing-dist/workflows/patch.yaml +0 -67
- package/pennyfarthing-dist/workflows/prd/data/domain-complexity.csv +0 -13
- package/pennyfarthing-dist/workflows/prd/data/prd-purpose.md +0 -197
- package/pennyfarthing-dist/workflows/prd/data/project-types.csv +0 -11
- package/pennyfarthing-dist/workflows/prd/steps-c/step-01-init.md +0 -197
- package/pennyfarthing-dist/workflows/prd/steps-c/step-01b-continue.md +0 -159
- package/pennyfarthing-dist/workflows/prd/steps-c/step-02-discovery.md +0 -230
- package/pennyfarthing-dist/workflows/prd/steps-c/step-03-success.md +0 -232
- package/pennyfarthing-dist/workflows/prd/steps-c/step-04-journeys.md +0 -219
- package/pennyfarthing-dist/workflows/prd/steps-c/step-05-domain.md +0 -213
- package/pennyfarthing-dist/workflows/prd/steps-c/step-06-innovation.md +0 -232
- package/pennyfarthing-dist/workflows/prd/steps-c/step-07-project-type.md +0 -243
- package/pennyfarthing-dist/workflows/prd/steps-c/step-08-scoping.md +0 -234
- package/pennyfarthing-dist/workflows/prd/steps-c/step-09-functional.md +0 -237
- package/pennyfarthing-dist/workflows/prd/steps-c/step-10-nonfunctional.md +0 -248
- package/pennyfarthing-dist/workflows/prd/steps-c/step-11-polish.md +0 -223
- package/pennyfarthing-dist/workflows/prd/steps-c/step-12-complete.md +0 -186
- package/pennyfarthing-dist/workflows/prd/steps-e/step-e-01-discovery.md +0 -253
- package/pennyfarthing-dist/workflows/prd/steps-e/step-e-01b-legacy-conversion.md +0 -214
- package/pennyfarthing-dist/workflows/prd/steps-e/step-e-02-review.md +0 -255
- package/pennyfarthing-dist/workflows/prd/steps-e/step-e-03-edit.md +0 -259
- package/pennyfarthing-dist/workflows/prd/steps-e/step-e-04-complete.md +0 -174
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-01-discovery.md +0 -224
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-02-format-detection.md +0 -197
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-02b-parity-check.md +0 -215
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-03-density-validation.md +0 -180
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-04-brief-coverage-validation.md +0 -220
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-05-measurability-validation.md +0 -234
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-06-traceability-validation.md +0 -223
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-07-implementation-leakage-validation.md +0 -211
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-08-domain-compliance-validation.md +0 -249
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-09-project-type-validation.md +0 -269
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-10-smart-validation.md +0 -215
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-11-holistic-quality-validation.md +0 -270
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-12-completeness-validation.md +0 -248
- package/pennyfarthing-dist/workflows/prd/steps-v/step-v-13-report-complete.md +0 -238
- package/pennyfarthing-dist/workflows/prd/templates/prd-template.md +0 -10
- package/pennyfarthing-dist/workflows/prd/workflow.yaml +0 -42
- package/pennyfarthing-dist/workflows/product-brief/steps/step-01-init.md +0 -195
- package/pennyfarthing-dist/workflows/product-brief/steps/step-01b-continue.md +0 -180
- package/pennyfarthing-dist/workflows/product-brief/steps/step-02-vision.md +0 -221
- package/pennyfarthing-dist/workflows/product-brief/steps/step-03-users.md +0 -224
- package/pennyfarthing-dist/workflows/product-brief/steps/step-04-metrics.md +0 -228
- package/pennyfarthing-dist/workflows/product-brief/steps/step-05-scope.md +0 -243
- package/pennyfarthing-dist/workflows/product-brief/steps/step-06-complete.md +0 -216
- package/pennyfarthing-dist/workflows/product-brief/templates/product-brief.template.md +0 -10
- package/pennyfarthing-dist/workflows/product-brief/workflow.yaml +0 -31
- package/pennyfarthing-dist/workflows/project-context/project-context-template.md +0 -21
- package/pennyfarthing-dist/workflows/project-context/steps/step-01-discover.md +0 -206
- package/pennyfarthing-dist/workflows/project-context/steps/step-02-generate.md +0 -349
- package/pennyfarthing-dist/workflows/project-context/steps/step-03-complete.md +0 -306
- package/pennyfarthing-dist/workflows/project-context/workflow.yaml +0 -27
- package/pennyfarthing-dist/workflows/project-setup/steps/step-01-discover.md +0 -157
- package/pennyfarthing-dist/workflows/project-setup/steps/step-02-clone-repos.md +0 -217
- package/pennyfarthing-dist/workflows/project-setup/steps/step-03-repos-yaml.md +0 -159
- package/pennyfarthing-dist/workflows/project-setup/steps/step-04-claude-md.md +0 -186
- package/pennyfarthing-dist/workflows/project-setup/steps/step-05-shared-context.md +0 -185
- package/pennyfarthing-dist/workflows/project-setup/steps/step-06-task-runner.md +0 -279
- package/pennyfarthing-dist/workflows/project-setup/steps/step-07-theme.md +0 -200
- package/pennyfarthing-dist/workflows/project-setup/steps/step-08-theme-packs.md +0 -142
- package/pennyfarthing-dist/workflows/project-setup/steps/step-09-cyclist.md +0 -245
- package/pennyfarthing-dist/workflows/project-setup/steps/step-10-complete.md +0 -204
- package/pennyfarthing-dist/workflows/project-setup/workflow.yaml +0 -41
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-01-mode-detection.md +0 -177
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-02-context-gathering.md +0 -143
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-03-execute.md +0 -138
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-04-self-check.md +0 -135
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-05-adversarial-review.md +0 -129
- package/pennyfarthing-dist/workflows/quick-dev/steps/step-06-resolve-findings.md +0 -163
- package/pennyfarthing-dist/workflows/quick-dev/workflow.yaml +0 -27
- package/pennyfarthing-dist/workflows/quick-spec/steps/step-01-understand.md +0 -201
- package/pennyfarthing-dist/workflows/quick-spec/steps/step-02-investigate.md +0 -156
- package/pennyfarthing-dist/workflows/quick-spec/steps/step-03-generate.md +0 -140
- package/pennyfarthing-dist/workflows/quick-spec/steps/step-04-review.md +0 -203
- package/pennyfarthing-dist/workflows/quick-spec/tech-spec-template.md +0 -74
- package/pennyfarthing-dist/workflows/quick-spec/workflow.yaml +0 -27
- package/pennyfarthing-dist/workflows/research/steps-domain/step-01-init.md +0 -159
- package/pennyfarthing-dist/workflows/research/steps-domain/step-02-domain-analysis.md +0 -253
- package/pennyfarthing-dist/workflows/research/steps-domain/step-03-competitive-landscape.md +0 -263
- package/pennyfarthing-dist/workflows/research/steps-domain/step-04-regulatory-focus.md +0 -232
- package/pennyfarthing-dist/workflows/research/steps-domain/step-05-technical-trends.md +0 -260
- package/pennyfarthing-dist/workflows/research/steps-domain/step-06-research-synthesis.md +0 -477
- package/pennyfarthing-dist/workflows/research/steps-market/step-01-init.md +0 -205
- package/pennyfarthing-dist/workflows/research/steps-market/step-02-customer-behavior.md +0 -262
- package/pennyfarthing-dist/workflows/research/steps-market/step-02-customer-insights.md +0 -227
- package/pennyfarthing-dist/workflows/research/steps-market/step-03-customer-pain-points.md +0 -275
- package/pennyfarthing-dist/workflows/research/steps-market/step-04-customer-decisions.md +0 -286
- package/pennyfarthing-dist/workflows/research/steps-market/step-05-competitive-analysis.md +0 -203
- package/pennyfarthing-dist/workflows/research/steps-market/step-06-research-completion.md +0 -510
- package/pennyfarthing-dist/workflows/research/steps-technical/step-01-init.md +0 -159
- package/pennyfarthing-dist/workflows/research/steps-technical/step-02-technical-overview.md +0 -264
- package/pennyfarthing-dist/workflows/research/steps-technical/step-03-integration-patterns.md +0 -274
- package/pennyfarthing-dist/workflows/research/steps-technical/step-04-architectural-patterns.md +0 -228
- package/pennyfarthing-dist/workflows/research/steps-technical/step-05-implementation-research.md +0 -267
- package/pennyfarthing-dist/workflows/research/steps-technical/step-06-research-synthesis.md +0 -522
- package/pennyfarthing-dist/workflows/research/templates/research.template.md +0 -29
- package/pennyfarthing-dist/workflows/research/workflow.yaml +0 -45
- package/pennyfarthing-dist/workflows/retrospective/checklist.md +0 -31
- package/pennyfarthing-dist/workflows/retrospective/instructions.md +0 -1443
- package/pennyfarthing-dist/workflows/retrospective/workflow.yaml +0 -50
- package/pennyfarthing-dist/workflows/sprint-planning/checklist.md +0 -33
- package/pennyfarthing-dist/workflows/sprint-planning/sprint-status-template.yaml +0 -55
- package/pennyfarthing-dist/workflows/sprint-planning/steps/step-01-parse-epic-files.md +0 -69
- package/pennyfarthing-dist/workflows/sprint-planning/steps/step-02-build-sprint-status.md +0 -61
- package/pennyfarthing-dist/workflows/sprint-planning/steps/step-03-status-detection.md +0 -80
- package/pennyfarthing-dist/workflows/sprint-planning/steps/step-04-generate-status-file.md +0 -90
- package/pennyfarthing-dist/workflows/sprint-planning/steps/step-05-validate-and-report.md +0 -78
- package/pennyfarthing-dist/workflows/sprint-planning/workflow.yaml +0 -34
- package/pennyfarthing-dist/workflows/tdd.yaml +0 -50
- package/pennyfarthing-dist/workflows/trivial.yaml +0 -40
- package/pennyfarthing-dist/workflows/ux-design/steps/step-01-init.md +0 -141
- package/pennyfarthing-dist/workflows/ux-design/steps/step-01b-continue.md +0 -133
- package/pennyfarthing-dist/workflows/ux-design/steps/step-02-discovery.md +0 -196
- package/pennyfarthing-dist/workflows/ux-design/steps/step-03-core-experience.md +0 -222
- package/pennyfarthing-dist/workflows/ux-design/steps/step-04-emotional-response.md +0 -225
- package/pennyfarthing-dist/workflows/ux-design/steps/step-05-inspiration.md +0 -240
- package/pennyfarthing-dist/workflows/ux-design/steps/step-06-design-system.md +0 -258
- package/pennyfarthing-dist/workflows/ux-design/steps/step-07-defining-experience.md +0 -260
- package/pennyfarthing-dist/workflows/ux-design/steps/step-08-visual-foundation.md +0 -230
- package/pennyfarthing-dist/workflows/ux-design/steps/step-09-design-directions.md +0 -230
- package/pennyfarthing-dist/workflows/ux-design/steps/step-10-user-journeys.md +0 -247
- package/pennyfarthing-dist/workflows/ux-design/steps/step-11-component-strategy.md +0 -254
- package/pennyfarthing-dist/workflows/ux-design/steps/step-12-ux-patterns.md +0 -243
- package/pennyfarthing-dist/workflows/ux-design/steps/step-13-responsive-accessibility.md +0 -270
- package/pennyfarthing-dist/workflows/ux-design/steps/step-14-complete.md +0 -234
- package/pennyfarthing-dist/workflows/ux-design/ux-design-template.md +0 -13
- package/pennyfarthing-dist/workflows/ux-design/workflow.yaml +0 -41
- package/pennyfarthing_scripts/README.md +0 -66
- package/pennyfarthing_scripts/__init__.py +0 -17
- package/pennyfarthing_scripts/__pycache__/__init__.cpython-311.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/config.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/hooks.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_bidirectional_sync.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_epic_creation.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_sync.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_sync_story.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/output.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/patch_mode.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/schema_validation_hook.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/sprint.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/workflow.cpython-311.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/workflow.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/bellmode_hook.py +0 -154
- package/pennyfarthing_scripts/brownfield/__init__.py +0 -35
- package/pennyfarthing_scripts/brownfield/__main__.py +0 -7
- package/pennyfarthing_scripts/brownfield/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/discover.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/cli.py +0 -131
- package/pennyfarthing_scripts/brownfield/discover.py +0 -753
- package/pennyfarthing_scripts/cli.py +0 -174
- package/pennyfarthing_scripts/common/__init__.py +0 -49
- package/pennyfarthing_scripts/common/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/__pycache__/config.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/__pycache__/output.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/__pycache__/themes.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/config.py +0 -91
- package/pennyfarthing_scripts/common/output.py +0 -180
- package/pennyfarthing_scripts/common/themes.py +0 -253
- package/pennyfarthing_scripts/config.py +0 -21
- package/pennyfarthing_scripts/context.py +0 -414
- package/pennyfarthing_scripts/git/__init__.py +0 -29
- package/pennyfarthing_scripts/git/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/__pycache__/create_branches.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/__pycache__/status_all.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/create_branches.py +0 -439
- package/pennyfarthing_scripts/git/status_all.py +0 -310
- package/pennyfarthing_scripts/hooks.py +0 -455
- package/pennyfarthing_scripts/jira/__init__.py +0 -93
- package/pennyfarthing_scripts/jira/__main__.py +0 -10
- package/pennyfarthing_scripts/jira/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/bidirectional.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/claim.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/client.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/compat.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/epic.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/mappings.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/models.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/story.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/sync.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/bidirectional.py +0 -561
- package/pennyfarthing_scripts/jira/claim.py +0 -211
- package/pennyfarthing_scripts/jira/cli.py +0 -150
- package/pennyfarthing_scripts/jira/client.py +0 -613
- package/pennyfarthing_scripts/jira/epic.py +0 -176
- package/pennyfarthing_scripts/jira/story.py +0 -219
- package/pennyfarthing_scripts/jira/sync.py +0 -350
- package/pennyfarthing_scripts/jira_bidirectional_sync.py +0 -37
- package/pennyfarthing_scripts/jira_epic_creation.py +0 -30
- package/pennyfarthing_scripts/jira_sync.py +0 -36
- package/pennyfarthing_scripts/jira_sync_story.py +0 -30
- package/pennyfarthing_scripts/migration/__init__.py +0 -39
- package/pennyfarthing_scripts/migration/__main__.py +0 -10
- package/pennyfarthing_scripts/migration/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/session.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/skill.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/step.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/__pycache__/validate.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/migration/cli.py +0 -304
- package/pennyfarthing_scripts/migration/session.py +0 -384
- package/pennyfarthing_scripts/migration/skill.py +0 -188
- package/pennyfarthing_scripts/migration/step.py +0 -229
- package/pennyfarthing_scripts/migration/validate.py +0 -282
- package/pennyfarthing_scripts/output.py +0 -37
- package/pennyfarthing_scripts/patch_mode.py +0 -449
- package/pennyfarthing_scripts/preflight/__init__.py +0 -17
- package/pennyfarthing_scripts/preflight/__main__.py +0 -10
- package/pennyfarthing_scripts/preflight/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/finish.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/cli.py +0 -141
- package/pennyfarthing_scripts/preflight/finish.py +0 -382
- package/pennyfarthing_scripts/pretooluse_hook.py +0 -142
- package/pennyfarthing_scripts/prime/__init__.py +0 -125
- package/pennyfarthing_scripts/prime/__main__.py +0 -8
- package/pennyfarthing_scripts/prime/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/loader.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/models.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/persona.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/session.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/tiers.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/workflow.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/cli.py +0 -645
- package/pennyfarthing_scripts/prime/loader.py +0 -239
- package/pennyfarthing_scripts/prime/models.py +0 -206
- package/pennyfarthing_scripts/prime/persona.py +0 -308
- package/pennyfarthing_scripts/prime/session.py +0 -183
- package/pennyfarthing_scripts/prime/tiers.py +0 -201
- package/pennyfarthing_scripts/prime/workflow.py +0 -275
- package/pennyfarthing_scripts/schema_validation_hook.py +0 -306
- package/pennyfarthing_scripts/sprint/__init__.py +0 -66
- package/pennyfarthing_scripts/sprint/__main__.py +0 -10
- package/pennyfarthing_scripts/sprint/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/archive.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/archive_epic.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/loader.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/status.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/validator.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/work.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/archive.py +0 -108
- package/pennyfarthing_scripts/sprint/archive_epic.py +0 -399
- package/pennyfarthing_scripts/sprint/cli.py +0 -284
- package/pennyfarthing_scripts/sprint/import_epic.py +0 -431
- package/pennyfarthing_scripts/sprint/loader.py +0 -193
- package/pennyfarthing_scripts/sprint/status.py +0 -122
- package/pennyfarthing_scripts/sprint/validator.py +0 -405
- package/pennyfarthing_scripts/sprint/work.py +0 -192
- package/pennyfarthing_scripts/story/__init__.py +0 -67
- package/pennyfarthing_scripts/story/__main__.py +0 -10
- package/pennyfarthing_scripts/story/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/__pycache__/create.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/__pycache__/size.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/__pycache__/template.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/story/cli.py +0 -105
- package/pennyfarthing_scripts/story/create.py +0 -167
- package/pennyfarthing_scripts/story/size.py +0 -113
- package/pennyfarthing_scripts/story/template.py +0 -151
- package/pennyfarthing_scripts/swebench.py +0 -216
- package/pennyfarthing_scripts/tests/__init__.py +0 -1
- package/pennyfarthing_scripts/tests/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/conftest.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_brownfield.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_cli_modules.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_common.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_git_utils.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_jira_package.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_package_structure.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_patch_mode.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_prime.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_sprint_package.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_sprint_validator.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_story_package.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_tiers.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_token_counting.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_workflow_check.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_workflow_cli.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/conftest.py +0 -106
- package/pennyfarthing_scripts/tests/test_brownfield.py +0 -842
- package/pennyfarthing_scripts/tests/test_cli_modules.py +0 -245
- package/pennyfarthing_scripts/tests/test_common.py +0 -180
- package/pennyfarthing_scripts/tests/test_git_utils.py +0 -866
- package/pennyfarthing_scripts/tests/test_jira_package.py +0 -334
- package/pennyfarthing_scripts/tests/test_package_structure.py +0 -372
- package/pennyfarthing_scripts/tests/test_patch_mode.py +0 -830
- package/pennyfarthing_scripts/tests/test_prime.py +0 -1050
- package/pennyfarthing_scripts/tests/test_sprint_package.py +0 -236
- package/pennyfarthing_scripts/tests/test_sprint_validator.py +0 -675
- package/pennyfarthing_scripts/tests/test_story_package.py +0 -156
- package/pennyfarthing_scripts/tests/test_tiers.py +0 -1090
- package/pennyfarthing_scripts/tests/test_token_counting.py +0 -559
- package/pennyfarthing_scripts/tests/test_workflow_check.py +0 -341
- package/pennyfarthing_scripts/welcome_hook.py +0 -157
- package/pennyfarthing_scripts/workflow.py +0 -287
- /package/{packages/core/bin → bin}/pennyfarthing.js +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.js +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.test.js +0 -0
- /package/{packages/core/dist → dist}/bmad/context-reader.test.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.js +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.test.js +0 -0
- /package/{packages/core/dist → dist}/bmad/epics-parser.test.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/index.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/index.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/index.js +0 -0
- /package/{packages/core/dist → dist}/bmad/index.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.js +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.test.js +0 -0
- /package/{packages/core/dist → dist}/bmad/status-sync.test.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.js +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.test.js +0 -0
- /package/{packages/core/dist → dist}/bmad/story-exporter.test.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.js +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.js.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.test.js +0 -0
- /package/{packages/core/dist → dist}/bmad/story-parser.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/command.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/command.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/command.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/command.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/cyclist.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor-legacy.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor-legacy.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor-legacy.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor-legacy.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/doctor.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/init.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/init.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/init.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/init.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/skill.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/skill.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/skill.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/skill.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/theme.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/theme.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/theme.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/theme.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/uninstall.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/uninstall.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/uninstall.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/uninstall.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/update.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/update.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/update.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/update.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/version.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/commands/version.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/commands/version.js +0 -0
- /package/{packages/core/dist → dist}/cli/commands/version.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/customization.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/customization.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/customization.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/customization.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/cyclist-migration.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/cyclist-migration.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/cyclist-migration.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/cyclist-migration.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/index.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/index.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/index.js +0 -0
- /package/{packages/core/dist → dist}/cli/index.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/ocean-profiles.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/ocean-profiles.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/ocean-profiles.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/ocean-profiles.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/theme-maker.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/theme-maker.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/theme-maker.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/theme-maker.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/constants.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/constants.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/constants.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/constants.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/files.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/files.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/files.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/files.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/logger.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/logger.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/logger.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/logger.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/manifest.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/manifest.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/manifest.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/manifest.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/node-modules.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/node-modules.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/node-modules.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/node-modules.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/prompts.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/prompts.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/prompts.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/prompts.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/settings.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/settings.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/settings.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/settings.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/symlinks.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/symlinks.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/symlinks.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/symlinks.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/themes.test.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/version.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/utils/version.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/utils/version.js +0 -0
- /package/{packages/core/dist → dist}/cli/utils/version.js.map +0 -0
- /package/{packages/core/dist → dist}/cli/workspace.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/cli/workspace.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/cli/workspace.test.js +0 -0
- /package/{packages/core/dist → dist}/cli/workspace.test.js.map +0 -0
- /package/{packages/core/dist → dist}/index.d.ts +0 -0
- /package/{packages/core/dist → dist}/index.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/index.js +0 -0
- /package/{packages/core/dist → dist}/index.js.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.d.ts +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.js +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.js.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.test.js +0 -0
- /package/{packages/core/dist → dist}/jira/jira-epic-creation.test.js.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.d.ts +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.js +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.js.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.test.js +0 -0
- /package/{packages/core/dist → dist}/jira/jira-sprint-sync.test.js.map +0 -0
- /package/{packages/core/dist → dist}/permissions/index.d.ts +0 -0
- /package/{packages/core/dist → dist}/permissions/index.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/permissions/index.js +0 -0
- /package/{packages/core/dist → dist}/permissions/index.js.map +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.d.ts +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.js +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.js.map +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.test.js +0 -0
- /package/{packages/core/dist → dist}/permissions/permission-schema.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/add-ocean-profiles.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/add-ocean-profiles.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/add-ocean-profiles.js +0 -0
- /package/{packages/core/dist → dist}/scripts/add-ocean-profiles.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.js +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/benchmark-integration.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/debugging-scenarios.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/debugging-scenarios.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/debugging-scenarios.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/debugging-scenarios.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-all-spiders.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-all-spiders.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-all-spiders.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-all-spiders.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-report.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider-report.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/generate-spider.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.js +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/job-fair-aggregator.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/run-ci.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/run-ci.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/run-ci.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/run-ci.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/theme-detail.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/theme-detail.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/theme-detail.test.js +0 -0
- /package/{packages/core/dist → dist}/scripts/theme-detail.test.js.map +0 -0
- /package/{packages/core/dist → dist}/scripts/validate-ocean-profiles.d.ts +0 -0
- /package/{packages/core/dist → dist}/scripts/validate-ocean-profiles.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/scripts/validate-ocean-profiles.js +0 -0
- /package/{packages/core/dist → dist}/scripts/validate-ocean-profiles.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.js +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/gate-handler.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-finish.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-finish.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-finish.js +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-finish.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-setup.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-setup.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-setup.js +0 -0
- /package/{packages/core/dist → dist}/workflow/generic-sm-setup.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.js +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/handoff.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/index.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/index.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/index.js +0 -0
- /package/{packages/core/dist → dist}/workflow/index.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.js +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/session-state.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/sm-subagents.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/sm-subagents.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/sm-subagents.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/sm-subagents.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.js +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/step-parser.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/story-workflow-routing.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/story-workflow-routing.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/story-workflow-routing.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/story-workflow-routing.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.js +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/test-cache.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.js +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/trimodal.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.js +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/variable-resolver.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-executor.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-loader.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-migration.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-migration.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-migration.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-migration.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-permissions.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-router.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-schema.test.js.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-stepped-schema.test.d.ts +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-stepped-schema.test.d.ts.map +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-stepped-schema.test.js +0 -0
- /package/{packages/core/dist → dist}/workflow/workflow-stepped-schema.test.js.map +0 -0
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
#
|
|
3
|
-
# Bell Mode PostToolUse Hook (Story MSSCI-12275)
|
|
4
|
-
#
|
|
5
|
-
# This hook is called by Claude Code after each tool execution.
|
|
6
|
-
# When bell mode is enabled and there are queued messages, it returns
|
|
7
|
-
# the first queued message as additionalContext to be injected into
|
|
8
|
-
# Claude's next API call.
|
|
9
|
-
#
|
|
10
|
-
# Configuration files:
|
|
11
|
-
# .pennyfarthing/config.local.yaml - workflow.bell_mode: true/false
|
|
12
|
-
# .pennyfarthing/bell-queue.json - [{ "text": "...", "images": [...] }, ...]
|
|
13
|
-
#
|
|
14
|
-
# Output format (when injecting):
|
|
15
|
-
# {
|
|
16
|
-
# "hookSpecificOutput": {
|
|
17
|
-
# "hookEventName": "PostToolUse",
|
|
18
|
-
# "additionalContext": "User feedback: <message>"
|
|
19
|
-
# }
|
|
20
|
-
# }
|
|
21
|
-
#
|
|
22
|
-
# Output when disabled or queue empty: (nothing - exit 0)
|
|
23
|
-
|
|
24
|
-
# Find project root (walk up to find .pennyfarthing)
|
|
25
|
-
PROJECT_ROOT="$PWD"
|
|
26
|
-
while [[ "$PROJECT_ROOT" != "/" ]]; do
|
|
27
|
-
if [[ -d "$PROJECT_ROOT/.pennyfarthing" ]]; then
|
|
28
|
-
break
|
|
29
|
-
fi
|
|
30
|
-
PROJECT_ROOT="$(dirname "$PROJECT_ROOT")"
|
|
31
|
-
done
|
|
32
|
-
|
|
33
|
-
if [[ ! -d "$PROJECT_ROOT/.pennyfarthing" ]]; then
|
|
34
|
-
# No .pennyfarthing directory found - exit silently
|
|
35
|
-
exit 0
|
|
36
|
-
fi
|
|
37
|
-
|
|
38
|
-
CONFIG_LOCAL_YAML="$PROJECT_ROOT/.pennyfarthing/config.local.yaml"
|
|
39
|
-
BELL_QUEUE_FILE="$PROJECT_ROOT/.pennyfarthing/bell-queue.json"
|
|
40
|
-
|
|
41
|
-
# Check if bell mode is enabled in config.local.yaml
|
|
42
|
-
if [[ ! -f "$CONFIG_LOCAL_YAML" ]]; then
|
|
43
|
-
exit 0
|
|
44
|
-
fi
|
|
45
|
-
|
|
46
|
-
# Parse YAML to check workflow.bell_mode - look for "bell_mode: true"
|
|
47
|
-
# This handles both "bell_mode: true" and " bell_mode: true" (indented under workflow)
|
|
48
|
-
ENABLED=$(grep -E '^\s*bell_mode:\s*true' "$CONFIG_LOCAL_YAML" 2>/dev/null || true)
|
|
49
|
-
if [[ -z "$ENABLED" ]]; then
|
|
50
|
-
exit 0
|
|
51
|
-
fi
|
|
52
|
-
|
|
53
|
-
# Check if queue file exists and has messages
|
|
54
|
-
if [[ ! -f "$BELL_QUEUE_FILE" ]]; then
|
|
55
|
-
exit 0
|
|
56
|
-
fi
|
|
57
|
-
|
|
58
|
-
# Read queue and check if non-empty
|
|
59
|
-
QUEUE_CONTENT=$(cat "$BELL_QUEUE_FILE" 2>/dev/null)
|
|
60
|
-
if [[ -z "$QUEUE_CONTENT" ]] || [[ "$QUEUE_CONTENT" == "[]" ]]; then
|
|
61
|
-
exit 0
|
|
62
|
-
fi
|
|
63
|
-
|
|
64
|
-
# Extract first message text using simple parsing
|
|
65
|
-
# The queue format is: [{"text":"...","images":[...]}, ...]
|
|
66
|
-
FIRST_MESSAGE_TEXT=$(echo "$QUEUE_CONTENT" | sed -n 's/.*"text"[[:space:]]*:[[:space:]]*"\([^"]*\)".*/\1/p' | head -1)
|
|
67
|
-
|
|
68
|
-
if [[ -z "$FIRST_MESSAGE_TEXT" ]]; then
|
|
69
|
-
exit 0
|
|
70
|
-
fi
|
|
71
|
-
|
|
72
|
-
# Get Cyclist port (if running)
|
|
73
|
-
CYCLIST_PORT=""
|
|
74
|
-
PORT_FILE="$PROJECT_ROOT/.cyclist-port"
|
|
75
|
-
if [[ -f "$PORT_FILE" ]]; then
|
|
76
|
-
CYCLIST_PORT=$(cat "$PORT_FILE" 2>/dev/null)
|
|
77
|
-
fi
|
|
78
|
-
|
|
79
|
-
# Output the hook response JSON
|
|
80
|
-
cat << EOF
|
|
81
|
-
{
|
|
82
|
-
"hookSpecificOutput": {
|
|
83
|
-
"hookEventName": "PostToolUse",
|
|
84
|
-
"additionalContext": "User feedback: $FIRST_MESSAGE_TEXT"
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
EOF
|
|
88
|
-
|
|
89
|
-
# Remove the first message from the queue and notify Cyclist
|
|
90
|
-
# Run in background to avoid blocking hook response
|
|
91
|
-
(
|
|
92
|
-
# Dequeue using jq if available
|
|
93
|
-
if command -v jq &> /dev/null; then
|
|
94
|
-
jq 'if length > 0 then .[1:] else [] end' "$BELL_QUEUE_FILE" > "$BELL_QUEUE_FILE.tmp" 2>/dev/null && mv "$BELL_QUEUE_FILE.tmp" "$BELL_QUEUE_FILE"
|
|
95
|
-
fi
|
|
96
|
-
|
|
97
|
-
# Notify Cyclist browser to dequeue and display the message
|
|
98
|
-
if [[ -n "$CYCLIST_PORT" ]] && [[ "$CYCLIST_PORT" =~ ^[0-9]+$ ]]; then
|
|
99
|
-
curl -s -X POST "http://localhost:$CYCLIST_PORT/api/bell-consumed" \
|
|
100
|
-
-H "Content-Type: application/json" \
|
|
101
|
-
-d "{\"text\": \"$FIRST_MESSAGE_TEXT\"}" \
|
|
102
|
-
>/dev/null 2>&1 || true
|
|
103
|
-
fi
|
|
104
|
-
) &
|
|
105
|
-
|
|
106
|
-
exit 0
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env zsh
|
|
2
|
-
# Context circuit breaker hook: Block tool execution at 85% context usage
|
|
3
|
-
# Called by Claude Code before tool calls (PreToolUse)
|
|
4
|
-
#
|
|
5
|
-
# Input: JSON via stdin with tool_name, tool_input, session_id
|
|
6
|
-
# Output: Exit 0 to allow, Exit 2 to block (stderr shown to Claude)
|
|
7
|
-
#
|
|
8
|
-
# This hook provides a hard stop when context is critically high,
|
|
9
|
-
# unlike context-warning.sh which only warns.
|
|
10
|
-
#
|
|
11
|
-
# When triggered, automatically saves the active agent to a checkpoint
|
|
12
|
-
# so /continue-session can restore it with FULL tier.
|
|
13
|
-
|
|
14
|
-
# Read stdin to get session_id (required by hook protocol)
|
|
15
|
-
INPUT=$(cat)
|
|
16
|
-
|
|
17
|
-
# Script location for sibling script references
|
|
18
|
-
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
|
19
|
-
|
|
20
|
-
# Get context percentage from check-context.sh
|
|
21
|
-
CONTEXT_SCRIPT="$SCRIPT_DIR/../check-context.sh"
|
|
22
|
-
if [[ ! -x "$CONTEXT_SCRIPT" ]]; then
|
|
23
|
-
# graceful degradation: if check-context.sh not found, allow the tool
|
|
24
|
-
exit 0
|
|
25
|
-
fi
|
|
26
|
-
|
|
27
|
-
# Run check-context.sh and parse output
|
|
28
|
-
eval "$("$CONTEXT_SCRIPT" 2>/dev/null)" 2>/dev/null
|
|
29
|
-
|
|
30
|
-
# graceful degradation: if we can't get context, allow the tool
|
|
31
|
-
if [[ -z "$CONTEXT_PERCENT" ]] || [[ "$CONTEXT_PERCENT" == "null" ]]; then
|
|
32
|
-
exit 0
|
|
33
|
-
fi
|
|
34
|
-
|
|
35
|
-
# Load critical threshold (default 80%)
|
|
36
|
-
CRITICAL_THRESHOLD="${CRITICAL_THRESHOLD:-80}"
|
|
37
|
-
|
|
38
|
-
# Check if at or above critical threshold
|
|
39
|
-
if [[ "$CONTEXT_PERCENT" -ge "$CRITICAL_THRESHOLD" ]] 2>/dev/null; then
|
|
40
|
-
# Auto-save active agent to checkpoint before blocking
|
|
41
|
-
# This allows /continue-session to restore with FULL tier
|
|
42
|
-
source "$SCRIPT_DIR/../lib/checkpoint.sh" 2>/dev/null || true
|
|
43
|
-
|
|
44
|
-
# Get session_id from input JSON
|
|
45
|
-
SESSION_ID=""
|
|
46
|
-
if command -v jq &>/dev/null && [[ -n "$INPUT" ]]; then
|
|
47
|
-
SESSION_ID=$(echo "$INPUT" | jq -r '.session_id // empty' 2>/dev/null)
|
|
48
|
-
fi
|
|
49
|
-
|
|
50
|
-
# Look up active agent for this session
|
|
51
|
-
ACTIVE_AGENT=""
|
|
52
|
-
AGENT_FILE="${CLAUDE_PROJECT_DIR:-.}/.session/agents/${SESSION_ID}"
|
|
53
|
-
if [[ -n "$SESSION_ID" && -f "$AGENT_FILE" ]]; then
|
|
54
|
-
ACTIVE_AGENT=$(cat "$AGENT_FILE" 2>/dev/null)
|
|
55
|
-
fi
|
|
56
|
-
|
|
57
|
-
# Save agent checkpoint if we found one
|
|
58
|
-
if [[ -n "$ACTIVE_AGENT" ]]; then
|
|
59
|
-
checkpoint_save "circuit_breaker_agent" "$ACTIVE_AGENT" 2>/dev/null || true
|
|
60
|
-
fi
|
|
61
|
-
|
|
62
|
-
# Send error message to stderr (Claude will see this)
|
|
63
|
-
cat >&2 << EOF
|
|
64
|
-
CONTEXT CIRCUIT BREAKER TRIGGERED
|
|
65
|
-
|
|
66
|
-
Context usage: ${CONTEXT_PERCENT}% - CRITICAL (threshold: ${CRITICAL_THRESHOLD}%)
|
|
67
|
-
|
|
68
|
-
Tool execution BLOCKED. You must stop and hand off.
|
|
69
|
-
EOF
|
|
70
|
-
|
|
71
|
-
# Include agent info if available
|
|
72
|
-
if [[ -n "$ACTIVE_AGENT" ]]; then
|
|
73
|
-
cat >&2 << EOF
|
|
74
|
-
|
|
75
|
-
Active agent saved: ${ACTIVE_AGENT}
|
|
76
|
-
The agent will be restored with FULL context when you run /continue-session.
|
|
77
|
-
EOF
|
|
78
|
-
fi
|
|
79
|
-
|
|
80
|
-
cat >&2 << EOF
|
|
81
|
-
|
|
82
|
-
Required actions:
|
|
83
|
-
1. Commit any pending changes
|
|
84
|
-
2. Tell user to start fresh session with /continue-session
|
|
85
|
-
|
|
86
|
-
DO NOT attempt further tool calls. This is a hard stop.
|
|
87
|
-
|
|
88
|
-
To resume later: /continue-session
|
|
89
|
-
EOF
|
|
90
|
-
# Exit 2 blocks the tool execution
|
|
91
|
-
exit 2
|
|
92
|
-
fi
|
|
93
|
-
|
|
94
|
-
# Below threshold: allow the tool
|
|
95
|
-
exit 0
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env zsh
|
|
2
|
-
# Context warning hook: Warn agent when context usage is high
|
|
3
|
-
# Called by Claude Code before tool calls (PreToolUse)
|
|
4
|
-
#
|
|
5
|
-
# Input: JSON via stdin with tool_name, tool_input
|
|
6
|
-
# Output: Warning message to stdout if context > 60%
|
|
7
|
-
# Always exits 0 (warning only, never blocks)
|
|
8
|
-
|
|
9
|
-
# Read and discard stdin (required by hook protocol)
|
|
10
|
-
cat > /dev/null
|
|
11
|
-
|
|
12
|
-
# Script location for sibling script references
|
|
13
|
-
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
|
14
|
-
|
|
15
|
-
# Get context percentage from check-context.sh
|
|
16
|
-
CONTEXT_SCRIPT="$SCRIPT_DIR/../check-context.sh"
|
|
17
|
-
if [[ ! -x "$CONTEXT_SCRIPT" ]]; then
|
|
18
|
-
exit 0 # Can't check, allow silently
|
|
19
|
-
fi
|
|
20
|
-
|
|
21
|
-
# Run check-context.sh and parse output
|
|
22
|
-
eval "$("$CONTEXT_SCRIPT" 2>/dev/null)" 2>/dev/null
|
|
23
|
-
|
|
24
|
-
# Check if we got a valid percentage
|
|
25
|
-
if [[ -z "$CONTEXT_PERCENT" ]] || [[ "$CONTEXT_PERCENT" == "null" ]]; then
|
|
26
|
-
exit 0 # Can't determine, allow silently
|
|
27
|
-
fi
|
|
28
|
-
|
|
29
|
-
# Load thresholds from settings (defaults match check-context.sh)
|
|
30
|
-
WARNING_THRESHOLD="${WARNING_THRESHOLD:-60}"
|
|
31
|
-
CRITICAL_THRESHOLD="${CRITICAL_THRESHOLD:-85}"
|
|
32
|
-
|
|
33
|
-
# Output warning if above threshold
|
|
34
|
-
if [[ "$CONTEXT_PERCENT" -ge "$CRITICAL_THRESHOLD" ]] 2>/dev/null; then
|
|
35
|
-
cat << EOF
|
|
36
|
-
|
|
37
|
-
---
|
|
38
|
-
CONTEXT WARNING: ${CONTEXT_PERCENT}% (CRITICAL)
|
|
39
|
-
|
|
40
|
-
Context usage is critically high. Recommended actions:
|
|
41
|
-
1. Complete current task immediately
|
|
42
|
-
2. Commit any pending changes
|
|
43
|
-
3. Hand off to next agent or ask user to start fresh session
|
|
44
|
-
|
|
45
|
-
Do NOT start new subtasks. Wrap up and hand off.
|
|
46
|
-
---
|
|
47
|
-
|
|
48
|
-
EOF
|
|
49
|
-
elif [[ "$CONTEXT_PERCENT" -ge "$WARNING_THRESHOLD" ]] 2>/dev/null; then
|
|
50
|
-
cat << EOF
|
|
51
|
-
|
|
52
|
-
---
|
|
53
|
-
CONTEXT WARNING: ${CONTEXT_PERCENT}%
|
|
54
|
-
|
|
55
|
-
Context usage is high. Consider:
|
|
56
|
-
- Wrapping up current task soon
|
|
57
|
-
- Preparing for handoff to next agent
|
|
58
|
-
- Avoiding large file reads or complex operations
|
|
59
|
-
---
|
|
60
|
-
|
|
61
|
-
EOF
|
|
62
|
-
fi
|
|
63
|
-
|
|
64
|
-
# Always allow the tool (we're warning, not blocking)
|
|
65
|
-
exit 0
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# otel-auto-config.sh - Auto-configure OTEL for Cyclist web mode (Story 20-1)
|
|
3
|
-
#
|
|
4
|
-
# This hook checks for a .cyclist-port file in the project directory.
|
|
5
|
-
# If found, it sets the OTEL environment variables to connect Claude Code
|
|
6
|
-
# telemetry to the running Cyclist server.
|
|
7
|
-
#
|
|
8
|
-
# Usage: Source this script early in Claude Code startup to enable auto-config.
|
|
9
|
-
# source /path/to/otel-auto-config.sh
|
|
10
|
-
#
|
|
11
|
-
# Prerequisites:
|
|
12
|
-
# - Cyclist must be running in web mode (writes .cyclist-port file)
|
|
13
|
-
# - CLAUDE_PROJECT_DIR must be set (standard in Claude Code environment)
|
|
14
|
-
|
|
15
|
-
# Determine project directory
|
|
16
|
-
PROJECT_DIR="${CLAUDE_PROJECT_DIR:-$(pwd)}"
|
|
17
|
-
PORT_FILE="$PROJECT_DIR/.cyclist-port"
|
|
18
|
-
|
|
19
|
-
# Check if port file exists
|
|
20
|
-
if [[ -f "$PORT_FILE" ]]; then
|
|
21
|
-
# Read the port number
|
|
22
|
-
PORT=$(cat "$PORT_FILE" 2>/dev/null)
|
|
23
|
-
|
|
24
|
-
# Validate port is a number
|
|
25
|
-
if [[ "$PORT" =~ ^[0-9]+$ ]]; then
|
|
26
|
-
# Set OTEL environment variables
|
|
27
|
-
export OTEL_EXPORTER_OTLP_PROTOCOL="http/json"
|
|
28
|
-
export OTEL_EXPORTER_OTLP_ENDPOINT="http://localhost:$PORT"
|
|
29
|
-
|
|
30
|
-
# Optional: Log for debugging (can be silenced by setting CYCLIST_QUIET=1)
|
|
31
|
-
if [[ -z "$CYCLIST_QUIET" ]]; then
|
|
32
|
-
echo "[otel-auto-config] Configured OTEL to http://localhost:$PORT" >&2
|
|
33
|
-
fi
|
|
34
|
-
fi
|
|
35
|
-
fi
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# post-merge.sh - Git hook for automatic sprint YAML updates after PR merge
|
|
3
|
-
# Story 8-1: Git Hook for PR Merge Detection
|
|
4
|
-
#
|
|
5
|
-
# This hook runs after git pull or git merge operations, detecting when a
|
|
6
|
-
# story branch is merged and automatically updating the sprint YAML status.
|
|
7
|
-
#
|
|
8
|
-
# Installation:
|
|
9
|
-
# Installed to .git/hooks/post-merge by pennyfarthing init or doctor --fix
|
|
10
|
-
#
|
|
11
|
-
# Dependencies:
|
|
12
|
-
# - yq (for YAML manipulation)
|
|
13
|
-
# - sprint-common.sh (for shared sprint functions)
|
|
14
|
-
|
|
15
|
-
set -uo pipefail
|
|
16
|
-
|
|
17
|
-
# Self-locate (resolve symlink first for .git/hooks/ symlinks)
|
|
18
|
-
REAL_SCRIPT="$(readlink -f "${BASH_SOURCE[0]:-$0}" 2>/dev/null || realpath "${BASH_SOURCE[0]:-$0}" 2>/dev/null || echo "${BASH_SOURCE[0]:-$0}")"
|
|
19
|
-
source "$(dirname "$REAL_SCRIPT")/../lib/find-root.sh"
|
|
20
|
-
|
|
21
|
-
# PROJECT_ROOT is now set by find-root.sh
|
|
22
|
-
SESSION_DIR="$PROJECT_ROOT/.session"
|
|
23
|
-
SPRINT_FILE="$PROJECT_ROOT/sprint/current-sprint.yaml"
|
|
24
|
-
|
|
25
|
-
# Source sprint-common.sh for shared functions
|
|
26
|
-
SPRINT_COMMON="$PROJECT_ROOT/.pennyfarthing/scripts/sprint/sprint-common.sh"
|
|
27
|
-
if [[ -f "$SPRINT_COMMON" ]]; then
|
|
28
|
-
# shellcheck source=/dev/null
|
|
29
|
-
source "$SPRINT_COMMON"
|
|
30
|
-
fi
|
|
31
|
-
|
|
32
|
-
# extract_story_id BRANCH_NAME
|
|
33
|
-
# Extract story ID from branch name pattern feat/X-Y-*
|
|
34
|
-
# Returns: X-Y (e.g., "8-1" from "feat/8-1-merge-detection")
|
|
35
|
-
# Returns empty for non-matching branches
|
|
36
|
-
extract_story_id() {
|
|
37
|
-
local branch="$1"
|
|
38
|
-
|
|
39
|
-
# Match pattern: feat/EPIC-STORY-description or feat/EPIC-STORY
|
|
40
|
-
if [[ "$branch" =~ ^feat/([0-9]+-[0-9]+) ]]; then
|
|
41
|
-
echo "${BASH_REMATCH[1]}"
|
|
42
|
-
fi
|
|
43
|
-
# Returns empty string for non-matching patterns
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
# update_story_status STORY_ID NEW_STATUS
|
|
47
|
-
# Update story status in sprint YAML and add completed date
|
|
48
|
-
# Uses yq for YAML manipulation
|
|
49
|
-
update_story_status() {
|
|
50
|
-
local story_id="$1"
|
|
51
|
-
local new_status="${2:-done}"
|
|
52
|
-
local completed_date
|
|
53
|
-
completed_date=$(date +%Y-%m-%d)
|
|
54
|
-
|
|
55
|
-
if [[ ! -f "$SPRINT_FILE" ]]; then
|
|
56
|
-
return 1
|
|
57
|
-
fi
|
|
58
|
-
|
|
59
|
-
# Check if yq is available
|
|
60
|
-
if ! command -v yq &>/dev/null; then
|
|
61
|
-
echo "Warning: yq not found, cannot update sprint YAML" >&2
|
|
62
|
-
return 1
|
|
63
|
-
fi
|
|
64
|
-
|
|
65
|
-
# Extract epic and story numbers
|
|
66
|
-
local epic_num="${story_id%%-*}"
|
|
67
|
-
local story_num="${story_id#*-}"
|
|
68
|
-
|
|
69
|
-
# Update status and add completed date using yq
|
|
70
|
-
yq eval -i "
|
|
71
|
-
(.epics[] | select(.id == \"$epic_num\") | .stories[] | select(.id == \"$story_num\")).status = \"$new_status\" |
|
|
72
|
-
(.epics[] | select(.id == \"$epic_num\") | .stories[] | select(.id == \"$story_num\")).completed = \"$completed_date\"
|
|
73
|
-
" "$SPRINT_FILE"
|
|
74
|
-
|
|
75
|
-
return $?
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
# log_reconciliation STORY_ID MESSAGE
|
|
79
|
-
# Log reconciliation event to .session/ directory
|
|
80
|
-
log_reconciliation() {
|
|
81
|
-
local story_id="$1"
|
|
82
|
-
local message="${2:-Merge detected}"
|
|
83
|
-
local timestamp
|
|
84
|
-
timestamp=$(date +"%Y-%m-%d %H:%M:%S")
|
|
85
|
-
|
|
86
|
-
# Ensure session directory exists
|
|
87
|
-
mkdir -p "$SESSION_DIR"
|
|
88
|
-
|
|
89
|
-
local log_file="$SESSION_DIR/reconciliation.log"
|
|
90
|
-
|
|
91
|
-
echo "[$timestamp] Story $story_id: $message" >> "$log_file"
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
# Main hook logic
|
|
95
|
-
main() {
|
|
96
|
-
# Get the current branch after merge
|
|
97
|
-
local current_branch
|
|
98
|
-
current_branch=$(git rev-parse --abbrev-ref HEAD 2>/dev/null)
|
|
99
|
-
|
|
100
|
-
# Only process if we're on develop or main (after a PR merge)
|
|
101
|
-
if [[ "$current_branch" != "develop" && "$current_branch" != "main" ]]; then
|
|
102
|
-
exit 0
|
|
103
|
-
fi
|
|
104
|
-
|
|
105
|
-
# Get the branches that were just merged
|
|
106
|
-
# The reflog shows what was merged: the previous HEAD and the merged commit
|
|
107
|
-
local merged_refs
|
|
108
|
-
merged_refs=$(git reflog -1 --format='%gs' 2>/dev/null)
|
|
109
|
-
|
|
110
|
-
# Check if this was a merge operation
|
|
111
|
-
if [[ ! "$merged_refs" =~ merge ]]; then
|
|
112
|
-
# Could be a pull with fast-forward - check for merged branches
|
|
113
|
-
# Look at recently merged branches by checking merge commits
|
|
114
|
-
:
|
|
115
|
-
fi
|
|
116
|
-
|
|
117
|
-
# Find recently merged feature branches by examining merge commits
|
|
118
|
-
local merge_commits
|
|
119
|
-
merge_commits=$(git log --merges --oneline -10 --since="5 minutes ago" 2>/dev/null)
|
|
120
|
-
|
|
121
|
-
# Extract branch names from merge commits
|
|
122
|
-
while IFS= read -r commit_line; do
|
|
123
|
-
# Parse "Merge pull request #X from user/feat/X-Y-description"
|
|
124
|
-
# or "Merge branch 'feat/X-Y-description'"
|
|
125
|
-
local branch_name=""
|
|
126
|
-
|
|
127
|
-
if [[ "$commit_line" =~ feat/([0-9]+-[0-9]+[a-zA-Z0-9-]*) ]]; then
|
|
128
|
-
branch_name="feat/${BASH_REMATCH[1]}"
|
|
129
|
-
fi
|
|
130
|
-
|
|
131
|
-
if [[ -n "$branch_name" ]]; then
|
|
132
|
-
local story_id
|
|
133
|
-
story_id=$(extract_story_id "$branch_name")
|
|
134
|
-
|
|
135
|
-
if [[ -n "$story_id" ]]; then
|
|
136
|
-
# Update sprint YAML
|
|
137
|
-
if update_story_status "$story_id" "done"; then
|
|
138
|
-
log_reconciliation "$story_id" "Status updated to 'done' after merge (branch: $branch_name)"
|
|
139
|
-
else
|
|
140
|
-
log_reconciliation "$story_id" "Failed to update status (branch: $branch_name)"
|
|
141
|
-
fi
|
|
142
|
-
fi
|
|
143
|
-
fi
|
|
144
|
-
done <<< "$merge_commits"
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
# Only run main when executed directly (not when sourced for testing)
|
|
148
|
-
if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then
|
|
149
|
-
main "$@"
|
|
150
|
-
fi
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# pre-commit.sh - Git hook to enforce branch protection and agent validation
|
|
3
|
-
#
|
|
4
|
-
# Checks:
|
|
5
|
-
# 1. Prevents direct commits to protected branches (main, develop)
|
|
6
|
-
# Exception: sprint/ folder commits allowed on develop
|
|
7
|
-
# 2. Validates agent files when pennyfarthing-dist/agents/*.md is modified
|
|
8
|
-
#
|
|
9
|
-
# Installation:
|
|
10
|
-
# Installed to .git/hooks/pre-commit by pennyfarthing init or doctor --fix
|
|
11
|
-
# Or symlink: ln -sf ../../pennyfarthing-dist/scripts/hooks/pre-commit.sh .git/hooks/pre-commit
|
|
12
|
-
|
|
13
|
-
set -uo pipefail
|
|
14
|
-
|
|
15
|
-
# Find project root (resolve symlink first for .git/hooks/ symlinks)
|
|
16
|
-
REAL_SCRIPT="$(readlink -f "${BASH_SOURCE[0]:-$0}" 2>/dev/null || realpath "${BASH_SOURCE[0]:-$0}" 2>/dev/null || echo "${BASH_SOURCE[0]:-$0}")"
|
|
17
|
-
source "$(dirname "$REAL_SCRIPT")/../lib/find-root.sh"
|
|
18
|
-
|
|
19
|
-
# =============================================================================
|
|
20
|
-
# Check 1: Branch Protection
|
|
21
|
-
# =============================================================================
|
|
22
|
-
|
|
23
|
-
BRANCH=$(git rev-parse --abbrev-ref HEAD 2>/dev/null)
|
|
24
|
-
PROTECTED_BRANCHES="^(main|develop)$"
|
|
25
|
-
|
|
26
|
-
if [[ $BRANCH =~ $PROTECTED_BRANCHES ]]; then
|
|
27
|
-
# Special case: Allow sprint/ folder commits on develop branch
|
|
28
|
-
if [[ $BRANCH == "develop" ]]; then
|
|
29
|
-
STAGED_FILES=$(git diff --cached --name-only)
|
|
30
|
-
NON_SPRINT_FILES=$(echo "$STAGED_FILES" | grep -v "^sprint/")
|
|
31
|
-
|
|
32
|
-
# If all staged files are in sprint/, allow the commit
|
|
33
|
-
if [ -z "$NON_SPRINT_FILES" ] && [ -n "$STAGED_FILES" ]; then
|
|
34
|
-
# Continue to agent validation check
|
|
35
|
-
:
|
|
36
|
-
else
|
|
37
|
-
echo ""
|
|
38
|
-
echo "COMMIT BLOCKED"
|
|
39
|
-
echo ""
|
|
40
|
-
echo "You are trying to commit directly to: $BRANCH"
|
|
41
|
-
echo "This violates the git workflow rules."
|
|
42
|
-
echo ""
|
|
43
|
-
echo "Protected branches: main, develop"
|
|
44
|
-
echo ""
|
|
45
|
-
echo "What to do:"
|
|
46
|
-
echo "1. Create a feature branch:"
|
|
47
|
-
echo " git checkout -b <type>/<epic-story>-<description>"
|
|
48
|
-
echo ""
|
|
49
|
-
echo "2. Example:"
|
|
50
|
-
echo " git checkout -b feat/8-2-add-authentication"
|
|
51
|
-
echo ""
|
|
52
|
-
echo "3. Then commit your changes on the feature branch"
|
|
53
|
-
echo ""
|
|
54
|
-
echo "Exception: Sprint tracking files (sprint/*) can be committed to develop"
|
|
55
|
-
echo ""
|
|
56
|
-
exit 1
|
|
57
|
-
fi
|
|
58
|
-
else
|
|
59
|
-
echo ""
|
|
60
|
-
echo "COMMIT BLOCKED - Cannot commit directly to $BRANCH"
|
|
61
|
-
echo ""
|
|
62
|
-
exit 1
|
|
63
|
-
fi
|
|
64
|
-
fi
|
|
65
|
-
|
|
66
|
-
# =============================================================================
|
|
67
|
-
# Check 2: Agent File Validation
|
|
68
|
-
# =============================================================================
|
|
69
|
-
|
|
70
|
-
STAGED_FILES=$(git diff --cached --name-only 2>/dev/null || true)
|
|
71
|
-
AGENT_FILES=$(echo "$STAGED_FILES" | grep "^pennyfarthing-dist/agents/.*\.md$" || true)
|
|
72
|
-
|
|
73
|
-
if [[ -n "$AGENT_FILES" ]]; then
|
|
74
|
-
echo "Agent files staged for commit:"
|
|
75
|
-
echo "$AGENT_FILES" | sed 's/^/ /'
|
|
76
|
-
echo ""
|
|
77
|
-
|
|
78
|
-
VALIDATOR="$PROJECT_ROOT/pennyfarthing-dist/scripts/validation/validate-agent-schema.sh"
|
|
79
|
-
|
|
80
|
-
if [[ -x "$VALIDATOR" ]]; then
|
|
81
|
-
echo "Running agent schema validation..."
|
|
82
|
-
echo ""
|
|
83
|
-
|
|
84
|
-
if ! "$VALIDATOR"; then
|
|
85
|
-
echo ""
|
|
86
|
-
echo "COMMIT BLOCKED - Agent validation failed"
|
|
87
|
-
echo ""
|
|
88
|
-
echo "Fix the validation errors above and try again."
|
|
89
|
-
echo "Run 'just validate-agents -v' for detailed output."
|
|
90
|
-
echo ""
|
|
91
|
-
exit 1
|
|
92
|
-
fi
|
|
93
|
-
|
|
94
|
-
echo ""
|
|
95
|
-
echo "✓ Agent validation passed"
|
|
96
|
-
else
|
|
97
|
-
echo "Warning: Agent validator not found at $VALIDATOR"
|
|
98
|
-
echo "Skipping agent validation."
|
|
99
|
-
fi
|
|
100
|
-
fi
|
|
101
|
-
|
|
102
|
-
exit 0
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env zsh
|
|
2
|
-
# Pre-edit hook: Verify edits don't touch protected files
|
|
3
|
-
# Called by Claude Code before Edit/Write tool calls
|
|
4
|
-
#
|
|
5
|
-
# Input: JSON via stdin with tool_name, tool_input
|
|
6
|
-
# Output: Exit 0 to allow, Exit 2 to block (stderr shown to Claude)
|
|
7
|
-
|
|
8
|
-
set -euo pipefail
|
|
9
|
-
|
|
10
|
-
# Read input from stdin
|
|
11
|
-
input=$(cat)
|
|
12
|
-
|
|
13
|
-
# Extract file path from tool input
|
|
14
|
-
file_path=$(echo "$input" | jq -r '.tool_input.file_path // .tool_input.path // ""')
|
|
15
|
-
|
|
16
|
-
# Protected patterns (files that should never be edited automatically)
|
|
17
|
-
protected_patterns=(
|
|
18
|
-
"*.env"
|
|
19
|
-
"*.pem"
|
|
20
|
-
"*.key"
|
|
21
|
-
"*credentials*"
|
|
22
|
-
"*secrets*"
|
|
23
|
-
".git/*"
|
|
24
|
-
"node_modules/*"
|
|
25
|
-
"vendor/*"
|
|
26
|
-
)
|
|
27
|
-
|
|
28
|
-
# Pennyfarthing managed files protection
|
|
29
|
-
# These are managed by `pennyfarthing update`, don't edit directly
|
|
30
|
-
# EXCEPTION: If we ARE in the pennyfarthing library itself, allow edits
|
|
31
|
-
is_pennyfarthing_lib=false
|
|
32
|
-
if [[ -d "${CLAUDE_PROJECT_DIR:-$PWD}/pennyfarthing-dist" ]]; then
|
|
33
|
-
is_pennyfarthing_lib=true
|
|
34
|
-
fi
|
|
35
|
-
|
|
36
|
-
if [[ "$file_path" == *".claude/pennyfarthing/"* ]] && [[ "$is_pennyfarthing_lib" == "false" ]]; then
|
|
37
|
-
echo "BLOCKED: Cannot edit managed pennyfarthing files." >&2
|
|
38
|
-
echo "File: $file_path" >&2
|
|
39
|
-
echo "" >&2
|
|
40
|
-
echo "These files are managed by pennyfarthing and will be overwritten on update." >&2
|
|
41
|
-
echo "Instead:" >&2
|
|
42
|
-
echo " - Put project-specific customizations in .claude/project/" >&2
|
|
43
|
-
echo " - For framework changes, edit the pennyfarthing repo and run 'pennyfarthing update'" >&2
|
|
44
|
-
exit 2
|
|
45
|
-
fi
|
|
46
|
-
|
|
47
|
-
# Check if file matches any protected pattern
|
|
48
|
-
for pattern in "${protected_patterns[@]}"; do
|
|
49
|
-
if [[ "$file_path" == $pattern ]]; then
|
|
50
|
-
echo "BLOCKED: Cannot edit protected file matching pattern: $pattern" >&2
|
|
51
|
-
echo "File: $file_path" >&2
|
|
52
|
-
exit 2
|
|
53
|
-
fi
|
|
54
|
-
done
|
|
55
|
-
|
|
56
|
-
# Additional check: warn on certain file types but allow
|
|
57
|
-
warn_patterns=(
|
|
58
|
-
"*.md"
|
|
59
|
-
"*.json"
|
|
60
|
-
)
|
|
61
|
-
|
|
62
|
-
# For warnings, just log to stderr but allow (exit 0)
|
|
63
|
-
for pattern in "${warn_patterns[@]}"; do
|
|
64
|
-
if [[ "$file_path" == $pattern ]]; then
|
|
65
|
-
# Could log warnings here if needed
|
|
66
|
-
:
|
|
67
|
-
fi
|
|
68
|
-
done
|
|
69
|
-
|
|
70
|
-
# Allow the edit
|
|
71
|
-
exit 0
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# pre-push.sh - Git hook to remind about Jira sync before push
|
|
3
|
-
#
|
|
4
|
-
# Checks if sprint files were modified and reminds to sync to Jira.
|
|
5
|
-
#
|
|
6
|
-
# Installation:
|
|
7
|
-
# Installed to .git/hooks/pre-push by pennyfarthing init or doctor --fix
|
|
8
|
-
# Or symlink: ln -sf ../../pennyfarthing-dist/scripts/hooks/pre-push.sh .git/hooks/pre-push
|
|
9
|
-
|
|
10
|
-
set -uo pipefail
|
|
11
|
-
|
|
12
|
-
# Self-locate (resolve symlink first for .git/hooks/ symlinks)
|
|
13
|
-
REAL_SCRIPT="$(readlink -f "${BASH_SOURCE[0]:-$0}" 2>/dev/null || realpath "${BASH_SOURCE[0]:-$0}" 2>/dev/null || echo "${BASH_SOURCE[0]:-$0}")"
|
|
14
|
-
if ! source "$(dirname "$REAL_SCRIPT")/../lib/find-root.sh" 2>/dev/null; then
|
|
15
|
-
exit 0
|
|
16
|
-
fi
|
|
17
|
-
|
|
18
|
-
SPRINT_FILE="$PROJECT_ROOT/sprint/current-sprint.yaml"
|
|
19
|
-
|
|
20
|
-
# Check if there are uncommitted changes to sprint file
|
|
21
|
-
if git diff --name-only | grep -q "sprint/current-sprint.yaml"; then
|
|
22
|
-
echo "Warning: current-sprint.yaml has uncommitted changes"
|
|
23
|
-
echo " Consider committing before pushing"
|
|
24
|
-
echo ""
|
|
25
|
-
fi
|
|
26
|
-
|
|
27
|
-
# Get the range of commits being pushed
|
|
28
|
-
REMOTE="$1"
|
|
29
|
-
URL="$2"
|
|
30
|
-
|
|
31
|
-
while read local_ref local_sha remote_ref remote_sha; do
|
|
32
|
-
if [ "$local_sha" != "0000000000000000000000000000000000000000" ]; then
|
|
33
|
-
# Check if sprint file changed in this push
|
|
34
|
-
if git diff --name-only "$remote_sha..$local_sha" 2>/dev/null | grep -q "sprint/current-sprint.yaml"; then
|
|
35
|
-
echo "Sprint changes detected in push"
|
|
36
|
-
echo " Reminder: Sync to Jira if story statuses changed"
|
|
37
|
-
echo ""
|
|
38
|
-
fi
|
|
39
|
-
fi
|
|
40
|
-
done
|
|
41
|
-
|
|
42
|
-
exit 0
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env bash
|
|
2
|
-
#
|
|
3
|
-
# Question Reflector Enforcement Hook (Stop hook / PreToolUse hook)
|
|
4
|
-
#
|
|
5
|
-
# Thin wrapper that delegates to question_reflector_check.py for the actual logic.
|
|
6
|
-
# This allows the hook to be written in Python for easier testing and maintenance.
|
|
7
|
-
#
|
|
8
|
-
# Input (stdin): JSON with transcript_path, stop_hook_active, etc.
|
|
9
|
-
# Output (stdout): JSON decision to allow or block
|
|
10
|
-
#
|
|
11
|
-
# Story: MSSCI-12393
|
|
12
|
-
#
|
|
13
|
-
|
|
14
|
-
set -euo pipefail
|
|
15
|
-
|
|
16
|
-
# Get the directory where this script lives
|
|
17
|
-
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
18
|
-
|
|
19
|
-
# Delegate to Python implementation
|
|
20
|
-
exec python3 "$SCRIPT_DIR/question_reflector_check.py"
|