@slopus/beer 0.1.1 → 0.1.2
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.map +1 -1
- package/dist/modules/ai/generate.d.ts +14 -2
- package/dist/modules/ai/generate.d.ts.map +1 -1
- package/dist/modules/ai/generate.js +113 -25
- package/dist/modules/ai/generate.js.map +1 -1
- package/dist/modules/ai/generate.spec.js +1 -8
- 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 +6 -2
- package/dist/modules/ai/generateFile.d.ts.map +1 -1
- package/dist/modules/ai/generateFile.js +25 -12
- package/dist/modules/ai/generateFile.js.map +1 -1
- package/dist/modules/ai/generateFile.spec.js +108 -7
- 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 +4 -2
- package/dist/modules/ai/generateText.d.ts.map +1 -1
- package/dist/modules/ai/generateText.js +4 -2
- package/dist/modules/ai/generateText.js.map +1 -1
- package/dist/modules/ai/generateText.spec.js +13 -2
- 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 +11 -2
- package/dist/modules/ai/providerGenerate.d.ts.map +1 -1
- package/dist/modules/ai/providerGenerate.js +355 -92
- package/dist/modules/ai/providerGenerate.js.map +1 -1
- package/dist/modules/ai/providerGenerate.spec.js +93 -1
- package/dist/modules/ai/providerGenerate.spec.js.map +1 -1
- package/dist/modules/ai/providerGenerate.unit.spec.js +346 -12
- 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 +3 -3
- package/dist/modules/beer/beerOriginalPathResolve.spec.js.map +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 +3 -3
- package/dist/modules/beer/beerSettingsTypes.d.ts.map +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.map +1 -1
- package/dist/modules/git/gitRemoteEnsure.js.map +1 -1
- package/dist/modules/git/gitRepoCheckout.js.map +1 -1
- package/dist/modules/git/gitRepoCheckout.spec.js +1 -1
- 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.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 +2 -2
- package/dist/modules/github/githubCliEnsure.js.map +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.map +1 -1
- package/dist/modules/github/githubRepoExists.d.ts.map +1 -1
- package/dist/modules/github/githubRepoExists.js +3 -1
- package/dist/modules/github/githubRepoExists.js.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.d.ts.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.js +2 -2
- package/dist/modules/github/githubRepoNameResolve.js.map +1 -1
- package/dist/modules/github/githubRepoNameResolve.spec.js.map +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.map +1 -1
- package/dist/modules/github/githubRepoStatusGet.d.ts.map +1 -1
- package/dist/modules/github/githubRepoStatusGet.js +2 -2
- 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 +2 -2
- 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.map +1 -1
- package/dist/modules/providers/providerDetect.js +1 -1
- package/dist/modules/providers/providerDetect.js.map +1 -1
- package/dist/modules/providers/providerDetect.spec.js +1 -1
- package/dist/modules/providers/providerDetect.spec.js.map +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 +67 -27
- package/dist/modules/providers/providerModelSelect.spec.js.map +1 -1
- package/dist/modules/providers/providerModelsGet.d.ts.map +1 -1
- package/dist/modules/providers/providerModelsGet.js +3 -7
- package/dist/modules/providers/providerModelsGet.js.map +1 -1
- package/dist/modules/providers/providerModelsGet.spec.js +1 -1
- package/dist/modules/providers/providerModelsGet.spec.js.map +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 +2 -6
- 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 +1 -0
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js +21 -17
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js +28 -10
- package/dist/modules/sandbox/sandboxInferenceFilesystemPolicy.spec.js.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts +2 -1
- package/dist/modules/sandbox/sandboxInferenceGet.d.ts.map +1 -1
- package/dist/modules/sandbox/sandboxInferenceGet.js +8 -3
- 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 +1 -1
- package/dist/modules/util/commandRun.d.ts.map +1 -1
- package/dist/modules/util/commandRun.js +26 -21
- package/dist/modules/util/commandRun.js.map +1 -1
- package/dist/modules/util/commandRun.spec.js +10 -0
- 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 +13 -26
- 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 +8 -9
- 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 +5 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +11 -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,39 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { treeChildrenRead } from "@/modules/tree/treeChildrenRead.js";
|
|
3
|
+
import { treeNodeRead } from "@/modules/tree/treeNodeRead.js";
|
|
4
|
+
/**
|
|
5
|
+
* Reads persisted tree state from disk starting at root children.json.
|
|
6
|
+
* Expects: rootDir is the tree root directory containing root-level children.json.
|
|
7
|
+
*/
|
|
8
|
+
export async function treeStateRead(rootDir) {
|
|
9
|
+
const rootChildren = await treeChildrenRead(rootDir);
|
|
10
|
+
if (!rootChildren) {
|
|
11
|
+
return [];
|
|
12
|
+
}
|
|
13
|
+
return Promise.all(rootChildren.map((child) => treeStateReadNode(rootDir, child, 1)));
|
|
14
|
+
}
|
|
15
|
+
async function treeStateReadNode(parentDirPath, child, depth) {
|
|
16
|
+
const dirPath = path.join(parentDirPath, child.slug);
|
|
17
|
+
const nodeDisk = await treeNodeRead(dirPath);
|
|
18
|
+
const childrenDisk = await treeChildrenRead(dirPath);
|
|
19
|
+
const children = childrenDisk
|
|
20
|
+
? await Promise.all(childrenDisk.map((entry) => treeStateReadNode(dirPath, entry, depth + 1)))
|
|
21
|
+
: [];
|
|
22
|
+
return {
|
|
23
|
+
slug: nodeDisk?.slug ?? child.slug,
|
|
24
|
+
title: nodeDisk?.title ?? child.title,
|
|
25
|
+
depth,
|
|
26
|
+
dirPath,
|
|
27
|
+
parentDirPath,
|
|
28
|
+
sessionId: nodeDisk?.sessionId,
|
|
29
|
+
status: treeNodeStatusResolve(nodeDisk?.status),
|
|
30
|
+
children
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function treeNodeStatusResolve(status) {
|
|
34
|
+
if (status === "unexpanded" || status === "in-progress" || status === "expanded" || status === "leaf") {
|
|
35
|
+
return status;
|
|
36
|
+
}
|
|
37
|
+
return "unexpanded";
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=treeStateRead.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRead.js","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRead.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAG9D;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAAe;IAC/C,MAAM,YAAY,GAAG,MAAM,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACrD,IAAI,CAAC,YAAY,EAAE,CAAC;QAChB,OAAO,EAAE,CAAC;IACd,CAAC;IAED,OAAO,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1F,CAAC;AAED,KAAK,UAAU,iBAAiB,CAAC,aAAqB,EAAE,KAAqB,EAAE,KAAa;IACxF,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACrD,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,CAAC;IAC7C,MAAM,YAAY,GAAG,MAAM,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAErD,MAAM,QAAQ,GAAG,YAAY;QACzB,CAAC,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;QAC9F,CAAC,CAAC,EAAE,CAAC;IAET,OAAO;QACH,IAAI,EAAE,QAAQ,EAAE,IAAI,IAAI,KAAK,CAAC,IAAI;QAClC,KAAK,EAAE,QAAQ,EAAE,KAAK,IAAI,KAAK,CAAC,KAAK;QACrC,KAAK;QACL,OAAO;QACP,aAAa;QACb,SAAS,EAAE,QAAQ,EAAE,SAAS;QAC9B,MAAM,EAAE,qBAAqB,CAAC,QAAQ,EAAE,MAAM,CAAC;QAC/C,QAAQ;KACX,CAAC;AACN,CAAC;AAED,SAAS,qBAAqB,CAAC,MAA0B;IACrD,IAAI,MAAM,KAAK,YAAY,IAAI,MAAM,KAAK,aAAa,IAAI,MAAM,KAAK,UAAU,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACpG,OAAO,MAAM,CAAC;IAClB,CAAC;IACD,OAAO,YAAY,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRead.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRead.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { mkdir, mkdtemp, rm, writeFile } 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 { treeStateRead } from "@/modules/tree/treeStateRead.js";
|
|
6
|
+
describe("treeStateRead", () => {
|
|
7
|
+
it("returns empty state when root children.json is missing", async () => {
|
|
8
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-tree-state-read-"));
|
|
9
|
+
try {
|
|
10
|
+
await expect(treeStateRead(tempDir)).resolves.toEqual([]);
|
|
11
|
+
}
|
|
12
|
+
finally {
|
|
13
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
it("reads nested tree state recursively", async () => {
|
|
17
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-tree-state-read-"));
|
|
18
|
+
try {
|
|
19
|
+
await writeFile(path.join(tempDir, "children.json"), JSON.stringify([{ title: "Auth", slug: "auth" }], null, 2), "utf-8");
|
|
20
|
+
await mkdir(path.join(tempDir, "auth"), { recursive: true });
|
|
21
|
+
await writeFile(path.join(tempDir, "auth", "node.json"), JSON.stringify({ title: "Auth", slug: "auth", sessionId: "sess-auth", status: "expanded" }, null, 2), "utf-8");
|
|
22
|
+
await writeFile(path.join(tempDir, "auth", "children.json"), JSON.stringify([{ title: "OAuth2", slug: "oauth2" }], null, 2), "utf-8");
|
|
23
|
+
await mkdir(path.join(tempDir, "auth", "oauth2"), { recursive: true });
|
|
24
|
+
await writeFile(path.join(tempDir, "auth", "oauth2", "node.json"), JSON.stringify({ title: "OAuth2", slug: "oauth2", status: "unexpanded" }, null, 2), "utf-8");
|
|
25
|
+
const state = await treeStateRead(tempDir);
|
|
26
|
+
expect(state).toHaveLength(1);
|
|
27
|
+
expect(state[0]).toMatchObject({
|
|
28
|
+
title: "Auth",
|
|
29
|
+
slug: "auth",
|
|
30
|
+
depth: 1,
|
|
31
|
+
status: "expanded",
|
|
32
|
+
sessionId: "sess-auth"
|
|
33
|
+
});
|
|
34
|
+
expect(state[0]?.children[0]).toMatchObject({
|
|
35
|
+
title: "OAuth2",
|
|
36
|
+
slug: "oauth2",
|
|
37
|
+
depth: 2,
|
|
38
|
+
status: "unexpanded"
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
finally {
|
|
42
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
it("handles missing node files by falling back to root children entry", async () => {
|
|
46
|
+
const tempDir = await mkdtemp(path.join(os.tmpdir(), "holdmybeer-tree-state-read-"));
|
|
47
|
+
try {
|
|
48
|
+
await writeFile(path.join(tempDir, "children.json"), JSON.stringify([{ title: "Auth", slug: "auth" }], null, 2), "utf-8");
|
|
49
|
+
const state = await treeStateRead(tempDir);
|
|
50
|
+
expect(state).toEqual([
|
|
51
|
+
expect.objectContaining({
|
|
52
|
+
title: "Auth",
|
|
53
|
+
slug: "auth",
|
|
54
|
+
status: "unexpanded",
|
|
55
|
+
children: []
|
|
56
|
+
})
|
|
57
|
+
]);
|
|
58
|
+
}
|
|
59
|
+
finally {
|
|
60
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
//# sourceMappingURL=treeStateRead.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRead.spec.js","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRead.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { TreeNode } from "@/types";
|
|
2
|
+
/**
|
|
3
|
+
* Renders tree state into an indented outline consumable by picker prompts.
|
|
4
|
+
* Expects: nodes are root-level entries (root itself is not rendered).
|
|
5
|
+
*/
|
|
6
|
+
export declare function treeStateRender(nodes: readonly TreeNode[]): string;
|
|
7
|
+
//# sourceMappingURL=treeStateRender.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRender.d.ts","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRender.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAExC;;;GAGG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,SAAS,QAAQ,EAAE,GAAG,MAAM,CAMlE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Renders tree state into an indented outline consumable by picker prompts.
|
|
3
|
+
* Expects: nodes are root-level entries (root itself is not rendered).
|
|
4
|
+
*/
|
|
5
|
+
export function treeStateRender(nodes) {
|
|
6
|
+
const lines = [];
|
|
7
|
+
for (const node of nodes) {
|
|
8
|
+
treeStateRenderNode(lines, node, 0);
|
|
9
|
+
}
|
|
10
|
+
return lines.join("\n");
|
|
11
|
+
}
|
|
12
|
+
function treeStateRenderNode(lines, node, level) {
|
|
13
|
+
const indent = " ".repeat(level);
|
|
14
|
+
lines.push(`${indent}- ${node.title} [${node.status}]`);
|
|
15
|
+
for (const child of node.children) {
|
|
16
|
+
treeStateRenderNode(lines, child, level + 1);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=treeStateRender.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRender.js","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRender.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,KAA0B;IACtD,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACvB,mBAAmB,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IACxC,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED,SAAS,mBAAmB,CAAC,KAAe,EAAE,IAAc,EAAE,KAAa;IACvE,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAClC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,KAAK,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IACxD,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChC,mBAAmB,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"treeStateRender.spec.d.ts","sourceRoot":"","sources":["../../../sources/modules/tree/treeStateRender.spec.ts"],"names":[],"mappings":""}
|
|
@@ -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 +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 {
|
|
2
|
+
import { textFormatKey } from "@text";
|
|
3
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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"}
|
|
@@ -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":"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"}
|
|
@@ -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"}
|