@slopus/beer 0.1.1 → 0.1.4
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/README.md +10 -8
- package/dist/_workflows/_index.d.ts +14 -0
- package/dist/_workflows/_index.d.ts.map +1 -0
- package/dist/_workflows/_index.js +46 -0
- package/dist/_workflows/_index.js.map +1 -0
- package/dist/_workflows/bootstrap.d.ts +6 -0
- package/dist/_workflows/bootstrap.d.ts.map +1 -0
- package/dist/_workflows/bootstrap.js +109 -0
- package/dist/_workflows/bootstrap.js.map +1 -0
- package/dist/_workflows/checkpointWorkflow.d.ts +7 -0
- package/dist/_workflows/checkpointWorkflow.d.ts.map +1 -0
- package/dist/_workflows/checkpointWorkflow.js +11 -0
- package/dist/_workflows/checkpointWorkflow.js.map +1 -0
- package/dist/_workflows/context/context.d.ts +100 -0
- package/dist/_workflows/context/context.d.ts.map +1 -0
- package/dist/_workflows/context/context.js +246 -0
- package/dist/_workflows/context/context.js.map +1 -0
- package/dist/_workflows/context/context.spec.d.ts +2 -0
- package/dist/_workflows/context/context.spec.d.ts.map +1 -0
- package/dist/_workflows/context/context.spec.js +230 -0
- package/dist/_workflows/context/context.spec.js.map +1 -0
- package/dist/_workflows/context/utils/contextApplyConfig.d.ts +7 -0
- package/dist/_workflows/context/utils/contextApplyConfig.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextApplyConfig.js +22 -0
- package/dist/_workflows/context/utils/contextApplyConfig.js.map +1 -0
- package/dist/_workflows/context/utils/contextApplyConfig.spec.d.ts +2 -0
- package/dist/_workflows/context/utils/contextApplyConfig.spec.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextApplyConfig.spec.js +24 -0
- package/dist/_workflows/context/utils/contextApplyConfig.spec.js.map +1 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.d.ts +7 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.js +23 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.js.map +1 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.spec.d.ts +2 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.spec.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.spec.js +36 -0
- package/dist/_workflows/context/utils/contextAskGithubRepo.spec.js.map +1 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.d.ts +6 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.js +60 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.js.map +1 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.spec.d.ts +2 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.spec.d.ts.map +1 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.spec.js +35 -0
- package/dist/_workflows/context/utils/contextGitignoreEnsure.spec.js.map +1 -0
- package/dist/_workflows/context/utils/progressMultilineStart.d.ts +15 -0
- package/dist/_workflows/context/utils/progressMultilineStart.d.ts.map +1 -0
- package/dist/_workflows/context/utils/progressMultilineStart.js +115 -0
- package/dist/_workflows/context/utils/progressMultilineStart.js.map +1 -0
- package/dist/_workflows/context/utils/progressMultilineStart.spec.d.ts +2 -0
- package/dist/_workflows/context/utils/progressMultilineStart.spec.d.ts.map +1 -0
- package/dist/_workflows/context/utils/progressMultilineStart.spec.js +30 -0
- package/dist/_workflows/context/utils/progressMultilineStart.spec.js.map +1 -0
- package/dist/_workflows/context/utils/progressStart.d.ts +11 -0
- package/dist/_workflows/context/utils/progressStart.d.ts.map +1 -0
- package/dist/_workflows/context/utils/progressStart.js +73 -0
- package/dist/_workflows/context/utils/progressStart.js.map +1 -0
- package/dist/_workflows/planWorkflow.d.ts +7 -0
- package/dist/_workflows/planWorkflow.d.ts.map +1 -0
- package/dist/_workflows/planWorkflow.js +63 -0
- package/dist/_workflows/planWorkflow.js.map +1 -0
- package/dist/_workflows/ralphLoopWorkflow.d.ts +7 -0
- package/dist/_workflows/ralphLoopWorkflow.d.ts.map +1 -0
- package/dist/_workflows/ralphLoopWorkflow.js +21 -0
- package/dist/_workflows/ralphLoopWorkflow.js.map +1 -0
- package/dist/_workflows/ralphWorkflow.d.ts +7 -0
- package/dist/_workflows/ralphWorkflow.d.ts.map +1 -0
- package/dist/_workflows/ralphWorkflow.js +19 -0
- package/dist/_workflows/ralphWorkflow.js.map +1 -0
- package/dist/_workflows/researchWorkflow.d.ts +7 -0
- package/dist/_workflows/researchWorkflow.d.ts.map +1 -0
- package/dist/_workflows/researchWorkflow.js +312 -0
- package/dist/_workflows/researchWorkflow.js.map +1 -0
- package/dist/_workflows/steps/generate.d.ts +11 -0
- package/dist/_workflows/steps/generate.d.ts.map +1 -0
- package/dist/_workflows/steps/generate.js +42 -0
- package/dist/_workflows/steps/generate.js.map +1 -0
- package/dist/_workflows/steps/generateCommit.d.ts +16 -0
- package/dist/_workflows/steps/generateCommit.d.ts.map +1 -0
- package/dist/_workflows/steps/generateCommit.js +29 -0
- package/dist/_workflows/steps/generateCommit.js.map +1 -0
- package/dist/_workflows/steps/generateDocument.d.ts +26 -0
- package/dist/_workflows/steps/generateDocument.d.ts.map +1 -0
- package/dist/_workflows/steps/generateDocument.js +62 -0
- package/dist/_workflows/steps/generateDocument.js.map +1 -0
- package/dist/_workflows/steps/generateDocument.spec.d.ts +2 -0
- package/dist/_workflows/steps/generateDocument.spec.d.ts.map +1 -0
- package/dist/_workflows/steps/generateDocument.spec.js +56 -0
- package/dist/_workflows/steps/generateDocument.spec.js.map +1 -0
- package/dist/_workflows/steps/generateFrontmatter.d.ts +17 -0
- package/dist/_workflows/steps/generateFrontmatter.d.ts.map +1 -0
- package/dist/_workflows/steps/generateFrontmatter.js +51 -0
- package/dist/_workflows/steps/generateFrontmatter.js.map +1 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.d.ts +10 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.d.ts.map +1 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.js +75 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.js.map +1 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.spec.d.ts +2 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.spec.d.ts.map +1 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.spec.js +53 -0
- package/dist/_workflows/steps/generateProgressMessageResolve.spec.js.map +1 -0
- package/dist/_workflows/steps/generateReadme.d.ts +21 -0
- package/dist/_workflows/steps/generateReadme.d.ts.map +1 -0
- package/dist/_workflows/steps/generateReadme.js +32 -0
- package/dist/_workflows/steps/generateReadme.js.map +1 -0
- package/dist/_workflows/steps/ralphExecute.d.ts +11 -0
- package/dist/_workflows/steps/ralphExecute.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphExecute.js +39 -0
- package/dist/_workflows/steps/ralphExecute.js.map +1 -0
- package/dist/_workflows/steps/ralphLoopExecute.d.ts +11 -0
- package/dist/_workflows/steps/ralphLoopExecute.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphLoopExecute.js +39 -0
- package/dist/_workflows/steps/ralphLoopExecute.js.map +1 -0
- package/dist/_workflows/steps/ralphLoopPlanGenerate.d.ts +15 -0
- package/dist/_workflows/steps/ralphLoopPlanGenerate.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphLoopPlanGenerate.js +46 -0
- package/dist/_workflows/steps/ralphLoopPlanGenerate.js.map +1 -0
- package/dist/_workflows/steps/ralphLoopPlanPathResolve.d.ts +7 -0
- package/dist/_workflows/steps/ralphLoopPlanPathResolve.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphLoopPlanPathResolve.js +21 -0
- package/dist/_workflows/steps/ralphLoopPlanPathResolve.js.map +1 -0
- package/dist/_workflows/steps/ralphLoopReviewRound.d.ts +11 -0
- package/dist/_workflows/steps/ralphLoopReviewRound.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphLoopReviewRound.js +42 -0
- package/dist/_workflows/steps/ralphLoopReviewRound.js.map +1 -0
- package/dist/_workflows/steps/ralphPlan.d.ts +15 -0
- package/dist/_workflows/steps/ralphPlan.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphPlan.js +100 -0
- package/dist/_workflows/steps/ralphPlan.js.map +1 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.d.ts +7 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.js +21 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.js.map +1 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.spec.d.ts +2 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.spec.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.spec.js +19 -0
- package/dist/_workflows/steps/ralphPlanPathResolve.spec.js.map +1 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.d.ts +10 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.js +35 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.js.map +1 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.spec.d.ts +2 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.spec.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.spec.js +46 -0
- package/dist/_workflows/steps/ralphPlanResponseParse.spec.js.map +1 -0
- package/dist/_workflows/steps/ralphReview.d.ts +12 -0
- package/dist/_workflows/steps/ralphReview.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphReview.js +75 -0
- package/dist/_workflows/steps/ralphReview.js.map +1 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.d.ts +6 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.js +8 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.js.map +1 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.spec.d.ts +2 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.spec.d.ts.map +1 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.spec.js +14 -0
- package/dist/_workflows/steps/ralphReviewNoIssuesDetect.spec.js.map +1 -0
- package/dist/main.js +40 -9
- package/dist/main.js.map +1 -1
- package/dist/modules/ai/aiOutputExtract.js.map +1 -1
- package/dist/modules/ai/aiOutputExtract.spec.js +1 -1
- package/dist/modules/ai/aiOutputExtract.spec.js.map +1 -1
- package/dist/modules/ai/generate.d.ts +15 -3
- package/dist/modules/ai/generate.d.ts.map +1 -1
- package/dist/modules/ai/generate.js +115 -27
- package/dist/modules/ai/generate.js.map +1 -1
- package/dist/modules/ai/generate.spec.js +2 -9
- package/dist/modules/ai/generate.spec.js.map +1 -1
- package/dist/modules/ai/generate.unit.spec.d.ts +2 -0
- package/dist/modules/ai/generate.unit.spec.d.ts.map +1 -0
- package/dist/modules/ai/generate.unit.spec.js +185 -0
- package/dist/modules/ai/generate.unit.spec.js.map +1 -0
- package/dist/modules/ai/generateEventTypes.d.ts +26 -0
- package/dist/modules/ai/generateEventTypes.d.ts.map +1 -0
- package/dist/modules/ai/generateEventTypes.js +2 -0
- package/dist/modules/ai/generateEventTypes.js.map +1 -0
- package/dist/modules/ai/generateFile.d.ts +7 -3
- package/dist/modules/ai/generateFile.d.ts.map +1 -1
- package/dist/modules/ai/generateFile.js +26 -13
- package/dist/modules/ai/generateFile.js.map +1 -1
- package/dist/modules/ai/generateFile.spec.js +109 -8
- package/dist/modules/ai/generateFile.spec.js.map +1 -1
- package/dist/modules/ai/generatePureSessionCreate.d.ts +19 -0
- package/dist/modules/ai/generatePureSessionCreate.d.ts.map +1 -0
- package/dist/modules/ai/generatePureSessionCreate.js +31 -0
- package/dist/modules/ai/generatePureSessionCreate.js.map +1 -0
- package/dist/modules/ai/generatePureSessionCreate.spec.d.ts +2 -0
- package/dist/modules/ai/generatePureSessionCreate.spec.d.ts.map +1 -0
- package/dist/modules/ai/generatePureSessionCreate.spec.js +38 -0
- package/dist/modules/ai/generatePureSessionCreate.spec.js.map +1 -0
- package/dist/modules/ai/generatePureText.d.ts +16 -0
- package/dist/modules/ai/generatePureText.d.ts.map +1 -0
- package/dist/modules/ai/generatePureText.js +151 -0
- package/dist/modules/ai/generatePureText.js.map +1 -0
- package/dist/modules/ai/generatePureText.spec.d.ts +2 -0
- package/dist/modules/ai/generatePureText.spec.d.ts.map +1 -0
- package/dist/modules/ai/generatePureText.spec.js +67 -0
- package/dist/modules/ai/generatePureText.spec.js.map +1 -0
- package/dist/modules/ai/generateSessionCreate.d.ts +18 -0
- package/dist/modules/ai/generateSessionCreate.d.ts.map +1 -0
- package/dist/modules/ai/generateSessionCreate.js +31 -0
- package/dist/modules/ai/generateSessionCreate.js.map +1 -0
- package/dist/modules/ai/generateSessionCreate.spec.d.ts +2 -0
- package/dist/modules/ai/generateSessionCreate.spec.d.ts.map +1 -0
- package/dist/modules/ai/generateSessionCreate.spec.js +38 -0
- package/dist/modules/ai/generateSessionCreate.spec.js.map +1 -0
- package/dist/modules/ai/generateText.d.ts +5 -3
- package/dist/modules/ai/generateText.d.ts.map +1 -1
- package/dist/modules/ai/generateText.js +5 -3
- package/dist/modules/ai/generateText.js.map +1 -1
- package/dist/modules/ai/generateText.spec.js +14 -3
- package/dist/modules/ai/generateText.spec.js.map +1 -1
- package/dist/modules/ai/generateVerify.spec.d.ts +2 -0
- package/dist/modules/ai/generateVerify.spec.d.ts.map +1 -0
- package/dist/modules/ai/generateVerify.spec.js +84 -0
- package/dist/modules/ai/generateVerify.spec.js.map +1 -0
- package/dist/modules/ai/providerEventTypes.d.ts +34 -0
- package/dist/modules/ai/providerEventTypes.d.ts.map +1 -0
- package/dist/modules/ai/providerEventTypes.js +2 -0
- package/dist/modules/ai/providerEventTypes.js.map +1 -0
- package/dist/modules/ai/providerGenerate.d.ts +12 -3
- package/dist/modules/ai/providerGenerate.d.ts.map +1 -1
- package/dist/modules/ai/providerGenerate.js +356 -93
- package/dist/modules/ai/providerGenerate.js.map +1 -1
- package/dist/modules/ai/providerGenerate.spec.js +95 -3
- package/dist/modules/ai/providerGenerate.spec.js.map +1 -1
- package/dist/modules/ai/providerGenerate.unit.spec.js +347 -13
- package/dist/modules/ai/providerGenerate.unit.spec.js.map +1 -1
- package/dist/modules/ai/providers/commandJSONL.d.ts +24 -0
- package/dist/modules/ai/providers/commandJSONL.d.ts.map +1 -0
- package/dist/modules/ai/providers/commandJSONL.js +158 -0
- package/dist/modules/ai/providers/commandJSONL.js.map +1 -0
- package/dist/modules/ai/providers/commandJSONL.spec.d.ts +2 -0
- package/dist/modules/ai/providers/commandJSONL.spec.d.ts.map +1 -0
- package/dist/modules/ai/providers/commandJSONL.spec.js +77 -0
- package/dist/modules/ai/providers/commandJSONL.spec.js.map +1 -0
- package/dist/modules/ai/providers/piProviderGenerate.d.ts +25 -0
- package/dist/modules/ai/providers/piProviderGenerate.d.ts.map +1 -0
- package/dist/modules/ai/providers/piProviderGenerate.js +72 -0
- package/dist/modules/ai/providers/piProviderGenerate.js.map +1 -0
- package/dist/modules/ai/providers/piProviderGenerate.spec.d.ts +2 -0
- package/dist/modules/ai/providers/piProviderGenerate.spec.d.ts.map +1 -0
- package/dist/modules/ai/providers/piProviderGenerate.spec.js +136 -0
- package/dist/modules/ai/providers/piProviderGenerate.spec.js.map +1 -0
- package/dist/modules/ai/providers/piProviderTypes.d.ts +77 -0
- package/dist/modules/ai/providers/piProviderTypes.d.ts.map +1 -0
- package/dist/modules/ai/providers/piProviderTypes.js +2 -0
- package/dist/modules/ai/providers/piProviderTypes.js.map +1 -0
- package/dist/modules/beer/beerOriginalPathResolve.d.ts +1 -1
- package/dist/modules/beer/beerOriginalPathResolve.js +2 -2
- package/dist/modules/beer/beerOriginalPathResolve.js.map +1 -1
- package/dist/modules/beer/beerOriginalPathResolve.spec.js +4 -4
- package/dist/modules/beer/beerOriginalPathResolve.spec.js.map +1 -1
- package/dist/modules/beer/beerSettingsRead.d.ts +1 -1
- package/dist/modules/beer/beerSettingsRead.d.ts.map +1 -1
- package/dist/modules/beer/beerSettingsRead.js +3 -2
- package/dist/modules/beer/beerSettingsRead.js.map +1 -1
- package/dist/modules/beer/beerSettingsRead.spec.d.ts +2 -0
- package/dist/modules/beer/beerSettingsRead.spec.d.ts.map +1 -0
- package/dist/modules/beer/beerSettingsRead.spec.js +26 -0
- package/dist/modules/beer/beerSettingsRead.spec.js.map +1 -0
- package/dist/modules/beer/beerSettingsTypes.d.ts +4 -4
- package/dist/modules/beer/beerSettingsTypes.d.ts.map +1 -1
- package/dist/modules/beer/beerSettingsWrite.d.ts +1 -1
- package/dist/modules/beer/beerSettingsWrite.d.ts.map +1 -1
- package/dist/modules/beer/beerSettingsWrite.js.map +1 -1
- package/dist/modules/git/gitPush.js +1 -1
- package/dist/modules/git/gitPush.js.map +1 -1
- package/dist/modules/git/gitRemoteEnsure.js +1 -1
- package/dist/modules/git/gitRemoteEnsure.js.map +1 -1
- package/dist/modules/git/gitRepoCheckout.js +1 -1
- package/dist/modules/git/gitRepoCheckout.js.map +1 -1
- package/dist/modules/git/gitRepoCheckout.spec.js +2 -2
- package/dist/modules/git/gitRepoCheckout.spec.js.map +1 -1
- package/dist/modules/git/gitRepoEnsure.d.ts +6 -0
- package/dist/modules/git/gitRepoEnsure.d.ts.map +1 -0
- package/dist/modules/git/gitRepoEnsure.js +16 -0
- package/dist/modules/git/gitRepoEnsure.js.map +1 -0
- package/dist/modules/git/gitRepoEnsure.spec.d.ts +2 -0
- package/dist/modules/git/gitRepoEnsure.spec.d.ts.map +1 -0
- package/dist/modules/git/gitRepoEnsure.spec.js +45 -0
- package/dist/modules/git/gitRepoEnsure.spec.js.map +1 -0
- package/dist/modules/git/gitStageAndCommit.js +1 -1
- package/dist/modules/git/gitStageAndCommit.js.map +1 -1
- package/dist/modules/git/gitignoreEnsure.d.ts +6 -0
- package/dist/modules/git/gitignoreEnsure.d.ts.map +1 -0
- package/dist/modules/git/gitignoreEnsure.js +36 -0
- package/dist/modules/git/gitignoreEnsure.js.map +1 -0
- package/dist/modules/git/gitignoreEnsure.spec.d.ts +2 -0
- package/dist/modules/git/gitignoreEnsure.spec.d.ts.map +1 -0
- package/dist/modules/git/gitignoreEnsure.spec.js +35 -0
- package/dist/modules/git/gitignoreEnsure.spec.js.map +1 -0
- package/dist/modules/github/githubCliEnsure.js +3 -3
- package/dist/modules/github/githubCliEnsure.js.map +1 -1
- package/dist/modules/github/githubOwnerChoicesGet.js +1 -1
- package/dist/modules/github/githubOwnerChoicesGet.js.map +1 -1
- package/dist/modules/github/githubRepoCreate.d.ts.map +1 -1
- package/dist/modules/github/githubRepoCreate.js +1 -1
- package/dist/modules/github/githubRepoCreate.js.map +1 -1
- package/dist/modules/github/githubRepoExists.d.ts.map +1 -1
- package/dist/modules/github/githubRepoExists.js +4 -2
- package/dist/modules/github/githubRepoExists.js.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.d.ts +1 -1
- package/dist/modules/github/githubRepoNameResolve.d.ts.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.js +3 -3
- package/dist/modules/github/githubRepoNameResolve.js.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.spec.js +1 -1
- package/dist/modules/github/githubRepoNameResolve.spec.js.map +1 -1
- package/dist/modules/github/githubRepoParse.d.ts +1 -1
- package/dist/modules/github/githubRepoParse.d.ts.map +1 -1
- package/dist/modules/github/githubRepoParse.js +1 -3
- package/dist/modules/github/githubRepoParse.js.map +1 -1
- package/dist/modules/github/githubRepoParse.spec.js +1 -1
- package/dist/modules/github/githubRepoParse.spec.js.map +1 -1
- package/dist/modules/github/githubRepoStatusGet.d.ts +1 -1
- package/dist/modules/github/githubRepoStatusGet.d.ts.map +1 -1
- package/dist/modules/github/githubRepoStatusGet.js +3 -3
- package/dist/modules/github/githubRepoStatusGet.js.map +1 -1
- package/dist/modules/github/githubRepoUrlBuild.js.map +1 -1
- package/dist/modules/github/githubTypes.d.ts.map +1 -1
- package/dist/modules/github/githubViewerGet.js +3 -3
- package/dist/modules/github/githubViewerGet.js.map +1 -1
- package/dist/modules/plan/planPromptChildren.d.ts +8 -0
- package/dist/modules/plan/planPromptChildren.d.ts.map +1 -0
- package/dist/modules/plan/planPromptChildren.js +29 -0
- package/dist/modules/plan/planPromptChildren.js.map +1 -0
- package/dist/modules/plan/planPromptChildren.spec.d.ts +2 -0
- package/dist/modules/plan/planPromptChildren.spec.d.ts.map +1 -0
- package/dist/modules/plan/planPromptChildren.spec.js +25 -0
- package/dist/modules/plan/planPromptChildren.spec.js.map +1 -0
- package/dist/modules/plan/planPromptDocument.d.ts +8 -0
- package/dist/modules/plan/planPromptDocument.d.ts.map +1 -0
- package/dist/modules/plan/planPromptDocument.js +36 -0
- package/dist/modules/plan/planPromptDocument.js.map +1 -0
- package/dist/modules/plan/planPromptDocument.spec.d.ts +2 -0
- package/dist/modules/plan/planPromptDocument.spec.d.ts.map +1 -0
- package/dist/modules/plan/planPromptDocument.spec.js +26 -0
- package/dist/modules/plan/planPromptDocument.spec.js.map +1 -0
- package/dist/modules/plan/planPromptPicker.d.ts +7 -0
- package/dist/modules/plan/planPromptPicker.d.ts.map +1 -0
- package/dist/modules/plan/planPromptPicker.js +28 -0
- package/dist/modules/plan/planPromptPicker.js.map +1 -0
- package/dist/modules/plan/planPromptPicker.spec.d.ts +2 -0
- package/dist/modules/plan/planPromptPicker.spec.d.ts.map +1 -0
- package/dist/modules/plan/planPromptPicker.spec.js +21 -0
- package/dist/modules/plan/planPromptPicker.spec.js.map +1 -0
- package/dist/modules/plan/planPromptRoot.d.ts +7 -0
- package/dist/modules/plan/planPromptRoot.d.ts.map +1 -0
- package/dist/modules/plan/planPromptRoot.js +27 -0
- package/dist/modules/plan/planPromptRoot.js.map +1 -0
- package/dist/modules/plan/planPromptRoot.spec.d.ts +2 -0
- package/dist/modules/plan/planPromptRoot.spec.d.ts.map +1 -0
- package/dist/modules/plan/planPromptRoot.spec.js +16 -0
- package/dist/modules/plan/planPromptRoot.spec.js.map +1 -0
- package/dist/modules/plan/planSourceDocumentTypes.d.ts +6 -0
- package/dist/modules/plan/planSourceDocumentTypes.d.ts.map +1 -0
- package/dist/modules/plan/planSourceDocumentTypes.js +2 -0
- package/dist/modules/plan/planSourceDocumentTypes.js.map +1 -0
- package/dist/modules/plan/planSourceDocumentsResolve.d.ts +7 -0
- package/dist/modules/plan/planSourceDocumentsResolve.d.ts.map +1 -0
- package/dist/modules/plan/planSourceDocumentsResolve.js +41 -0
- package/dist/modules/plan/planSourceDocumentsResolve.js.map +1 -0
- package/dist/modules/plan/planSourceDocumentsResolve.spec.d.ts +2 -0
- package/dist/modules/plan/planSourceDocumentsResolve.spec.d.ts.map +1 -0
- package/dist/modules/plan/planSourceDocumentsResolve.spec.js +21 -0
- package/dist/modules/plan/planSourceDocumentsResolve.spec.js.map +1 -0
- package/dist/modules/prompt/promptConfirm.d.ts.map +1 -1
- package/dist/modules/prompt/promptConfirm.js +1 -1
- package/dist/modules/prompt/promptConfirm.js.map +1 -1
- package/dist/modules/prompt/promptInput.d.ts.map +1 -1
- package/dist/modules/prompt/promptInput.js +1 -1
- package/dist/modules/prompt/promptInput.js.map +1 -1
- package/dist/modules/providers/providerDetect.d.ts +1 -1
- package/dist/modules/providers/providerDetect.d.ts.map +1 -1
- package/dist/modules/providers/providerDetect.js +2 -2
- package/dist/modules/providers/providerDetect.js.map +1 -1
- package/dist/modules/providers/providerDetect.spec.js +2 -2
- package/dist/modules/providers/providerDetect.spec.js.map +1 -1
- package/dist/modules/providers/providerModelSelect.d.ts +1 -1
- package/dist/modules/providers/providerModelSelect.d.ts.map +1 -1
- package/dist/modules/providers/providerModelSelect.js +99 -85
- package/dist/modules/providers/providerModelSelect.js.map +1 -1
- package/dist/modules/providers/providerModelSelect.spec.js +68 -28
- package/dist/modules/providers/providerModelSelect.spec.js.map +1 -1
- package/dist/modules/providers/providerModelsGet.d.ts +1 -1
- package/dist/modules/providers/providerModelsGet.d.ts.map +1 -1
- package/dist/modules/providers/providerModelsGet.js +4 -8
- package/dist/modules/providers/providerModelsGet.js.map +1 -1
- package/dist/modules/providers/providerModelsGet.spec.js +2 -2
- package/dist/modules/providers/providerModelsGet.spec.js.map +1 -1
- package/dist/modules/providers/providerPriorityList.d.ts +1 -1
- package/dist/modules/providers/providerPriorityList.d.ts.map +1 -1
- package/dist/modules/providers/providerPriorityList.js.map +1 -1
- package/dist/modules/providers/providerPriorityList.spec.js +3 -7
- package/dist/modules/providers/providerPriorityList.spec.js.map +1 -1
- package/dist/modules/providers/providerTypes.d.ts +1 -1
- package/dist/modules/providers/providerTypes.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.d.ts +2 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js +22 -18
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js +29 -11
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts +3 -2
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceGet.js +9 -4
- package/dist/modules/sandbox/sandboxInferenceGet.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceGet.spec.js +12 -0
- package/dist/modules/sandbox/sandboxInferenceGet.spec.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceTypes.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxPassthrough.d.ts +7 -0
- package/dist/modules/sandbox/sandboxPassthrough.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxPassthrough.js +12 -0
- package/dist/modules/sandbox/sandboxPassthrough.js.map +1 -0
- package/dist/modules/sandbox/sandboxPassthrough.spec.d.ts +2 -0
- package/dist/modules/sandbox/sandboxPassthrough.spec.d.ts.map +1 -0
- package/dist/modules/sandbox/sandboxPassthrough.spec.js +9 -0
- package/dist/modules/sandbox/sandboxPassthrough.spec.js.map +1 -0
- package/dist/modules/sandbox/sandboxTypes.d.ts.map +1 -1
- package/dist/modules/tree/treeChildrenParse.d.ts +7 -0
- package/dist/modules/tree/treeChildrenParse.d.ts.map +1 -0
- package/dist/modules/tree/treeChildrenParse.js +23 -0
- package/dist/modules/tree/treeChildrenParse.js.map +1 -0
- package/dist/modules/tree/treeChildrenRead.d.ts +7 -0
- package/dist/modules/tree/treeChildrenRead.d.ts.map +1 -0
- package/dist/modules/tree/treeChildrenRead.js +44 -0
- package/dist/modules/tree/treeChildrenRead.js.map +1 -0
- package/dist/modules/tree/treeChildrenRead.spec.d.ts +2 -0
- package/dist/modules/tree/treeChildrenRead.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeChildrenRead.spec.js +43 -0
- package/dist/modules/tree/treeChildrenRead.spec.js.map +1 -0
- package/dist/modules/tree/treeChildrenWrite.d.ts +7 -0
- package/dist/modules/tree/treeChildrenWrite.d.ts.map +1 -0
- package/dist/modules/tree/treeChildrenWrite.js +15 -0
- package/dist/modules/tree/treeChildrenWrite.js.map +1 -0
- package/dist/modules/tree/treeChildrenWrite.spec.d.ts +2 -0
- package/dist/modules/tree/treeChildrenWrite.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeChildrenWrite.spec.js +34 -0
- package/dist/modules/tree/treeChildrenWrite.spec.js.map +1 -0
- package/dist/modules/tree/treeInferenceProgressRun.d.ts +7 -0
- package/dist/modules/tree/treeInferenceProgressRun.d.ts.map +1 -0
- package/dist/modules/tree/treeInferenceProgressRun.js +16 -0
- package/dist/modules/tree/treeInferenceProgressRun.js.map +1 -0
- package/dist/modules/tree/treeInferenceProgressRun.spec.d.ts +2 -0
- package/dist/modules/tree/treeInferenceProgressRun.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeInferenceProgressRun.spec.js +35 -0
- package/dist/modules/tree/treeInferenceProgressRun.spec.js.map +1 -0
- package/dist/modules/tree/treeLeafPick.d.ts +7 -0
- package/dist/modules/tree/treeLeafPick.d.ts.map +1 -0
- package/dist/modules/tree/treeLeafPick.js +67 -0
- package/dist/modules/tree/treeLeafPick.js.map +1 -0
- package/dist/modules/tree/treeLeafPick.spec.d.ts +2 -0
- package/dist/modules/tree/treeLeafPick.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeLeafPick.spec.js +119 -0
- package/dist/modules/tree/treeLeafPick.spec.js.map +1 -0
- package/dist/modules/tree/treeNodeExpand.d.ts +12 -0
- package/dist/modules/tree/treeNodeExpand.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeExpand.js +128 -0
- package/dist/modules/tree/treeNodeExpand.js.map +1 -0
- package/dist/modules/tree/treeNodeExpand.spec.d.ts +2 -0
- package/dist/modules/tree/treeNodeExpand.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeExpand.spec.js +146 -0
- package/dist/modules/tree/treeNodeExpand.spec.js.map +1 -0
- package/dist/modules/tree/treeNodePathResolve.d.ts +7 -0
- package/dist/modules/tree/treeNodePathResolve.d.ts.map +1 -0
- package/dist/modules/tree/treeNodePathResolve.js +9 -0
- package/dist/modules/tree/treeNodePathResolve.js.map +1 -0
- package/dist/modules/tree/treeNodeRead.d.ts +7 -0
- package/dist/modules/tree/treeNodeRead.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeRead.js +46 -0
- package/dist/modules/tree/treeNodeRead.js.map +1 -0
- package/dist/modules/tree/treeNodeRead.spec.d.ts +2 -0
- package/dist/modules/tree/treeNodeRead.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeRead.spec.js +42 -0
- package/dist/modules/tree/treeNodeRead.spec.js.map +1 -0
- package/dist/modules/tree/treeNodeSlug.d.ts +6 -0
- package/dist/modules/tree/treeNodeSlug.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeSlug.js +20 -0
- package/dist/modules/tree/treeNodeSlug.js.map +1 -0
- package/dist/modules/tree/treeNodeSlug.spec.d.ts +2 -0
- package/dist/modules/tree/treeNodeSlug.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeSlug.spec.js +25 -0
- package/dist/modules/tree/treeNodeSlug.spec.js.map +1 -0
- package/dist/modules/tree/treeNodeWrite.d.ts +7 -0
- package/dist/modules/tree/treeNodeWrite.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeWrite.js +15 -0
- package/dist/modules/tree/treeNodeWrite.js.map +1 -0
- package/dist/modules/tree/treeNodeWrite.spec.d.ts +2 -0
- package/dist/modules/tree/treeNodeWrite.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeNodeWrite.spec.js +34 -0
- package/dist/modules/tree/treeNodeWrite.spec.js.map +1 -0
- package/dist/modules/tree/treeSearchRun.d.ts +7 -0
- package/dist/modules/tree/treeSearchRun.d.ts.map +1 -0
- package/dist/modules/tree/treeSearchRun.js +178 -0
- package/dist/modules/tree/treeSearchRun.js.map +1 -0
- package/dist/modules/tree/treeSearchRun.spec.d.ts +2 -0
- package/dist/modules/tree/treeSearchRun.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeSearchRun.spec.js +203 -0
- package/dist/modules/tree/treeSearchRun.spec.js.map +1 -0
- package/dist/modules/tree/treeSearchTypes.d.ts +40 -0
- package/dist/modules/tree/treeSearchTypes.d.ts.map +1 -0
- package/dist/modules/tree/treeSearchTypes.js +2 -0
- package/dist/modules/tree/treeSearchTypes.js.map +1 -0
- package/dist/modules/tree/treeSearchTypes.spec.d.ts +2 -0
- package/dist/modules/tree/treeSearchTypes.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeSearchTypes.spec.js +40 -0
- package/dist/modules/tree/treeSearchTypes.spec.js.map +1 -0
- package/dist/modules/tree/treeStateLeaves.d.ts +7 -0
- package/dist/modules/tree/treeStateLeaves.d.ts.map +1 -0
- package/dist/modules/tree/treeStateLeaves.js +20 -0
- package/dist/modules/tree/treeStateLeaves.js.map +1 -0
- package/dist/modules/tree/treeStateLeaves.spec.d.ts +2 -0
- package/dist/modules/tree/treeStateLeaves.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeStateLeaves.spec.js +57 -0
- package/dist/modules/tree/treeStateLeaves.spec.js.map +1 -0
- package/dist/modules/tree/treeStateRead.d.ts +7 -0
- package/dist/modules/tree/treeStateRead.d.ts.map +1 -0
- package/dist/modules/tree/treeStateRead.js +39 -0
- package/dist/modules/tree/treeStateRead.js.map +1 -0
- package/dist/modules/tree/treeStateRead.spec.d.ts +2 -0
- package/dist/modules/tree/treeStateRead.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeStateRead.spec.js +64 -0
- package/dist/modules/tree/treeStateRead.spec.js.map +1 -0
- package/dist/modules/tree/treeStateRender.d.ts +7 -0
- package/dist/modules/tree/treeStateRender.d.ts.map +1 -0
- package/dist/modules/tree/treeStateRender.js +19 -0
- package/dist/modules/tree/treeStateRender.js.map +1 -0
- package/dist/modules/tree/treeStateRender.spec.d.ts +2 -0
- package/dist/modules/tree/treeStateRender.spec.d.ts.map +1 -0
- package/dist/modules/tree/treeStateRender.spec.js +42 -0
- package/dist/modules/tree/treeStateRender.spec.js.map +1 -0
- package/dist/modules/util/asyncLock.d.ts +9 -0
- package/dist/modules/util/asyncLock.d.ts.map +1 -0
- package/dist/modules/util/asyncLock.js +22 -0
- package/dist/modules/util/asyncLock.js.map +1 -0
- package/dist/modules/util/asyncLock.spec.d.ts +2 -0
- package/dist/modules/util/asyncLock.spec.d.ts.map +1 -0
- package/dist/modules/util/asyncLock.spec.js +52 -0
- package/dist/modules/util/asyncLock.spec.js.map +1 -0
- package/dist/modules/util/commandRun.d.ts +2 -2
- package/dist/modules/util/commandRun.d.ts.map +1 -1
- package/dist/modules/util/commandRun.js +27 -22
- package/dist/modules/util/commandRun.js.map +1 -1
- package/dist/modules/util/commandRun.spec.js +11 -1
- package/dist/modules/util/commandRun.spec.js.map +1 -1
- package/dist/modules/util/pathLock.d.ts +21 -0
- package/dist/modules/util/pathLock.d.ts.map +1 -0
- package/dist/modules/util/pathLock.js +127 -0
- package/dist/modules/util/pathLock.js.map +1 -0
- package/dist/modules/util/pathLock.spec.d.ts +2 -0
- package/dist/modules/util/pathLock.spec.d.ts.map +1 -0
- package/dist/modules/util/pathLock.spec.js +98 -0
- package/dist/modules/util/pathLock.spec.js.map +1 -0
- package/dist/modules/util/pathLockOverlap.d.ts +11 -0
- package/dist/modules/util/pathLockOverlap.d.ts.map +1 -0
- package/dist/modules/util/pathLockOverlap.js +41 -0
- package/dist/modules/util/pathLockOverlap.js.map +1 -0
- package/dist/modules/util/pathLockOverlap.spec.d.ts +2 -0
- package/dist/modules/util/pathLockOverlap.spec.d.ts.map +1 -0
- package/dist/modules/util/pathLockOverlap.spec.js +34 -0
- package/dist/modules/util/pathLockOverlap.spec.js.map +1 -0
- package/dist/modules/util/pathResolveFromInitCwd.d.ts +1 -1
- package/dist/modules/util/pathResolveFromInitCwd.js +1 -1
- package/dist/modules/util/pathResolveFromInitCwd.js.map +1 -1
- package/dist/release/releaseRun.d.ts.map +1 -1
- package/dist/release/releaseRun.js +15 -28
- package/dist/release/releaseRun.js.map +1 -1
- package/dist/release/releaseVersionIncrement.d.ts.map +1 -1
- package/dist/release/releaseVersionIncrement.js.map +1 -1
- package/dist/release/releaseVersionIncrement.spec.js.map +1 -1
- package/dist/release/releaseVersionPrompt.d.ts.map +1 -1
- package/dist/release/releaseVersionPrompt.js +10 -11
- package/dist/release/releaseVersionPrompt.js.map +1 -1
- package/dist/text/all.txt +66 -1
- package/dist/text/text.d.ts +11 -5
- package/dist/text/text.d.ts.map +1 -1
- package/dist/text/text.gen.d.ts +378 -0
- package/dist/text/text.gen.d.ts.map +1 -0
- package/dist/text/text.gen.js +135 -0
- package/dist/text/text.gen.js.map +1 -0
- package/dist/text/text.js +31 -26
- package/dist/text/text.js.map +1 -1
- package/dist/text/text.spec.d.ts +2 -0
- package/dist/text/text.spec.d.ts.map +1 -0
- package/dist/text/text.spec.js +50 -0
- package/dist/text/text.spec.js.map +1 -0
- package/dist/text/textGenBuild.d.ts +6 -0
- package/dist/text/textGenBuild.d.ts.map +1 -0
- package/dist/text/textGenBuild.js +14 -0
- package/dist/text/textGenBuild.js.map +1 -0
- package/dist/text/textGenGenerate.d.ts +6 -0
- package/dist/text/textGenGenerate.d.ts.map +1 -0
- package/dist/text/textGenGenerate.js +74 -0
- package/dist/text/textGenGenerate.js.map +1 -0
- package/dist/text/textGenGenerate.spec.d.ts +2 -0
- package/dist/text/textGenGenerate.spec.d.ts.map +1 -0
- package/dist/text/textGenGenerate.spec.js +24 -0
- package/dist/text/textGenGenerate.spec.js.map +1 -0
- package/dist/types.d.ts +9 -5
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +12 -6
- package/dist/apps/bootstrap.d.ts +0 -5
- package/dist/apps/bootstrap.d.ts.map +0 -1
- package/dist/apps/bootstrap.js +0 -170
- package/dist/apps/bootstrap.js.map +0 -1
- package/dist/commands/bootstrapCommand.d.ts +0 -6
- package/dist/commands/bootstrapCommand.d.ts.map +0 -1
- package/dist/commands/bootstrapCommand.js +0 -16
- package/dist/commands/bootstrapCommand.js.map +0 -1
- package/dist/modules/ai/aiReadmeGenerate.d.ts +0 -18
- package/dist/modules/ai/aiReadmeGenerate.d.ts.map +0 -1
- package/dist/modules/ai/aiReadmeGenerate.js +0 -23
- package/dist/modules/ai/aiReadmeGenerate.js.map +0 -1
- package/dist/modules/ai/aiReadmeGenerate.spec.d.ts +0 -2
- package/dist/modules/ai/aiReadmeGenerate.spec.d.ts.map +0 -1
- package/dist/modules/ai/aiReadmeGenerate.spec.js +0 -27
- package/dist/modules/ai/aiReadmeGenerate.spec.js.map +0 -1
- package/dist/modules/beer/beerDevFolderResolve.d.ts +0 -5
- package/dist/modules/beer/beerDevFolderResolve.d.ts.map +0 -1
- package/dist/modules/beer/beerDevFolderResolve.js +0 -9
- package/dist/modules/beer/beerDevFolderResolve.js.map +0 -1
- package/dist/modules/beer/beerDevFolderResolve.spec.d.ts +0 -2
- package/dist/modules/beer/beerDevFolderResolve.spec.d.ts.map +0 -1
- package/dist/modules/beer/beerDevFolderResolve.spec.js +0 -10
- package/dist/modules/beer/beerDevFolderResolve.spec.js.map +0 -1
- package/dist/modules/beer/beerSettingsPathResolve.d.ts +0 -5
- package/dist/modules/beer/beerSettingsPathResolve.d.ts.map +0 -1
- package/dist/modules/beer/beerSettingsPathResolve.js +0 -9
- package/dist/modules/beer/beerSettingsPathResolve.js.map +0 -1
- package/dist/modules/beer/beerSettingsPathResolve.spec.d.ts +0 -2
- package/dist/modules/beer/beerSettingsPathResolve.spec.d.ts.map +0 -1
- package/dist/modules/beer/beerSettingsPathResolve.spec.js +0 -10
- package/dist/modules/beer/beerSettingsPathResolve.spec.js.map +0 -1
- package/dist/modules/context/contextGet.d.ts +0 -7
- package/dist/modules/context/contextGet.d.ts.map +0 -1
- package/dist/modules/context/contextGet.js +0 -12
- package/dist/modules/context/contextGet.js.map +0 -1
- package/dist/modules/context/contextGetOrInitialize.d.ts +0 -7
- package/dist/modules/context/contextGetOrInitialize.d.ts.map +0 -1
- package/dist/modules/context/contextGetOrInitialize.js +0 -12
- package/dist/modules/context/contextGetOrInitialize.js.map +0 -1
- package/dist/modules/context/contextInitialize.d.ts +0 -7
- package/dist/modules/context/contextInitialize.d.ts.map +0 -1
- package/dist/modules/context/contextInitialize.js +0 -25
- package/dist/modules/context/contextInitialize.js.map +0 -1
- package/dist/modules/context/contextInitialize.spec.d.ts +0 -2
- package/dist/modules/context/contextInitialize.spec.d.ts.map +0 -1
- package/dist/modules/context/contextInitialize.spec.js +0 -77
- package/dist/modules/context/contextInitialize.spec.js.map +0 -1
- package/dist/modules/context/contextTypes.d.ts +0 -21
- package/dist/modules/context/contextTypes.d.ts.map +0 -1
- package/dist/modules/context/contextTypes.js +0 -2
- package/dist/modules/context/contextTypes.js.map +0 -1
- package/dist/workflows/steps/generateCommitMessage.d.ts +0 -13
- package/dist/workflows/steps/generateCommitMessage.d.ts.map +0 -1
- package/dist/workflows/steps/generateCommitMessage.js +0 -25
- package/dist/workflows/steps/generateCommitMessage.js.map +0 -1
- package/dist/workflows/steps/generateCommitMessage.spec.d.ts +0 -2
- package/dist/workflows/steps/generateCommitMessage.spec.d.ts.map +0 -1
- package/dist/workflows/steps/generateCommitMessage.spec.js +0 -28
- package/dist/workflows/steps/generateCommitMessage.spec.js.map +0 -1
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { treeStateRender } from "../../modules/tree/treeStateRender.js";
|
|
3
|
+
describe("treeStateRender", () => {
|
|
4
|
+
it("renders indentation and status labels", () => {
|
|
5
|
+
const tree = [
|
|
6
|
+
{
|
|
7
|
+
slug: "auth",
|
|
8
|
+
title: "Authentication System",
|
|
9
|
+
depth: 1,
|
|
10
|
+
dirPath: "/tmp/auth",
|
|
11
|
+
parentDirPath: "/tmp",
|
|
12
|
+
status: "expanded",
|
|
13
|
+
children: [
|
|
14
|
+
{
|
|
15
|
+
slug: "oauth2",
|
|
16
|
+
title: "OAuth2 Flow",
|
|
17
|
+
depth: 2,
|
|
18
|
+
dirPath: "/tmp/auth/oauth2",
|
|
19
|
+
parentDirPath: "/tmp/auth",
|
|
20
|
+
status: "unexpanded",
|
|
21
|
+
children: []
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
slug: "sessions",
|
|
25
|
+
title: "Session Management",
|
|
26
|
+
depth: 2,
|
|
27
|
+
dirPath: "/tmp/auth/sessions",
|
|
28
|
+
parentDirPath: "/tmp/auth",
|
|
29
|
+
status: "in-progress",
|
|
30
|
+
children: []
|
|
31
|
+
}
|
|
32
|
+
]
|
|
33
|
+
}
|
|
34
|
+
];
|
|
35
|
+
expect(treeStateRender(tree)).toBe([
|
|
36
|
+
"- Authentication System [expanded]",
|
|
37
|
+
" - OAuth2 Flow [unexpanded]",
|
|
38
|
+
" - Session Management [in-progress]"
|
|
39
|
+
].join("\n"));
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=treeStateRender.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRender.spec.js","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRender.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAGpE,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC7B,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC7C,MAAM,IAAI,GAAe;YACrB;gBACI,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,uBAAuB;gBAC9B,KAAK,EAAE,CAAC;gBACR,OAAO,EAAE,WAAW;gBACpB,aAAa,EAAE,MAAM;gBACrB,MAAM,EAAE,UAAU;gBAClB,QAAQ,EAAE;oBACN;wBACI,IAAI,EAAE,QAAQ;wBACd,KAAK,EAAE,aAAa;wBACpB,KAAK,EAAE,CAAC;wBACR,OAAO,EAAE,kBAAkB;wBAC3B,aAAa,EAAE,WAAW;wBAC1B,MAAM,EAAE,YAAY;wBACpB,QAAQ,EAAE,EAAE;qBACf;oBACD;wBACI,IAAI,EAAE,UAAU;wBAChB,KAAK,EAAE,oBAAoB;wBAC3B,KAAK,EAAE,CAAC;wBACR,OAAO,EAAE,oBAAoB;wBAC7B,aAAa,EAAE,WAAW;wBAC1B,MAAM,EAAE,aAAa;wBACrB,QAAQ,EAAE,EAAE;qBACf;iBACJ;aACJ;SACJ,CAAC;QAEF,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAC9B;YACI,oCAAoC;YACpC,8BAA8B;YAC9B,sCAAsC;SACzC,CAAC,IAAI,CAAC,IAAI,CAAC,CACf,CAAC;IACN,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Runs async callbacks sequentially under a single mutex.
|
|
3
|
+
* Expects: callback handles its own failures; lock release happens in finally.
|
|
4
|
+
*/
|
|
5
|
+
export declare class AsyncLock {
|
|
6
|
+
private pending;
|
|
7
|
+
inLock<T>(fn: () => Promise<T>): Promise<T>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=asyncLock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"asyncLock.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/asyncLock.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,qBAAa,SAAS;IAClB,OAAO,CAAC,OAAO,CAAoC;IAE7C,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;CAcpD"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Runs async callbacks sequentially under a single mutex.
|
|
3
|
+
* Expects: callback handles its own failures; lock release happens in finally.
|
|
4
|
+
*/
|
|
5
|
+
export class AsyncLock {
|
|
6
|
+
pending = Promise.resolve();
|
|
7
|
+
async inLock(fn) {
|
|
8
|
+
const waitForTurn = this.pending;
|
|
9
|
+
let releaseTurn = () => { };
|
|
10
|
+
this.pending = new Promise((resolve) => {
|
|
11
|
+
releaseTurn = resolve;
|
|
12
|
+
});
|
|
13
|
+
await waitForTurn;
|
|
14
|
+
try {
|
|
15
|
+
return await fn();
|
|
16
|
+
}
|
|
17
|
+
finally {
|
|
18
|
+
releaseTurn();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=asyncLock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"asyncLock.js","sourceRoot":"","sources":["../../../sources/modules/util/asyncLock.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,OAAO,SAAS;IACV,OAAO,GAAkB,OAAO,CAAC,OAAO,EAAE,CAAC;IAEnD,KAAK,CAAC,MAAM,CAAI,EAAoB;QAChC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC;QACjC,IAAI,WAAW,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YACzC,WAAW,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,MAAM,WAAW,CAAC;QAClB,IAAI,CAAC;YACD,OAAO,MAAM,EAAE,EAAE,CAAC;QACtB,CAAC;gBAAS,CAAC;YACP,WAAW,EAAE,CAAC;QAClB,CAAC;IACL,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"asyncLock.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/asyncLock.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { AsyncLock } from "../../modules/util/asyncLock.js";
|
|
3
|
+
function asyncLockSleep(ms) {
|
|
4
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
5
|
+
}
|
|
6
|
+
describe("AsyncLock", () => {
|
|
7
|
+
it("executes concurrent operations sequentially", async () => {
|
|
8
|
+
const lock = new AsyncLock();
|
|
9
|
+
const order = [];
|
|
10
|
+
await Promise.all([
|
|
11
|
+
lock.inLock(async () => {
|
|
12
|
+
order.push("first:start");
|
|
13
|
+
await asyncLockSleep(10);
|
|
14
|
+
order.push("first:end");
|
|
15
|
+
}),
|
|
16
|
+
lock.inLock(async () => {
|
|
17
|
+
order.push("second:start");
|
|
18
|
+
order.push("second:end");
|
|
19
|
+
})
|
|
20
|
+
]);
|
|
21
|
+
expect(order).toEqual(["first:start", "first:end", "second:start", "second:end"]);
|
|
22
|
+
});
|
|
23
|
+
it("queues many callers with single concurrency", async () => {
|
|
24
|
+
const lock = new AsyncLock();
|
|
25
|
+
let current = 0;
|
|
26
|
+
let max = 0;
|
|
27
|
+
const values = await Promise.all(Array.from({ length: 5 }, (_, index) => lock.inLock(async () => {
|
|
28
|
+
current += 1;
|
|
29
|
+
max = Math.max(max, current);
|
|
30
|
+
await asyncLockSleep(1);
|
|
31
|
+
current -= 1;
|
|
32
|
+
return index;
|
|
33
|
+
})));
|
|
34
|
+
expect(max).toBe(1);
|
|
35
|
+
expect(values).toEqual([0, 1, 2, 3, 4]);
|
|
36
|
+
});
|
|
37
|
+
it("propagates errors and still releases for later callers", async () => {
|
|
38
|
+
const lock = new AsyncLock();
|
|
39
|
+
const first = lock.inLock(async () => {
|
|
40
|
+
throw new Error("boom");
|
|
41
|
+
});
|
|
42
|
+
const second = lock.inLock(async () => "ok");
|
|
43
|
+
await expect(first).rejects.toThrow("boom");
|
|
44
|
+
await expect(second).resolves.toBe("ok");
|
|
45
|
+
});
|
|
46
|
+
it("returns the callback value", async () => {
|
|
47
|
+
const lock = new AsyncLock();
|
|
48
|
+
const value = await lock.inLock(async () => ({ id: "value" }));
|
|
49
|
+
expect(value).toEqual({ id: "value" });
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
//# sourceMappingURL=asyncLock.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"asyncLock.spec.js","sourceRoot":"","sources":["../../../sources/modules/util/asyncLock.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { CommandSandbox } from "
|
|
1
|
+
import type { CommandSandbox } from "../../modules/sandbox/sandboxTypes.js";
|
|
2
2
|
export interface CommandRunOptions {
|
|
3
3
|
cwd?: string;
|
|
4
|
-
timeoutMs?: number;
|
|
4
|
+
timeoutMs?: number | null;
|
|
5
5
|
input?: string;
|
|
6
6
|
allowFailure?: boolean;
|
|
7
7
|
onStdoutText?: (text: string) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commandRun.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAGxE,MAAM,WAAW,iBAAiB;
|
|
1
|
+
{"version":3,"file":"commandRun.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAGxE,MAAM,WAAW,iBAAiB;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,OAAO,CAAC,EAAE,cAAc,CAAC;IACzB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,gBAAgB;IAC7B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAClB;AAED;;;GAGG;AACH,wBAAsB,UAAU,CAC5B,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EAAE,EACd,OAAO,GAAE,iBAAsB,GAChC,OAAO,CAAC,gBAAgB,CAAC,CAwF3B"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { spawn } from "node:child_process";
|
|
2
|
-
import {
|
|
3
|
-
import { pathResolveFromInitCwd } from "
|
|
2
|
+
import { textFormatKey } from "../../text/text.js";
|
|
3
|
+
import { pathResolveFromInitCwd } from "../../modules/util/pathResolveFromInitCwd.js";
|
|
4
4
|
/**
|
|
5
5
|
* Runs a command and captures stdout/stderr.
|
|
6
6
|
* Throws on non-zero exit unless allowFailure is true.
|
|
7
7
|
*/
|
|
8
8
|
export async function commandRun(command, args, options = {}) {
|
|
9
|
-
const timeoutMs = options.timeoutMs
|
|
9
|
+
const timeoutMs = options.timeoutMs === undefined ? 60_000 : options.timeoutMs;
|
|
10
10
|
const cwdResolved = options.cwd ?? pathResolveFromInitCwd(".");
|
|
11
11
|
const displayCommand = `${command} ${args.join(" ")}`;
|
|
12
12
|
const abortController = new AbortController();
|
|
@@ -16,18 +16,21 @@ export async function commandRun(command, args, options = {}) {
|
|
|
16
16
|
let stdout = "";
|
|
17
17
|
let stderr = "";
|
|
18
18
|
let settled = false;
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
19
|
+
let timeout;
|
|
20
|
+
if (timeoutMs !== null) {
|
|
21
|
+
timeout = setTimeout(() => {
|
|
22
|
+
if (settled) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
settled = true;
|
|
26
|
+
abortController.abort();
|
|
27
|
+
child.kill("SIGTERM");
|
|
28
|
+
reject(new Error(textFormatKey("error_command_timeout", {
|
|
29
|
+
ms: timeoutMs,
|
|
30
|
+
command: displayCommand
|
|
31
|
+
})));
|
|
32
|
+
}, timeoutMs);
|
|
33
|
+
}
|
|
31
34
|
child.stdout.on("data", (chunk) => {
|
|
32
35
|
const text = chunk.toString("utf-8");
|
|
33
36
|
stdout += text;
|
|
@@ -43,7 +46,9 @@ export async function commandRun(command, args, options = {}) {
|
|
|
43
46
|
return;
|
|
44
47
|
}
|
|
45
48
|
settled = true;
|
|
46
|
-
|
|
49
|
+
if (timeout) {
|
|
50
|
+
clearTimeout(timeout);
|
|
51
|
+
}
|
|
47
52
|
reject(error);
|
|
48
53
|
});
|
|
49
54
|
child.on("close", (code) => {
|
|
@@ -51,7 +56,9 @@ export async function commandRun(command, args, options = {}) {
|
|
|
51
56
|
return;
|
|
52
57
|
}
|
|
53
58
|
settled = true;
|
|
54
|
-
|
|
59
|
+
if (timeout) {
|
|
60
|
+
clearTimeout(timeout);
|
|
61
|
+
}
|
|
55
62
|
resolve({
|
|
56
63
|
exitCode: code ?? 1,
|
|
57
64
|
stdout,
|
|
@@ -64,17 +71,15 @@ export async function commandRun(command, args, options = {}) {
|
|
|
64
71
|
child.stdin.end();
|
|
65
72
|
});
|
|
66
73
|
if (!options.allowFailure && result.exitCode !== 0) {
|
|
67
|
-
throw new Error(
|
|
74
|
+
throw new Error(`${textFormatKey("error_command_failed", {
|
|
68
75
|
code: result.exitCode,
|
|
69
76
|
command: displayCommand
|
|
70
|
-
})
|
|
77
|
+
})}\n${result.stderr || result.stdout}`);
|
|
71
78
|
}
|
|
72
79
|
return result;
|
|
73
80
|
}
|
|
74
81
|
async function commandInvocationResolve(command, args, cwd, options, abortSignal) {
|
|
75
|
-
const env = options.env
|
|
76
|
-
? { ...process.env, ...options.env }
|
|
77
|
-
: process.env;
|
|
82
|
+
const env = options.env ? { ...process.env, ...options.env } : process.env;
|
|
78
83
|
if (!options.sandbox) {
|
|
79
84
|
return {
|
|
80
85
|
command,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commandRun.js","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"commandRun.js","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,7 +4,7 @@ const spawnMock = vi.hoisted(() => vi.fn());
|
|
|
4
4
|
vi.mock("node:child_process", () => ({
|
|
5
5
|
spawn: spawnMock
|
|
6
6
|
}));
|
|
7
|
-
import { commandRun } from "
|
|
7
|
+
import { commandRun } from "../../modules/util/commandRun.js";
|
|
8
8
|
function spawnSuccessChild() {
|
|
9
9
|
const child = new EventEmitter();
|
|
10
10
|
child.stdout = new EventEmitter();
|
|
@@ -36,6 +36,16 @@ describe("commandRun", () => {
|
|
|
36
36
|
expect(spawnMock).toHaveBeenCalledTimes(1);
|
|
37
37
|
expect(spawnMock.mock.calls[0]?.[2]?.cwd).toBe("/tmp/explicit-cwd");
|
|
38
38
|
});
|
|
39
|
+
it("skips timeout timer when timeoutMs is null", async () => {
|
|
40
|
+
const setTimeoutSpy = vi.spyOn(globalThis, "setTimeout");
|
|
41
|
+
try {
|
|
42
|
+
await commandRun("echo", ["ok"], { timeoutMs: null });
|
|
43
|
+
expect(setTimeoutSpy).not.toHaveBeenCalled();
|
|
44
|
+
}
|
|
45
|
+
finally {
|
|
46
|
+
setTimeoutSpy.mockRestore();
|
|
47
|
+
}
|
|
48
|
+
});
|
|
39
49
|
afterAll(() => {
|
|
40
50
|
process.env.INIT_CWD = initCwd;
|
|
41
51
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commandRun.spec.js","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAExE,MAAM,SAAS,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;AAE5C,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"commandRun.spec.js","sourceRoot":"","sources":["../../../sources/modules/util/commandRun.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAExE,MAAM,SAAS,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;AAE5C,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;IACjC,KAAK,EAAE,SAAS;CACnB,CAAC,CAAC,CAAC;AAEJ,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,SAAS,iBAAiB;IAMtB,MAAM,KAAK,GAAG,IAAI,YAAY,EAK7B,CAAC;IAEF,KAAK,CAAC,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAClC,KAAK,CAAC,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAClC,KAAK,CAAC,KAAK,GAAG;QACV,KAAK,EAAE,GAAG,EAAE,CAAC,SAAS;QACtB,GAAG,EAAE,GAAG,EAAE,CAAC,SAAS;KACvB,CAAC;IACF,KAAK,CAAC,IAAI,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC;IAE7B,cAAc,CAAC,GAAG,EAAE;QAChB,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IACxB,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC;IAErC,UAAU,CAAC,GAAG,EAAE;QACZ,SAAS,CAAC,SAAS,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,QAAQ,GAAG,4BAA4B,CAAC;QACpD,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC3E,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAEjC,MAAM,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IACjF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,EAAE,mBAAmB,EAAE,CAAC,CAAC;QAE/D,MAAM,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QACxD,MAAM,aAAa,GAAG,EAAE,CAAC,KAAK,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QACzD,IAAI,CAAC;YACD,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACtD,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;QACjD,CAAC;gBAAS,CAAC;YACP,aAAa,CAAC,WAAW,EAAE,CAAC;QAChC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,GAAG,EAAE;QACV,OAAO,CAAC,GAAG,CAAC,QAAQ,GAAG,OAAO,CAAC;IACnC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export interface PathLockResult {
|
|
2
|
+
locked: boolean;
|
|
3
|
+
conflicts: string[];
|
|
4
|
+
release: (() => Promise<void>) | null;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Coordinates path locks in-memory or through a disk-backed JSON file.
|
|
8
|
+
* Expects: all paths are in the same root namespace (usually repository-relative).
|
|
9
|
+
*/
|
|
10
|
+
export declare class PathLock {
|
|
11
|
+
static create(): PathLock;
|
|
12
|
+
static open(filePath: string): Promise<PathLock>;
|
|
13
|
+
private readonly stateLock;
|
|
14
|
+
private readonly filePath;
|
|
15
|
+
private lockedPaths;
|
|
16
|
+
private constructor();
|
|
17
|
+
lock(paths: string[]): Promise<PathLockResult>;
|
|
18
|
+
private sync;
|
|
19
|
+
private refresh;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=pathLock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathLock.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/pathLock.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,cAAc;IAC3B,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,OAAO,EAAE,CAAC,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC;CACzC;AAED;;;GAGG;AACH,qBAAa,QAAQ;IACjB,MAAM,CAAC,MAAM,IAAI,QAAQ;WAIZ,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAQtD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAmB;IAC7C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgB;IACzC,OAAO,CAAC,WAAW,CAAc;IAEjC,OAAO;IAKD,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC;YAuCtC,IAAI;YAOJ,OAAO;CAMxB"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { mkdir, readFile, rename, rm, writeFile } from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { AsyncLock } from "../../modules/util/asyncLock.js";
|
|
4
|
+
import { pathLockConflicts } from "../../modules/util/pathLockOverlap.js";
|
|
5
|
+
/**
|
|
6
|
+
* Coordinates path locks in-memory or through a disk-backed JSON file.
|
|
7
|
+
* Expects: all paths are in the same root namespace (usually repository-relative).
|
|
8
|
+
*/
|
|
9
|
+
export class PathLock {
|
|
10
|
+
static create() {
|
|
11
|
+
return new PathLock();
|
|
12
|
+
}
|
|
13
|
+
static async open(filePath) {
|
|
14
|
+
const resolvedFilePath = path.resolve(filePath);
|
|
15
|
+
const lock = new PathLock(resolvedFilePath);
|
|
16
|
+
lock.lockedPaths = new Set(await pathLockRead(resolvedFilePath));
|
|
17
|
+
await lock.sync();
|
|
18
|
+
return lock;
|
|
19
|
+
}
|
|
20
|
+
stateLock = new AsyncLock();
|
|
21
|
+
filePath;
|
|
22
|
+
lockedPaths;
|
|
23
|
+
constructor(filePath) {
|
|
24
|
+
this.filePath = filePath ?? null;
|
|
25
|
+
this.lockedPaths = new Set();
|
|
26
|
+
}
|
|
27
|
+
async lock(paths) {
|
|
28
|
+
const normalizedPaths = pathLockPathsNormalize(paths);
|
|
29
|
+
return this.stateLock.inLock(async () => {
|
|
30
|
+
await this.refresh();
|
|
31
|
+
const conflicts = pathLockConflicts(normalizedPaths, [...this.lockedPaths]);
|
|
32
|
+
if (conflicts.length > 0) {
|
|
33
|
+
return {
|
|
34
|
+
locked: false,
|
|
35
|
+
conflicts,
|
|
36
|
+
release: null
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
for (const pathValue of normalizedPaths) {
|
|
40
|
+
this.lockedPaths.add(pathValue);
|
|
41
|
+
}
|
|
42
|
+
await this.sync();
|
|
43
|
+
let released = false;
|
|
44
|
+
return {
|
|
45
|
+
locked: true,
|
|
46
|
+
conflicts: [],
|
|
47
|
+
release: async () => {
|
|
48
|
+
await this.stateLock.inLock(async () => {
|
|
49
|
+
if (released) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
await this.refresh();
|
|
53
|
+
released = true;
|
|
54
|
+
for (const pathValue of normalizedPaths) {
|
|
55
|
+
this.lockedPaths.delete(pathValue);
|
|
56
|
+
}
|
|
57
|
+
await this.sync();
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
async sync() {
|
|
64
|
+
if (!this.filePath) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
await pathLockWrite(this.filePath, [...this.lockedPaths]);
|
|
68
|
+
}
|
|
69
|
+
async refresh() {
|
|
70
|
+
if (!this.filePath) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
this.lockedPaths = new Set(await pathLockRead(this.filePath));
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
function pathLockErrorIsNotFound(error) {
|
|
77
|
+
return typeof error === "object" && error !== null && "code" in error && error.code === "ENOENT";
|
|
78
|
+
}
|
|
79
|
+
function pathLockPathsNormalize(paths) {
|
|
80
|
+
const normalized = new Set();
|
|
81
|
+
for (const pathValue of paths) {
|
|
82
|
+
normalized.add(pathLockPathNormalize(pathValue));
|
|
83
|
+
}
|
|
84
|
+
return [...normalized];
|
|
85
|
+
}
|
|
86
|
+
function pathLockPathNormalize(pathValue) {
|
|
87
|
+
const forwardSlashPath = pathValue.replaceAll("\\", "/");
|
|
88
|
+
const normalized = path.posix.normalize(forwardSlashPath);
|
|
89
|
+
if (normalized === "/") {
|
|
90
|
+
return normalized;
|
|
91
|
+
}
|
|
92
|
+
if (!normalized.endsWith("/")) {
|
|
93
|
+
return normalized;
|
|
94
|
+
}
|
|
95
|
+
return normalized.slice(0, -1);
|
|
96
|
+
}
|
|
97
|
+
async function pathLockRead(filePath) {
|
|
98
|
+
try {
|
|
99
|
+
const raw = await readFile(filePath, "utf-8");
|
|
100
|
+
const parsed = JSON.parse(raw);
|
|
101
|
+
if (!parsed || !Array.isArray(parsed.locked)) {
|
|
102
|
+
throw new Error(`Invalid path lock file: ${filePath}`);
|
|
103
|
+
}
|
|
104
|
+
return pathLockPathsNormalize(parsed.locked);
|
|
105
|
+
}
|
|
106
|
+
catch (error) {
|
|
107
|
+
if (pathLockErrorIsNotFound(error)) {
|
|
108
|
+
return [];
|
|
109
|
+
}
|
|
110
|
+
throw error;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
async function pathLockWrite(filePath, locked) {
|
|
114
|
+
await mkdir(path.dirname(filePath), { recursive: true });
|
|
115
|
+
const tempPath = `${filePath}.${process.pid}.${Date.now().toString(36)}.tmp`;
|
|
116
|
+
const body = JSON.stringify({
|
|
117
|
+
locked: pathLockPathsNormalize(locked).sort()
|
|
118
|
+
});
|
|
119
|
+
try {
|
|
120
|
+
await writeFile(tempPath, body, "utf-8");
|
|
121
|
+
await rename(tempPath, filePath);
|
|
122
|
+
}
|
|
123
|
+
finally {
|
|
124
|
+
await rm(tempPath, { force: true });
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=pathLock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathLock.js","sourceRoot":"","sources":["../../../sources/modules/util/pathLock.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathLock.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/pathLock.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { access, mkdtemp, readFile, rm } from "node:fs/promises";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import { PathLock } from "../../modules/util/pathLock.js";
|
|
6
|
+
function pathLockDiskStateParse(raw) {
|
|
7
|
+
return JSON.parse(raw);
|
|
8
|
+
}
|
|
9
|
+
describe("PathLock memory mode", () => {
|
|
10
|
+
it("locks paths, reports conflicts, and unlocks on release", async () => {
|
|
11
|
+
const lock = PathLock.create();
|
|
12
|
+
const first = await lock.lock(["src/bar"]);
|
|
13
|
+
expect(first.locked).toBe(true);
|
|
14
|
+
expect(first.conflicts).toEqual([]);
|
|
15
|
+
expect(first.release).not.toBeNull();
|
|
16
|
+
const second = await lock.lock(["src/bar/baz.ts"]);
|
|
17
|
+
expect(second).toEqual({
|
|
18
|
+
locked: false,
|
|
19
|
+
conflicts: ["src/bar"],
|
|
20
|
+
release: null
|
|
21
|
+
});
|
|
22
|
+
await first.release?.();
|
|
23
|
+
const third = await lock.lock(["src/bar/baz.ts"]);
|
|
24
|
+
expect(third.locked).toBe(true);
|
|
25
|
+
});
|
|
26
|
+
it("returns an idempotent release handle for empty lock requests", async () => {
|
|
27
|
+
const lock = PathLock.create();
|
|
28
|
+
const result = await lock.lock([]);
|
|
29
|
+
expect(result.locked).toBe(true);
|
|
30
|
+
expect(result.conflicts).toEqual([]);
|
|
31
|
+
expect(result.release).not.toBeNull();
|
|
32
|
+
await result.release?.();
|
|
33
|
+
await result.release?.();
|
|
34
|
+
});
|
|
35
|
+
it("treats path normalization variants as the same lock", async () => {
|
|
36
|
+
const lock = PathLock.create();
|
|
37
|
+
const first = await lock.lock(["./src/bar/"]);
|
|
38
|
+
expect(first.locked).toBe(true);
|
|
39
|
+
const second = await lock.lock(["src/bar"]);
|
|
40
|
+
expect(second).toEqual({
|
|
41
|
+
locked: false,
|
|
42
|
+
conflicts: ["src/bar"],
|
|
43
|
+
release: null
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
describe("PathLock disk mode", () => {
|
|
48
|
+
it("creates the lock file on open", async () => {
|
|
49
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-path-lock-"));
|
|
50
|
+
try {
|
|
51
|
+
const lockPath = path.join(tempDir, "locks", "paths.json");
|
|
52
|
+
await PathLock.open(lockPath);
|
|
53
|
+
await expect(access(lockPath)).resolves.toBeUndefined();
|
|
54
|
+
}
|
|
55
|
+
finally {
|
|
56
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
it("persists lock and release state to disk", async () => {
|
|
60
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-path-lock-"));
|
|
61
|
+
try {
|
|
62
|
+
const lockPath = path.join(tempDir, "paths.json");
|
|
63
|
+
const lock = await PathLock.open(lockPath);
|
|
64
|
+
const result = await lock.lock(["src/foo.ts"]);
|
|
65
|
+
const lockedState = pathLockDiskStateParse(await readFile(lockPath, "utf-8"));
|
|
66
|
+
expect(lockedState.locked).toEqual(["src/foo.ts"]);
|
|
67
|
+
await result.release?.();
|
|
68
|
+
const releasedState = pathLockDiskStateParse(await readFile(lockPath, "utf-8"));
|
|
69
|
+
expect(releasedState.locked).toEqual([]);
|
|
70
|
+
}
|
|
71
|
+
finally {
|
|
72
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
it("reads existing disk state when reopened", async () => {
|
|
76
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-path-lock-"));
|
|
77
|
+
try {
|
|
78
|
+
const lockPath = path.join(tempDir, "paths.json");
|
|
79
|
+
const first = await PathLock.open(lockPath);
|
|
80
|
+
const firstLock = await first.lock(["src/bar"]);
|
|
81
|
+
expect(firstLock.locked).toBe(true);
|
|
82
|
+
const second = await PathLock.open(lockPath);
|
|
83
|
+
const secondLock = await second.lock(["src/bar/baz.ts"]);
|
|
84
|
+
expect(secondLock).toEqual({
|
|
85
|
+
locked: false,
|
|
86
|
+
conflicts: ["src/bar"],
|
|
87
|
+
release: null
|
|
88
|
+
});
|
|
89
|
+
await firstLock.release?.();
|
|
90
|
+
const thirdLock = await second.lock(["src/bar/baz.ts"]);
|
|
91
|
+
expect(thirdLock.locked).toBe(true);
|
|
92
|
+
}
|
|
93
|
+
finally {
|
|
94
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
//# sourceMappingURL=pathLock.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathLock.spec.js","sourceRoot":"","sources":["../../../sources/modules/util/pathLock.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns true when paths are equal or one is a parent directory of the other.
|
|
3
|
+
* Expects: paths target the same root namespace (typically repository-relative paths).
|
|
4
|
+
*/
|
|
5
|
+
export declare function pathLockOverlap(pathA: string, pathB: string): boolean;
|
|
6
|
+
/**
|
|
7
|
+
* Finds existing locked paths that conflict with candidate lock paths.
|
|
8
|
+
* Expects: returns normalized existing lock paths with deduplicated conflicts.
|
|
9
|
+
*/
|
|
10
|
+
export declare function pathLockConflicts(newPaths: string[], locked: string[]): string[];
|
|
11
|
+
//# sourceMappingURL=pathLockOverlap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathLockOverlap.d.ts","sourceRoot":"","sources":["../../../sources/modules/util/pathLockOverlap.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CASrE;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAchF"}
|