zone-ai-agent 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gittignore +4 -0
- package/README.md +36 -0
- package/dist/api/server.js +136 -0
- package/dist/api/server.js.map +1 -0
- package/dist/apply/applyPatchPlan.js +17 -0
- package/dist/apply/applyPatchPlan.js.map +1 -0
- package/dist/apply/canApplyDecision.js +26 -0
- package/dist/apply/canApplyDecision.js.map +1 -0
- package/dist/apply/patchPlan.js +3 -0
- package/dist/apply/patchPlan.js.map +1 -0
- package/dist/apply/renderApplyResult.js +18 -0
- package/dist/apply/renderApplyResult.js.map +1 -0
- package/dist/apply/runApplyFlow.js +40 -0
- package/dist/apply/runApplyFlow.js.map +1 -0
- package/dist/apply/types.js +3 -0
- package/dist/apply/types.js.map +1 -0
- package/dist/audit/auditDiffIntelligence.js +3 -0
- package/dist/audit/auditDiffIntelligence.js.map +1 -0
- package/dist/audit/auditSnapshot.js +87 -0
- package/dist/audit/auditSnapshot.js.map +1 -0
- package/dist/audit/renderAuditDiff.js +64 -0
- package/dist/audit/renderAuditDiff.js.map +1 -0
- package/dist/audit/snapshotDiff.js +53 -0
- package/dist/audit/snapshotDiff.js.map +1 -0
- package/dist/audit/snapshotReader.js +31 -0
- package/dist/audit/snapshotReader.js.map +1 -0
- package/dist/audit/snapshotWriter.js +59 -0
- package/dist/audit/snapshotWriter.js.map +1 -0
- package/dist/ci/evaluateCiResult.js +142 -0
- package/dist/ci/evaluateCiResult.js.map +1 -0
- package/dist/cli/buildGeneratedPatchPlanPreview.js +65 -0
- package/dist/cli/buildGeneratedPatchPlanPreview.js.map +1 -0
- package/dist/cli/colors.js +28 -0
- package/dist/cli/colors.js.map +1 -0
- package/dist/cli/diffOutput.js +37 -0
- package/dist/cli/diffOutput.js.map +1 -0
- package/dist/cli/index.js +850 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/loadPatchPlan.js +52 -0
- package/dist/cli/loadPatchPlan.js.map +1 -0
- package/dist/cli/output.js +34 -0
- package/dist/cli/output.js.map +1 -0
- package/dist/cli/parseCliArgs.js +3 -0
- package/dist/cli/parseCliArgs.js.map +1 -0
- package/dist/cli/runGeneratedPatchPlanFlow.js +23 -0
- package/dist/cli/runGeneratedPatchPlanFlow.js.map +1 -0
- package/dist/components/LoginForm.js +64 -0
- package/dist/components/LoginForm.js.map +1 -0
- package/dist/core/analyzeCodePatterns.js +3 -0
- package/dist/core/analyzeCodePatterns.js.map +1 -0
- package/dist/core/applyLlmPatches.js +43 -0
- package/dist/core/applyLlmPatches.js.map +1 -0
- package/dist/core/buildConfidenceBreakdownFromSignals.js +33 -0
- package/dist/core/buildConfidenceBreakdownFromSignals.js.map +1 -0
- package/dist/core/buildDecisionAuditSnapshot.js +18 -0
- package/dist/core/buildDecisionAuditSnapshot.js.map +1 -0
- package/dist/core/buildDecisionTrace.js +113 -0
- package/dist/core/buildDecisionTrace.js.map +1 -0
- package/dist/core/buildFallbackPatchPlan.js +23 -0
- package/dist/core/buildFallbackPatchPlan.js.map +1 -0
- package/dist/core/buildFallbackPlan.js +25 -0
- package/dist/core/buildFallbackPlan.js.map +1 -0
- package/dist/core/buildSchemaAwareContext.js +49 -0
- package/dist/core/buildSchemaAwareContext.js.map +1 -0
- package/dist/core/buildTaskExecutionContext.js +70 -0
- package/dist/core/buildTaskExecutionContext.js.map +1 -0
- package/dist/core/ciEvaluator.js +83 -0
- package/dist/core/ciEvaluator.js.map +1 -0
- package/dist/core/computeRiskScore.js +43 -0
- package/dist/core/computeRiskScore.js.map +1 -0
- package/dist/core/computeRiskScoreDetails.js +106 -0
- package/dist/core/computeRiskScoreDetails.js.map +1 -0
- package/dist/core/confidenceGate.js +83 -0
- package/dist/core/confidenceGate.js.map +1 -0
- package/dist/core/decision/buildDecisionExplanation.js +91 -0
- package/dist/core/decision/buildDecisionExplanation.js.map +1 -0
- package/dist/core/decision/buildDecisionReasonCodes.js +65 -0
- package/dist/core/decision/buildDecisionReasonCodes.js.map +1 -0
- package/dist/core/decision/buildReasonSummaryLine.js +24 -0
- package/dist/core/decision/buildReasonSummaryLine.js.map +1 -0
- package/dist/core/decision/buildRecommendation.js +43 -0
- package/dist/core/decision/buildRecommendation.js.map +1 -0
- package/dist/core/decision/decideExecutionMode.js +125 -0
- package/dist/core/decision/decideExecutionMode.js.map +1 -0
- package/dist/core/decision/decisionReasonCodeMeta.js +91 -0
- package/dist/core/decision/decisionReasonCodeMeta.js.map +1 -0
- package/dist/core/decision/renderDecisionSummary.js +115 -0
- package/dist/core/decision/renderDecisionSummary.js.map +1 -0
- package/dist/core/detectResourceStorage.js +78 -0
- package/dist/core/detectResourceStorage.js.map +1 -0
- package/dist/core/formatOutput.js +53 -0
- package/dist/core/formatOutput.js.map +1 -0
- package/dist/core/intentAwareScore.js +35 -0
- package/dist/core/intentAwareScore.js.map +1 -0
- package/dist/core/loadSavedAgentResult.js +18 -0
- package/dist/core/loadSavedAgentResult.js.map +1 -0
- package/dist/core/normalizeIssues.js +50 -0
- package/dist/core/normalizeIssues.js.map +1 -0
- package/dist/core/normalizeSignals.js +40 -0
- package/dist/core/normalizeSignals.js.map +1 -0
- package/dist/core/output/zoneStageTypes.js +3 -0
- package/dist/core/output/zoneStageTypes.js.map +1 -0
- package/dist/core/patchRiskAnalyzer.js +50 -0
- package/dist/core/patchRiskAnalyzer.js.map +1 -0
- package/dist/core/renderRunAgentResult.js +77 -0
- package/dist/core/renderRunAgentResult.js.map +1 -0
- package/dist/core/result/buildApplyStageResult.js +61 -0
- package/dist/core/result/buildApplyStageResult.js.map +1 -0
- package/dist/core/result/buildCliViewModel.js +79 -0
- package/dist/core/result/buildCliViewModel.js.map +1 -0
- package/dist/core/result/buildConversionStageResult.js +62 -0
- package/dist/core/result/buildConversionStageResult.js.map +1 -0
- package/dist/core/result/buildDecisionStageResult.js +61 -0
- package/dist/core/result/buildDecisionStageResult.js.map +1 -0
- package/dist/core/result/buildExecutionResult.js +148 -0
- package/dist/core/result/buildExecutionResult.js.map +1 -0
- package/dist/core/result/buildPreviewStageResult.js +47 -0
- package/dist/core/result/buildPreviewStageResult.js.map +1 -0
- package/dist/core/result/buildSavedDecisionExplanation.js +52 -0
- package/dist/core/result/buildSavedDecisionExplanation.js.map +1 -0
- package/dist/core/result/buildSavedRecommendation.js +39 -0
- package/dist/core/result/buildSavedRecommendation.js.map +1 -0
- package/dist/core/result/buildStageResultV2.js +52 -0
- package/dist/core/result/buildStageResultV2.js.map +1 -0
- package/dist/core/result/renderBundledResult.js +47 -0
- package/dist/core/result/renderBundledResult.js.map +1 -0
- package/dist/core/result/renderCliResult.js +93 -0
- package/dist/core/result/renderCliResult.js.map +1 -0
- package/dist/core/result/scoreTopRisks.js +205 -0
- package/dist/core/result/scoreTopRisks.js.map +1 -0
- package/dist/core/runAgent.js +210 -0
- package/dist/core/runAgent.js.map +1 -0
- package/dist/core/runFeatureAgent.js +684 -0
- package/dist/core/runFeatureAgent.js.map +1 -0
- package/dist/core/runLlmPatchFlow.js +522 -0
- package/dist/core/runLlmPatchFlow.js.map +1 -0
- package/dist/core/saveAgentResult.js +234 -0
- package/dist/core/saveAgentResult.js.map +1 -0
- package/dist/core/scoring/computeConfidenceBreakdown.js +130 -0
- package/dist/core/scoring/computeConfidenceBreakdown.js.map +1 -0
- package/dist/core/scoring/computeConfidenceScore.js +37 -0
- package/dist/core/scoring/computeConfidenceScore.js.map +1 -0
- package/dist/core/scoring/confidenceRules.js +58 -0
- package/dist/core/scoring/confidenceRules.js.map +1 -0
- package/dist/core/scoring/confidenceScore.js +8 -0
- package/dist/core/scoring/confidenceScore.js.map +1 -0
- package/dist/core/selectRelevantBlocks.js +58 -0
- package/dist/core/selectRelevantBlocks.js.map +1 -0
- package/dist/core/selfHealingLoop.js +209 -0
- package/dist/core/selfHealingLoop.js.map +1 -0
- package/dist/core/taskIntentParser.js +165 -0
- package/dist/core/taskIntentParser.js.map +1 -0
- package/dist/core/types/agentResult.js +3 -0
- package/dist/core/types/agentResult.js.map +1 -0
- package/dist/core/types/risk.js +3 -0
- package/dist/core/types/risk.js.map +1 -0
- package/dist/core/validatePatchAgainstSchema.js +100 -0
- package/dist/core/validatePatchAgainstSchema.js.map +1 -0
- package/dist/core/validateSuggestedArchitecture.js +24 -0
- package/dist/core/validateSuggestedArchitecture.js.map +1 -0
- package/dist/engine/buildDecisionExplanation.js +114 -0
- package/dist/engine/buildDecisionExplanation.js.map +1 -0
- package/dist/engine/contradictionDetector.js +40 -0
- package/dist/engine/contradictionDetector.js.map +1 -0
- package/dist/engine/decisionEngine.js +19 -0
- package/dist/engine/decisionEngine.js.map +1 -0
- package/dist/llm/openaiClient.js +19 -0
- package/dist/llm/openaiClient.js.map +1 -0
- package/dist/llm/planFeature.js +57 -0
- package/dist/llm/planFeature.js.map +1 -0
- package/dist/llm/planFix.js +3 -0
- package/dist/llm/planFix.js.map +1 -0
- package/dist/llm/planFullPatch.js +62 -0
- package/dist/llm/planFullPatch.js.map +1 -0
- package/dist/llm/planPatchPreview.js +60 -0
- package/dist/llm/planPatchPreview.js.map +1 -0
- package/dist/llm/prompts.js +131 -0
- package/dist/llm/prompts.js.map +1 -0
- package/dist/llm/schemas.js +28 -0
- package/dist/llm/schemas.js.map +1 -0
- package/dist/patch/apply/formatApplyFlowResult.js +23 -0
- package/dist/patch/apply/formatApplyFlowResult.js.map +1 -0
- package/dist/patch/apply/renderApplyFlowResult.js +15 -0
- package/dist/patch/apply/renderApplyFlowResult.js.map +1 -0
- package/dist/patch/apply/runApplyFlow.js +88 -0
- package/dist/patch/apply/runApplyFlow.js.map +1 -0
- package/dist/patch/applyFlowTypes.js +3 -0
- package/dist/patch/applyFlowTypes.js.map +1 -0
- package/dist/patch/applyPatchPlan.js +117 -0
- package/dist/patch/applyPatchPlan.js.map +1 -0
- package/dist/patch/backupFile.js +23 -0
- package/dist/patch/backupFile.js.map +1 -0
- package/dist/patch/conversion/canConvertGeneratedPlanToPatchPlan.js +57 -0
- package/dist/patch/conversion/canConvertGeneratedPlanToPatchPlan.js.map +1 -0
- package/dist/patch/conversion/convertGeneratedPlanToPatchPlan.js +38 -0
- package/dist/patch/conversion/convertGeneratedPlanToPatchPlan.js.map +1 -0
- package/dist/patch/conversion/formatGeneratedPlanConversionFailure.js +17 -0
- package/dist/patch/conversion/formatGeneratedPlanConversionFailure.js.map +1 -0
- package/dist/patch/conversion/generatedPlanConversionFailureMeta.js +40 -0
- package/dist/patch/conversion/generatedPlanConversionFailureMeta.js.map +1 -0
- package/dist/patch/conversion/generatedPlanConversionTypes.js +3 -0
- package/dist/patch/conversion/generatedPlanConversionTypes.js.map +1 -0
- package/dist/patch/conversion/renderGeneratedPlanConversionFailure.js +16 -0
- package/dist/patch/conversion/renderGeneratedPlanConversionFailure.js.map +1 -0
- package/dist/patch/generatedPlanConversion.js +96 -0
- package/dist/patch/generatedPlanConversion.js.map +1 -0
- package/dist/patch/patchAnchors.js +3 -0
- package/dist/patch/patchAnchors.js.map +1 -0
- package/dist/patch/patchValidationRules.js +116 -0
- package/dist/patch/patchValidationRules.js.map +1 -0
- package/dist/patch/patchValidationTypes.js +3 -0
- package/dist/patch/patchValidationTypes.js.map +1 -0
- package/dist/patch/renderApplyFlowResult.js +26 -0
- package/dist/patch/renderApplyFlowResult.js.map +1 -0
- package/dist/patch/validatePatchPlan.js +148 -0
- package/dist/patch/validatePatchPlan.js.map +1 -0
- package/dist/patch-generation/buildGeneratedPatchPlan.js +94 -0
- package/dist/patch-generation/buildGeneratedPatchPlan.js.map +1 -0
- package/dist/patch-generation/buildPatchOperations.js +41 -0
- package/dist/patch-generation/buildPatchOperations.js.map +1 -0
- package/dist/patch-generation/classifyPatchIntent.js +62 -0
- package/dist/patch-generation/classifyPatchIntent.js.map +1 -0
- package/dist/patch-generation/formatGeneratedPatchPlanPreview.js +25 -0
- package/dist/patch-generation/formatGeneratedPatchPlanPreview.js.map +1 -0
- package/dist/patch-generation/generatePatchPlan.js +74 -0
- package/dist/patch-generation/generatePatchPlan.js.map +1 -0
- package/dist/patch-generation/generatedPatchPlanTypes.js +3 -0
- package/dist/patch-generation/generatedPatchPlanTypes.js.map +1 -0
- package/dist/patch-generation/isIntentAllowed.js +15 -0
- package/dist/patch-generation/isIntentAllowed.js.map +1 -0
- package/dist/patch-generation/renderGeneratedPatchPlan.js +62 -0
- package/dist/patch-generation/renderGeneratedPatchPlan.js.map +1 -0
- package/dist/prompts/developerPrompt.js +213 -0
- package/dist/prompts/developerPrompt.js.map +1 -0
- package/dist/prompts/fullPatchPrompt.js +82 -0
- package/dist/prompts/fullPatchPrompt.js.map +1 -0
- package/dist/prompts/patchPreviewPrompt.js +83 -0
- package/dist/prompts/patchPreviewPrompt.js.map +1 -0
- package/dist/prompts/planFeaturePrompt.js +73 -0
- package/dist/prompts/planFeaturePrompt.js.map +1 -0
- package/dist/prompts/testEngineerContext.js +184 -0
- package/dist/prompts/testEngineerContext.js.map +1 -0
- package/dist/prompts/testEngineerPrompt.js +135 -0
- package/dist/prompts/testEngineerPrompt.js.map +1 -0
- package/dist/repo/analyzeProjectPatterns.js +46 -0
- package/dist/repo/analyzeProjectPatterns.js.map +1 -0
- package/dist/repo/detectProjectStructure.js +45 -0
- package/dist/repo/detectProjectStructure.js.map +1 -0
- package/dist/repo/getGitChangedFiles.js +96 -0
- package/dist/repo/getGitChangedFiles.js.map +1 -0
- package/dist/repo/loadSchemaSnapshot.js +29 -0
- package/dist/repo/loadSchemaSnapshot.js.map +1 -0
- package/dist/repo/rankRelevantFiles.js +306 -0
- package/dist/repo/rankRelevantFiles.js.map +1 -0
- package/dist/repo/readProjectFiles.js +27 -0
- package/dist/repo/readProjectFiles.js.map +1 -0
- package/dist/repo/scanRepo.js +93 -0
- package/dist/repo/scanRepo.js.map +1 -0
- package/dist/repo/validateSuggestedFiles.js +66 -0
- package/dist/repo/validateSuggestedFiles.js.map +1 -0
- package/dist/roles/dataAnalystContext.js +155 -0
- package/dist/roles/dataAnalystContext.js.map +1 -0
- package/dist/roles/detectDataSchema.js +152 -0
- package/dist/roles/detectDataSchema.js.map +1 -0
- package/dist/roles/detectTestComplexity.js +74 -0
- package/dist/roles/detectTestComplexity.js.map +1 -0
- package/dist/roles/detectTestFramework.js +166 -0
- package/dist/roles/detectTestFramework.js.map +1 -0
- package/dist/roles/runDataAnalystFlow.js +221 -0
- package/dist/roles/runDataAnalystFlow.js.map +1 -0
- package/dist/roles/runTestEngineerFlow.js +266 -0
- package/dist/roles/runTestEngineerFlow.js.map +1 -0
- package/dist/roles/testEngineerContext.js +282 -0
- package/dist/roles/testEngineerContext.js.map +1 -0
- package/dist/roles/testOutputValidator.js +474 -0
- package/dist/roles/testOutputValidator.js.map +1 -0
- package/dist/types/agent.js +3 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/analysis.js +3 -0
- package/dist/types/analysis.js.map +1 -0
- package/dist/types/patch.js +3 -0
- package/dist/types/patch.js.map +1 -0
- package/dist/types/project.js +3 -0
- package/dist/types/project.js.map +1 -0
- package/dist/types/schema.js +3 -0
- package/dist/types/schema.js.map +1 -0
- package/dist/utils/executionTracker.js +33 -0
- package/dist/utils/executionTracker.js.map +1 -0
- package/dist/utils/files.js +35 -0
- package/dist/utils/files.js.map +1 -0
- package/dist/utils/logger.js +179 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/paths.js +14 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/trace.js +10 -0
- package/dist/utils/trace.js.map +1 -0
- package/dist/utils/validation.js +24 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +53 -0
- package/tsconfig.json +17 -0
- package/vitest.config.ts +21 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.writeAuditSnapshot = writeAuditSnapshot;
|
|
7
|
+
exports.resolveAuditOutFlag = resolveAuditOutFlag;
|
|
8
|
+
const node_fs_1 = __importDefault(require("node:fs"));
|
|
9
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
10
|
+
// ---------------------------------------------------------------------------
|
|
11
|
+
// writeAuditSnapshot
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
/**
|
|
14
|
+
* Writes a serialized AuditSnapshot to disk as pretty-printed JSON.
|
|
15
|
+
*
|
|
16
|
+
* Side-effect only: no return value, no mutation of the snapshot.
|
|
17
|
+
* Parent directories are created automatically when missing.
|
|
18
|
+
*
|
|
19
|
+
* On failure the error is logged to stderr and the function returns normally —
|
|
20
|
+
* it never throws and never affects stdout.
|
|
21
|
+
*
|
|
22
|
+
* @param snapshot - The AuditSnapshot to serialize.
|
|
23
|
+
* @param filePath - Absolute or relative path for the output file.
|
|
24
|
+
*/
|
|
25
|
+
function writeAuditSnapshot(snapshot, filePath) {
|
|
26
|
+
try {
|
|
27
|
+
const dir = node_path_1.default.dirname(filePath);
|
|
28
|
+
node_fs_1.default.mkdirSync(dir, { recursive: true });
|
|
29
|
+
node_fs_1.default.writeFileSync(filePath, JSON.stringify(snapshot, null, 2), "utf8");
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
33
|
+
console.error(`[audit] Failed to write snapshot: ${message}`);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
// ---------------------------------------------------------------------------
|
|
37
|
+
// resolveAuditOutFlag
|
|
38
|
+
// ---------------------------------------------------------------------------
|
|
39
|
+
/**
|
|
40
|
+
* Parses the `--audit-out=<path>` flag from a raw argv array.
|
|
41
|
+
*
|
|
42
|
+
* Accepts only the `--audit-out=value` form (equals-delimited). A flag with
|
|
43
|
+
* an empty value (`--audit-out=`) is treated as absent and returns null.
|
|
44
|
+
*
|
|
45
|
+
* @param argv - The raw argument vector to inspect (e.g. process.argv).
|
|
46
|
+
* @returns The path string when the flag is present with a non-empty value,
|
|
47
|
+
* or null when absent / empty.
|
|
48
|
+
*/
|
|
49
|
+
function resolveAuditOutFlag(argv) {
|
|
50
|
+
const prefix = "--audit-out=";
|
|
51
|
+
for (const arg of argv) {
|
|
52
|
+
if (arg.startsWith(prefix)) {
|
|
53
|
+
const value = arg.slice(prefix.length);
|
|
54
|
+
return value.length > 0 ? value : null;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=snapshotWriter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"snapshotWriter.js","sourceRoot":"","sources":["../../src/audit/snapshotWriter.ts"],"names":[],"mappings":";;;;;AAoBA,gDAYC;AAgBD,kDASC;AAzDD,sDAAyB;AACzB,0DAA6B;AAG7B,8EAA8E;AAC9E,qBAAqB;AACrB,8EAA8E;AAE9E;;;;;;;;;;;GAWG;AACH,SAAgB,kBAAkB,CAChC,QAAuB,EACvB,QAAgB;IAEhB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,mBAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACnC,iBAAE,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACvC,iBAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IACxE,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjE,OAAO,CAAC,KAAK,CAAC,qCAAqC,OAAO,EAAE,CAAC,CAAC;IAChE,CAAC;AACH,CAAC;AAED,8EAA8E;AAC9E,sBAAsB;AACtB,8EAA8E;AAE9E;;;;;;;;;GASG;AACH,SAAgB,mBAAmB,CAAC,IAAc;IAChD,MAAM,MAAM,GAAG,cAAc,CAAC;IAC9B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YACvC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;QACzC,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.evaluateCiResult = evaluateCiResult;
|
|
4
|
+
function normalizeDecisionMode(result) {
|
|
5
|
+
const mode = result?.decision?.mode;
|
|
6
|
+
if (mode === "blocked" ||
|
|
7
|
+
mode === "preview_only" ||
|
|
8
|
+
mode === "safe_to_apply" ||
|
|
9
|
+
mode === "preview" ||
|
|
10
|
+
mode === "apply") {
|
|
11
|
+
return mode;
|
|
12
|
+
}
|
|
13
|
+
return "unknown";
|
|
14
|
+
}
|
|
15
|
+
function normalizeConfidenceScore(result) {
|
|
16
|
+
if (typeof result?.decision?.confidenceScore === "number") {
|
|
17
|
+
return result.decision.confidenceScore;
|
|
18
|
+
}
|
|
19
|
+
if (typeof result?.decision?.confidence === "number") {
|
|
20
|
+
return result.decision.confidence;
|
|
21
|
+
}
|
|
22
|
+
if (typeof result?.confidence?.finalScore === "number") {
|
|
23
|
+
return result.confidence.finalScore;
|
|
24
|
+
}
|
|
25
|
+
if (typeof result?.confidenceBreakdown?.finalScore === "number") {
|
|
26
|
+
return result.confidenceBreakdown.finalScore;
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
function normalizePenaltyReasons(result) {
|
|
31
|
+
const penalties = result?.confidenceDetails?.penalties ?? [];
|
|
32
|
+
const reasons = penalties
|
|
33
|
+
.map((item) => item.label?.trim())
|
|
34
|
+
.filter((value) => Boolean(value));
|
|
35
|
+
return [...new Set(reasons)];
|
|
36
|
+
}
|
|
37
|
+
function normalizeIssueSources(result) {
|
|
38
|
+
const grouped = result?.issues?.grouped ?? [];
|
|
39
|
+
const sources = grouped
|
|
40
|
+
.flatMap((group) => group.issues ?? [])
|
|
41
|
+
.map((issue) => issue.source?.trim())
|
|
42
|
+
.filter((value) => Boolean(value));
|
|
43
|
+
return [...new Set(sources)];
|
|
44
|
+
}
|
|
45
|
+
function normalizeTopRisks(result) {
|
|
46
|
+
return result?.issues?.topRisks ?? [];
|
|
47
|
+
}
|
|
48
|
+
function hasHighSeverityRisk(result) {
|
|
49
|
+
return normalizeTopRisks(result).some((risk) => risk.severity === "high");
|
|
50
|
+
}
|
|
51
|
+
function buildStatusLine(decisionMode) {
|
|
52
|
+
switch (decisionMode) {
|
|
53
|
+
case "blocked":
|
|
54
|
+
return "STATUS: BLOCKED";
|
|
55
|
+
case "preview_only":
|
|
56
|
+
case "preview":
|
|
57
|
+
return "STATUS: PREVIEW ONLY";
|
|
58
|
+
case "safe_to_apply":
|
|
59
|
+
case "apply":
|
|
60
|
+
return "STATUS: SAFE TO APPLY";
|
|
61
|
+
default:
|
|
62
|
+
return "STATUS: UNKNOWN";
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
function buildSummaryLine(input) {
|
|
66
|
+
const parts = [];
|
|
67
|
+
parts.push(`decision=${input.decisionMode}`);
|
|
68
|
+
if (typeof input.confidenceScore === "number") {
|
|
69
|
+
parts.push(`confidence=${input.confidenceScore}`);
|
|
70
|
+
}
|
|
71
|
+
if (input.result?.decision?.reason) {
|
|
72
|
+
parts.push(`reason=${input.result.decision.reason}`);
|
|
73
|
+
}
|
|
74
|
+
const errorCount = input.result?.issues?.summary?.errors;
|
|
75
|
+
const warningCount = input.result?.issues?.summary?.warnings;
|
|
76
|
+
if (typeof errorCount === "number") {
|
|
77
|
+
parts.push(`errors=${errorCount}`);
|
|
78
|
+
}
|
|
79
|
+
if (typeof warningCount === "number") {
|
|
80
|
+
parts.push(`warnings=${warningCount}`);
|
|
81
|
+
}
|
|
82
|
+
const issueSources = normalizeIssueSources(input.result);
|
|
83
|
+
if (issueSources.length > 0) {
|
|
84
|
+
parts.push(`sources=${issueSources.join(" | ")}`);
|
|
85
|
+
}
|
|
86
|
+
const topRisks = normalizeTopRisks(input.result);
|
|
87
|
+
if (topRisks.length > 0) {
|
|
88
|
+
parts.push(`topRisks=${topRisks
|
|
89
|
+
.slice(0, 3)
|
|
90
|
+
.map((risk) => `${risk.severity ?? "unknown"}:${risk.title ?? risk.id ?? "risk"}`)
|
|
91
|
+
.join(" | ")}`);
|
|
92
|
+
}
|
|
93
|
+
if (input.penaltyReasons.length > 0) {
|
|
94
|
+
parts.push(`penalties=${input.penaltyReasons.slice(0, 4).join(" | ")}`);
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
parts.push("penalties=none");
|
|
98
|
+
}
|
|
99
|
+
return parts.join(" ; ");
|
|
100
|
+
}
|
|
101
|
+
function evaluateCiResult(result) {
|
|
102
|
+
const decisionMode = normalizeDecisionMode(result);
|
|
103
|
+
const confidenceScore = normalizeConfidenceScore(result);
|
|
104
|
+
const penaltyReasons = normalizePenaltyReasons(result);
|
|
105
|
+
const errorCount = result?.issues?.summary?.errors ?? 0;
|
|
106
|
+
const containsHighSeverityRisk = hasHighSeverityRisk(result);
|
|
107
|
+
let ciStatus = "warn";
|
|
108
|
+
let shouldFail = false;
|
|
109
|
+
if (decisionMode === "blocked") {
|
|
110
|
+
ciStatus = "fail";
|
|
111
|
+
shouldFail = true;
|
|
112
|
+
}
|
|
113
|
+
else if (errorCount > 0) {
|
|
114
|
+
ciStatus = "fail";
|
|
115
|
+
shouldFail = true;
|
|
116
|
+
}
|
|
117
|
+
else if (containsHighSeverityRisk) {
|
|
118
|
+
ciStatus = "fail";
|
|
119
|
+
shouldFail = true;
|
|
120
|
+
}
|
|
121
|
+
else if (decisionMode === "preview_only" || decisionMode === "preview") {
|
|
122
|
+
ciStatus = "warn";
|
|
123
|
+
}
|
|
124
|
+
else if (decisionMode === "safe_to_apply" || decisionMode === "apply") {
|
|
125
|
+
ciStatus = "pass";
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
decisionMode,
|
|
129
|
+
ciStatus,
|
|
130
|
+
shouldFail,
|
|
131
|
+
confidenceScore,
|
|
132
|
+
statusLine: result.statusLine || buildStatusLine(decisionMode),
|
|
133
|
+
summaryLine: buildSummaryLine({
|
|
134
|
+
result,
|
|
135
|
+
decisionMode,
|
|
136
|
+
confidenceScore,
|
|
137
|
+
penaltyReasons
|
|
138
|
+
}),
|
|
139
|
+
penaltyReasons
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=evaluateCiResult.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evaluateCiResult.js","sourceRoot":"","sources":["../../src/ci/evaluateCiResult.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildGeneratedPatchPlanPreview = buildGeneratedPatchPlanPreview;
|
|
4
|
+
const classifyPatchIntent_js_1 = require("../patch-generation/classifyPatchIntent.js");
|
|
5
|
+
const isIntentAllowed_js_1 = require("../patch-generation/isIntentAllowed.js");
|
|
6
|
+
const buildPatchOperations_js_1 = require("../patch-generation/buildPatchOperations.js");
|
|
7
|
+
function resolveStrategy(mode) {
|
|
8
|
+
return mode === "blocked" ? "blocked" : "safe";
|
|
9
|
+
}
|
|
10
|
+
function resolveAllowedLabel(allowed) {
|
|
11
|
+
return allowed ? "yes" : "no";
|
|
12
|
+
}
|
|
13
|
+
function renderOperations(intent) {
|
|
14
|
+
if (intent === "unknown") {
|
|
15
|
+
return ["- none"];
|
|
16
|
+
}
|
|
17
|
+
const operations = (0, buildPatchOperations_js_1.buildPatchOperations)(intent);
|
|
18
|
+
if (!operations.length) {
|
|
19
|
+
return ["- none"];
|
|
20
|
+
}
|
|
21
|
+
return operations.map((operation) => {
|
|
22
|
+
const scope = "scope" in operation && typeof operation.scope === "string"
|
|
23
|
+
? operation.scope
|
|
24
|
+
: "single_file";
|
|
25
|
+
return `- ${operation.type} (scope: ${scope})`;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
function resolveReason(intent, allowed) {
|
|
29
|
+
if (!allowed && intent === "unknown") {
|
|
30
|
+
return "Patch generation blocked because task intent is unknown.";
|
|
31
|
+
}
|
|
32
|
+
if (!allowed) {
|
|
33
|
+
return `Patch generation blocked because intent '${intent}' is not allowed for this strategy.`;
|
|
34
|
+
}
|
|
35
|
+
return "Patch generation allowed.";
|
|
36
|
+
}
|
|
37
|
+
function buildGeneratedPatchPlanPreview(input) {
|
|
38
|
+
const reasonCodes = input.reasonCodes ?? [];
|
|
39
|
+
const strategy = resolveStrategy(input.decision.mode);
|
|
40
|
+
const rawIntent = (0, classifyPatchIntent_js_1.classifyPatchIntent)(input.task);
|
|
41
|
+
const intent = rawIntent === "unknown" ? "unknown" : rawIntent;
|
|
42
|
+
const allowed = rawIntent === "unknown" ? false : (0, isIntentAllowed_js_1.isIntentAllowed)(rawIntent, strategy);
|
|
43
|
+
const lines = [];
|
|
44
|
+
lines.push("=== GENERATED PATCH PLAN ===");
|
|
45
|
+
lines.push(`Allowed: ${resolveAllowedLabel(allowed)}`);
|
|
46
|
+
lines.push(`Strategy: ${strategy}`);
|
|
47
|
+
lines.push(`Intent: ${intent}`);
|
|
48
|
+
lines.push(`Confidence: ${input.decision.confidenceScore}`);
|
|
49
|
+
lines.push(`Reason: ${resolveReason(intent, allowed)}`);
|
|
50
|
+
lines.push("");
|
|
51
|
+
lines.push("Operations:");
|
|
52
|
+
lines.push(...renderOperations(intent));
|
|
53
|
+
lines.push("");
|
|
54
|
+
lines.push("Derived From:");
|
|
55
|
+
if (reasonCodes.length === 0) {
|
|
56
|
+
lines.push("- none");
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
for (const code of reasonCodes) {
|
|
60
|
+
lines.push(`- ${code}`);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return lines.join("\n");
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=buildGeneratedPatchPlanPreview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildGeneratedPatchPlanPreview.js","sourceRoot":"","sources":["../../src/cli/buildGeneratedPatchPlanPreview.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.c = void 0;
|
|
4
|
+
exports.colorize = colorize;
|
|
5
|
+
exports.badge = badge;
|
|
6
|
+
exports.c = {
|
|
7
|
+
reset: "\x1b[0m",
|
|
8
|
+
bold: "\x1b[1m",
|
|
9
|
+
dim: "\x1b[2m",
|
|
10
|
+
green: "\x1b[32m",
|
|
11
|
+
yellow: "\x1b[33m",
|
|
12
|
+
red: "\x1b[31m",
|
|
13
|
+
blue: "\x1b[34m",
|
|
14
|
+
cyan: "\x1b[36m",
|
|
15
|
+
white: "\x1b[37m",
|
|
16
|
+
gray: "\x1b[90m",
|
|
17
|
+
orange: "\x1b[38;5;208m",
|
|
18
|
+
bgGreen: "\x1b[42m",
|
|
19
|
+
bgRed: "\x1b[41m",
|
|
20
|
+
bgBlue: "\x1b[44m",
|
|
21
|
+
};
|
|
22
|
+
function colorize(text, ...codes) {
|
|
23
|
+
return codes.join("") + text + exports.c.reset;
|
|
24
|
+
}
|
|
25
|
+
function badge(text, color) {
|
|
26
|
+
return colorize(` ${text} `, exports.c.bold, color);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=colors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.js","sourceRoot":"","sources":["../../src/cli/colors.ts"],"names":[],"mappings":";;;AAmBA,4BAEC;AAED,sBAEC;AAzBY,QAAA,CAAC,GAAG;IACf,KAAK,EAAE,SAAS;IAChB,IAAI,EAAE,SAAS;IACf,GAAG,EAAE,SAAS;IAEd,KAAK,EAAE,UAAU;IACjB,MAAM,EAAE,UAAU;IAClB,GAAG,EAAE,UAAU;IACf,IAAI,EAAE,UAAU;IAChB,IAAI,EAAE,UAAU;IAChB,KAAK,EAAE,UAAU;IACjB,IAAI,EAAE,UAAU;IAChB,MAAM,EAAE,gBAAgB;IAExB,OAAO,EAAE,UAAU;IACnB,KAAK,EAAE,UAAU;IACjB,MAAM,EAAE,UAAU;CACnB,CAAC;AAEF,SAAgB,QAAQ,CAAC,IAAY,EAAE,GAAG,KAAe;IACvD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,GAAG,SAAC,CAAC,KAAK,CAAC;AACzC,CAAC;AAED,SAAgB,KAAK,CAAC,IAAY,EAAE,KAAa;IAC/C,OAAO,QAAQ,CAAC,IAAI,IAAI,GAAG,EAAE,SAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.renderColoredDiff = renderColoredDiff;
|
|
4
|
+
exports.renderDiffSummary = renderDiffSummary;
|
|
5
|
+
const colors_js_1 = require("./colors.js");
|
|
6
|
+
function renderColoredDiff(originalContent, newContent, filePath) {
|
|
7
|
+
const originalLines = originalContent.split("\n");
|
|
8
|
+
const newLines = newContent.split("\n");
|
|
9
|
+
const lines = [];
|
|
10
|
+
lines.push((0, colors_js_1.colorize)(`--- ${filePath}`, colors_js_1.c.bold, colors_js_1.c.white));
|
|
11
|
+
lines.push("");
|
|
12
|
+
const maxLen = Math.max(originalLines.length, newLines.length);
|
|
13
|
+
for (let i = 0; i < maxLen; i++) {
|
|
14
|
+
const origLine = originalLines[i];
|
|
15
|
+
const nextLine = newLines[i];
|
|
16
|
+
if (origLine === nextLine) {
|
|
17
|
+
if (nextLine !== undefined) {
|
|
18
|
+
lines.push((0, colors_js_1.colorize)(` ${nextLine}`, colors_js_1.c.dim, colors_js_1.c.gray));
|
|
19
|
+
}
|
|
20
|
+
continue;
|
|
21
|
+
}
|
|
22
|
+
if (origLine !== undefined) {
|
|
23
|
+
lines.push((0, colors_js_1.colorize)(`- ${origLine}`, colors_js_1.c.red));
|
|
24
|
+
}
|
|
25
|
+
if (nextLine !== undefined) {
|
|
26
|
+
lines.push((0, colors_js_1.colorize)(`+ ${nextLine}`, colors_js_1.c.green));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return lines.join("\n");
|
|
30
|
+
}
|
|
31
|
+
function renderDiffSummary(applied) {
|
|
32
|
+
for (const entry of applied) {
|
|
33
|
+
console.log(renderColoredDiff(entry.original, entry.updated, entry.filePath));
|
|
34
|
+
console.log("");
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=diffOutput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diffOutput.js","sourceRoot":"","sources":["../../src/cli/diffOutput.ts"],"names":[],"mappings":";;AAEA,8CAkCC;AAED,8CASC;AA/CD,2CAA0C;AAE1C,SAAgB,iBAAiB,CAC/B,eAAuB,EACvB,UAAkB,EAClB,QAAgB;IAEhB,MAAM,aAAa,GAAG,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAClD,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAExC,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,IAAA,oBAAQ,EAAC,OAAO,QAAQ,EAAE,EAAE,aAAC,CAAC,IAAI,EAAE,aAAC,CAAC,KAAK,CAAC,CAAC,CAAC;IACzD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,MAAM,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IAE/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAE7B,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;YAC1B,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAC3B,KAAK,CAAC,IAAI,CAAC,IAAA,oBAAQ,EAAC,KAAK,QAAQ,EAAE,EAAE,aAAC,CAAC,GAAG,EAAE,aAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACvD,CAAC;YACD,SAAS;QACX,CAAC;QAED,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,KAAK,CAAC,IAAI,CAAC,IAAA,oBAAQ,EAAC,KAAK,QAAQ,EAAE,EAAE,aAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,KAAK,CAAC,IAAI,CAAC,IAAA,oBAAQ,EAAC,KAAK,QAAQ,EAAE,EAAE,aAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,SAAgB,iBAAiB,CAC/B,OAAuE;IAEvE,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,OAAO,CAAC,GAAG,CACT,iBAAiB,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,QAAQ,CAAC,CACjE,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
|