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,148 @@
|
|
|
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.validatePatchPlan = validatePatchPlan;
|
|
7
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
8
|
+
const files_js_1 = require("../utils/files.js");
|
|
9
|
+
function isSupportedOperation(value) {
|
|
10
|
+
return value === "create" || value === "modify";
|
|
11
|
+
}
|
|
12
|
+
function normalizePatchPath(filePath) {
|
|
13
|
+
return filePath.replace(/\\/g, "/").trim();
|
|
14
|
+
}
|
|
15
|
+
function resolvePatchPath(targetPath, patchPath) {
|
|
16
|
+
return node_path_1.default.resolve(targetPath, patchPath);
|
|
17
|
+
}
|
|
18
|
+
function isPathOutsideRepo(targetPath, patchPath) {
|
|
19
|
+
const resolvedRepoRoot = node_path_1.default.resolve(targetPath);
|
|
20
|
+
const resolvedPatchPath = resolvePatchPath(targetPath, patchPath);
|
|
21
|
+
const relative = node_path_1.default.relative(resolvedRepoRoot, resolvedPatchPath);
|
|
22
|
+
return relative.startsWith("..") || node_path_1.default.isAbsolute(relative);
|
|
23
|
+
}
|
|
24
|
+
function isProtectedFilePath(normalizedPath) {
|
|
25
|
+
return (normalizedPath === ".env" ||
|
|
26
|
+
normalizedPath.startsWith(".env.") ||
|
|
27
|
+
normalizedPath === "package-lock.json" ||
|
|
28
|
+
normalizedPath === "yarn.lock" ||
|
|
29
|
+
normalizedPath === "pnpm-lock.yaml" ||
|
|
30
|
+
normalizedPath.startsWith(".github/workflows/") ||
|
|
31
|
+
normalizedPath.startsWith(".git/"));
|
|
32
|
+
}
|
|
33
|
+
function isNodeModulesPath(normalizedPath) {
|
|
34
|
+
return normalizedPath.includes("node_modules/");
|
|
35
|
+
}
|
|
36
|
+
function isAgentArtifactPath(normalizedPath) {
|
|
37
|
+
return (normalizedPath.startsWith(".agent-patches") ||
|
|
38
|
+
normalizedPath.startsWith(".agent-backups") ||
|
|
39
|
+
normalizedPath.startsWith(".agent-cache"));
|
|
40
|
+
}
|
|
41
|
+
function buildIssue(input) {
|
|
42
|
+
return {
|
|
43
|
+
level: input.level,
|
|
44
|
+
code: input.code,
|
|
45
|
+
message: input.message,
|
|
46
|
+
filePath: input.filePath,
|
|
47
|
+
details: input.details,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
async function validatePatchPlan(input) {
|
|
51
|
+
const issues = [];
|
|
52
|
+
const seenPaths = new Set();
|
|
53
|
+
for (const patch of input.patchPlan.patches) {
|
|
54
|
+
if (!patch.path || !patch.path.trim()) {
|
|
55
|
+
issues.push(buildIssue({
|
|
56
|
+
level: "error",
|
|
57
|
+
code: "MISSING_TARGET_PATH",
|
|
58
|
+
message: "Patch item is missing a target path.",
|
|
59
|
+
}));
|
|
60
|
+
continue;
|
|
61
|
+
}
|
|
62
|
+
const normalizedPath = normalizePatchPath(patch.path);
|
|
63
|
+
if (!isSupportedOperation(patch.operation)) {
|
|
64
|
+
issues.push(buildIssue({
|
|
65
|
+
level: "error",
|
|
66
|
+
code: "UNSUPPORTED_OPERATION",
|
|
67
|
+
message: `Unsupported patch operation '${patch.operation}'.`,
|
|
68
|
+
filePath: normalizedPath,
|
|
69
|
+
}));
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
if (!patch.contentPreview || !patch.contentPreview.trim()) {
|
|
73
|
+
issues.push(buildIssue({
|
|
74
|
+
level: "warning",
|
|
75
|
+
code: "EMPTY_CONTENT_PREVIEW",
|
|
76
|
+
message: "Patch item has empty content preview.",
|
|
77
|
+
filePath: normalizedPath,
|
|
78
|
+
}));
|
|
79
|
+
}
|
|
80
|
+
if (seenPaths.has(normalizedPath)) {
|
|
81
|
+
issues.push(buildIssue({
|
|
82
|
+
level: "warning",
|
|
83
|
+
code: "DUPLICATE_TARGET_PATH",
|
|
84
|
+
message: "Multiple patch items target the same file.",
|
|
85
|
+
filePath: normalizedPath,
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
seenPaths.add(normalizedPath);
|
|
90
|
+
}
|
|
91
|
+
if (isPathOutsideRepo(input.targetPath, normalizedPath)) {
|
|
92
|
+
issues.push(buildIssue({
|
|
93
|
+
level: "error",
|
|
94
|
+
code: "PATH_OUTSIDE_REPO",
|
|
95
|
+
message: "Patch target resolves outside the repository root.",
|
|
96
|
+
filePath: normalizedPath,
|
|
97
|
+
}));
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
if (isProtectedFilePath(normalizedPath)) {
|
|
101
|
+
issues.push(buildIssue({
|
|
102
|
+
level: "error",
|
|
103
|
+
code: "TARGETS_PROTECTED_FILE",
|
|
104
|
+
message: "Patch targets a protected file or workflow path.",
|
|
105
|
+
filePath: normalizedPath,
|
|
106
|
+
}));
|
|
107
|
+
}
|
|
108
|
+
const absoluteTargetPath = resolvePatchPath(input.targetPath, normalizedPath);
|
|
109
|
+
const exists = await (0, files_js_1.fileExists)(absoluteTargetPath);
|
|
110
|
+
if (patch.operation === "create" && exists) {
|
|
111
|
+
issues.push(buildIssue({
|
|
112
|
+
level: "warning",
|
|
113
|
+
code: "CREATE_TARGET_ALREADY_EXISTS",
|
|
114
|
+
message: "Create operation targets an existing file.",
|
|
115
|
+
filePath: normalizedPath,
|
|
116
|
+
}));
|
|
117
|
+
}
|
|
118
|
+
if (patch.operation === "modify" && !exists) {
|
|
119
|
+
issues.push(buildIssue({
|
|
120
|
+
level: "error",
|
|
121
|
+
code: "MODIFY_TARGET_MISSING",
|
|
122
|
+
message: "Modify operation targets a file that does not exist.",
|
|
123
|
+
filePath: normalizedPath,
|
|
124
|
+
}));
|
|
125
|
+
}
|
|
126
|
+
if (isNodeModulesPath(normalizedPath)) {
|
|
127
|
+
issues.push(buildIssue({
|
|
128
|
+
level: "warning",
|
|
129
|
+
code: "TARGETS_NODE_MODULES",
|
|
130
|
+
message: "Patch targets a file inside node_modules, which is usually unintended.",
|
|
131
|
+
filePath: normalizedPath,
|
|
132
|
+
}));
|
|
133
|
+
}
|
|
134
|
+
if (isAgentArtifactPath(normalizedPath)) {
|
|
135
|
+
issues.push(buildIssue({
|
|
136
|
+
level: "warning",
|
|
137
|
+
code: "TARGETS_AGENT_ARTIFACT",
|
|
138
|
+
message: "Patch targets an internal agent artifact directory.",
|
|
139
|
+
filePath: normalizedPath,
|
|
140
|
+
}));
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
return {
|
|
144
|
+
isValid: !issues.some((issue) => issue.level === "error"),
|
|
145
|
+
issues,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
//# sourceMappingURL=validatePatchPlan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validatePatchPlan.js","sourceRoot":"","sources":["../../src/patch/validatePatchPlan.ts"],"names":[],"mappings":";;;;;AA8EA,8CAqIC;AAnND,0DAA6B;AAM7B,gDAA+C;AAE/C,SAAS,oBAAoB,CAAC,KAAa;IACzC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,CAAC;AAClD,CAAC;AAED,SAAS,kBAAkB,CAAC,QAAgB;IAC1C,OAAO,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;AAC7C,CAAC;AAED,SAAS,gBAAgB,CAAC,UAAkB,EAAE,SAAiB;IAC7D,OAAO,mBAAI,CAAC,OAAO,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;AAC7C,CAAC;AAED,SAAS,iBAAiB,CAAC,UAAkB,EAAE,SAAiB;IAC9D,MAAM,gBAAgB,GAAG,mBAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAClD,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;IAClE,MAAM,QAAQ,GAAG,mBAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,CAAC;IAEpE,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,mBAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AAChE,CAAC;AAED,SAAS,mBAAmB,CAAC,cAAsB;IACjD,OAAO,CACL,cAAc,KAAK,MAAM;QACzB,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC;QAClC,cAAc,KAAK,mBAAmB;QACtC,cAAc,KAAK,WAAW;QAC9B,cAAc,KAAK,gBAAgB;QACnC,cAAc,CAAC,UAAU,CAAC,oBAAoB,CAAC;QAC/C,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,CACnC,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CAAC,cAAsB;IAC/C,OAAO,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;AAClD,CAAC;AAED,SAAS,mBAAmB,CAAC,cAAsB;IACjD,OAAO,CACL,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC;QAC3C,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC;QAC3C,cAAc,CAAC,UAAU,CAAC,cAAc,CAAC,CAC1C,CAAC;AACJ,CAAC;AAED,SAAS,UAAU,CAAC,KAgBnB;IACC,OAAO;QACL,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,OAAO,EAAE,KAAK,CAAC,OAAO;KACvB,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,iBAAiB,CAAC,KAGvC;IACC,MAAM,MAAM,GAA2B,EAAE,CAAC;IAC1C,MAAM,SAAS,GAAG,IAAI,GAAG,EAAU,CAAC;IAEpC,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QAC5C,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YACtC,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,qBAAqB;gBAC3B,OAAO,EAAE,sCAAsC;aAChD,CAAC,CACH,CAAC;YACF,SAAS;QACX,CAAC;QAED,MAAM,cAAc,GAAG,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAEtD,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;YAC3C,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,uBAAuB;gBAC7B,OAAO,EAAE,gCAAgC,KAAK,CAAC,SAAS,IAAI;gBAC5D,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;YACF,SAAS;QACX,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,cAAc,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,EAAE,EAAE,CAAC;YAC1D,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,uBAAuB;gBAC7B,OAAO,EAAE,uCAAuC;gBAChD,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC;YAClC,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,uBAAuB;gBAC7B,OAAO,EAAE,4CAA4C;gBACrD,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,iBAAiB,CAAC,KAAK,CAAC,UAAU,EAAE,cAAc,CAAC,EAAE,CAAC;YACxD,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,mBAAmB;gBACzB,OAAO,EAAE,oDAAoD;gBAC7D,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;YACF,SAAS;QACX,CAAC;QAED,IAAI,mBAAmB,CAAC,cAAc,CAAC,EAAE,CAAC;YACxC,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,wBAAwB;gBAC9B,OAAO,EAAE,kDAAkD;gBAC3D,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;QAED,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,KAAK,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;QAC9E,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAU,EAAC,kBAAkB,CAAC,CAAC;QAEpD,IAAI,KAAK,CAAC,SAAS,KAAK,QAAQ,IAAI,MAAM,EAAE,CAAC;YAC3C,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,8BAA8B;gBACpC,OAAO,EAAE,4CAA4C;gBACrD,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,KAAK,CAAC,SAAS,KAAK,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5C,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,uBAAuB;gBAC7B,OAAO,EAAE,sDAAsD;gBAC/D,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,iBAAiB,CAAC,cAAc,CAAC,EAAE,CAAC;YACtC,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,sBAAsB;gBAC5B,OAAO,EACL,wEAAwE;gBAC1E,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,mBAAmB,CAAC,cAAc,CAAC,EAAE,CAAC;YACxC,MAAM,CAAC,IAAI,CACT,UAAU,CAAC;gBACT,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,wBAAwB;gBAC9B,OAAO,EAAE,qDAAqD;gBAC9D,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IAED,OAAO;QACL,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,OAAO,CAAC;QACzD,MAAM;KACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildGeneratedPatchPlan = buildGeneratedPatchPlan;
|
|
4
|
+
const classifyPatchIntent_js_1 = require("./classifyPatchIntent.js");
|
|
5
|
+
function mapIntent(intent) {
|
|
6
|
+
switch (intent) {
|
|
7
|
+
case "safe_replace":
|
|
8
|
+
case "add_comment":
|
|
9
|
+
case "update_import":
|
|
10
|
+
case "rename_symbol":
|
|
11
|
+
return intent;
|
|
12
|
+
default:
|
|
13
|
+
return "add_comment";
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
function buildOperations(intent) {
|
|
17
|
+
switch (intent) {
|
|
18
|
+
case "add_comment":
|
|
19
|
+
return [
|
|
20
|
+
{
|
|
21
|
+
type: "add_comment",
|
|
22
|
+
filePath: "unknown",
|
|
23
|
+
comment: "TODO",
|
|
24
|
+
target: "unknown"
|
|
25
|
+
}
|
|
26
|
+
];
|
|
27
|
+
case "safe_replace":
|
|
28
|
+
return [
|
|
29
|
+
{
|
|
30
|
+
type: "safe_replace",
|
|
31
|
+
filePath: "unknown",
|
|
32
|
+
find: "old_value",
|
|
33
|
+
replaceWith: "new_value",
|
|
34
|
+
matchMode: "exact"
|
|
35
|
+
}
|
|
36
|
+
];
|
|
37
|
+
case "update_import":
|
|
38
|
+
return [
|
|
39
|
+
{
|
|
40
|
+
type: "update_import",
|
|
41
|
+
filePath: "unknown",
|
|
42
|
+
from: "old/import",
|
|
43
|
+
to: "new/import"
|
|
44
|
+
}
|
|
45
|
+
];
|
|
46
|
+
case "rename_symbol":
|
|
47
|
+
return [
|
|
48
|
+
{
|
|
49
|
+
type: "rename_symbol",
|
|
50
|
+
filePath: "unknown",
|
|
51
|
+
from: "oldName",
|
|
52
|
+
to: "newName"
|
|
53
|
+
}
|
|
54
|
+
];
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function buildSummary(intent) {
|
|
58
|
+
switch (intent) {
|
|
59
|
+
case "add_comment":
|
|
60
|
+
return "Adds a comment in a deterministic location.";
|
|
61
|
+
case "safe_replace":
|
|
62
|
+
return "Performs a safe deterministic replacement.";
|
|
63
|
+
case "update_import":
|
|
64
|
+
return "Updates an import path in a deterministic way.";
|
|
65
|
+
case "rename_symbol":
|
|
66
|
+
return "Renames a symbol intent in preview form.";
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
function buildWarnings(input, intent) {
|
|
70
|
+
const warnings = [];
|
|
71
|
+
if (input.decision.mode !== "safe_to_apply") {
|
|
72
|
+
warnings.push(`Decision mode is '${input.decision.mode}', so generated operations are preview-oriented.`);
|
|
73
|
+
}
|
|
74
|
+
if (intent !== "safe_replace") {
|
|
75
|
+
warnings.push(`Intent '${intent}' is not convertible to a real PatchPlan in v1 unless explicitly supported.`);
|
|
76
|
+
}
|
|
77
|
+
if (input.reasonCodes.length > 0) {
|
|
78
|
+
warnings.push(`Reason codes: ${input.reasonCodes.join(", ")}`);
|
|
79
|
+
}
|
|
80
|
+
return warnings;
|
|
81
|
+
}
|
|
82
|
+
function buildGeneratedPatchPlan(input) {
|
|
83
|
+
const rawIntent = (0, classifyPatchIntent_js_1.classifyPatchIntent)(input.task);
|
|
84
|
+
const intent = mapIntent(rawIntent);
|
|
85
|
+
const operations = buildOperations(intent);
|
|
86
|
+
return {
|
|
87
|
+
version: 1,
|
|
88
|
+
intent,
|
|
89
|
+
operations,
|
|
90
|
+
summary: buildSummary(intent),
|
|
91
|
+
warnings: buildWarnings(input, intent)
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=buildGeneratedPatchPlan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildGeneratedPatchPlan.js","sourceRoot":"","sources":["../../src/patch-generation/buildGeneratedPatchPlan.ts"],"names":[],"mappings":";;AA4GA,0DAYC;AAxHD,qEAA+D;AAgB/D,SAAS,SAAS,CAAC,MAAc;IAC/B,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,cAAc,CAAC;QACpB,KAAK,aAAa,CAAC;QACnB,KAAK,eAAe,CAAC;QACrB,KAAK,eAAe;YAClB,OAAO,MAAM,CAAC;QAChB;YACE,OAAO,aAAa,CAAC;IACzB,CAAC;AACH,CAAC;AAED,SAAS,eAAe,CAAC,MAA4B;IACnD,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,aAAa;YAChB,OAAO;gBACL;oBACE,IAAI,EAAE,aAAa;oBACnB,QAAQ,EAAE,SAAS;oBACnB,OAAO,EAAE,MAAM;oBACf,MAAM,EAAE,SAAS;iBAClB;aACF,CAAC;QAEJ,KAAK,cAAc;YACjB,OAAO;gBACL;oBACE,IAAI,EAAE,cAAc;oBACpB,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,WAAW;oBACjB,WAAW,EAAE,WAAW;oBACxB,SAAS,EAAE,OAAO;iBACnB;aACF,CAAC;QAEJ,KAAK,eAAe;YAClB,OAAO;gBACL;oBACE,IAAI,EAAE,eAAe;oBACrB,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,YAAY;oBAClB,EAAE,EAAE,YAAY;iBACjB;aACF,CAAC;QAEJ,KAAK,eAAe;YAClB,OAAO;gBACL;oBACE,IAAI,EAAE,eAAe;oBACrB,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,SAAS;oBACf,EAAE,EAAE,SAAS;iBACd;aACF,CAAC;IACN,CAAC;AACH,CAAC;AAED,SAAS,YAAY,CAAC,MAA4B;IAChD,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,aAAa;YAChB,OAAO,6CAA6C,CAAC;QACvD,KAAK,cAAc;YACjB,OAAO,4CAA4C,CAAC;QACtD,KAAK,eAAe;YAClB,OAAO,gDAAgD,CAAC;QAC1D,KAAK,eAAe;YAClB,OAAO,0CAA0C,CAAC;IACtD,CAAC;AACH,CAAC;AAED,SAAS,aAAa,CAAC,KAAY,EAAE,MAA4B;IAC/D,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,KAAK,eAAe,EAAE,CAAC;QAC5C,QAAQ,CAAC,IAAI,CACX,qBAAqB,KAAK,CAAC,QAAQ,CAAC,IAAI,kDAAkD,CAC3F,CAAC;IACJ,CAAC;IAED,IAAI,MAAM,KAAK,cAAc,EAAE,CAAC;QAC9B,QAAQ,CAAC,IAAI,CACX,WAAW,MAAM,6EAA6E,CAC/F,CAAC;IACJ,CAAC;IAED,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACjC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAgB,uBAAuB,CAAC,KAAY;IAClD,MAAM,SAAS,GAAG,IAAA,4CAAmB,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAClD,MAAM,MAAM,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;IACpC,MAAM,UAAU,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IAE3C,OAAO;QACL,OAAO,EAAE,CAAC;QACV,MAAM;QACN,UAAU;QACV,OAAO,EAAE,YAAY,CAAC,MAAM,CAAC;QAC7B,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC;KACvC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildPatchOperations = buildPatchOperations;
|
|
4
|
+
function buildPatchOperations(intent) {
|
|
5
|
+
switch (intent) {
|
|
6
|
+
case "rename_symbol":
|
|
7
|
+
return [
|
|
8
|
+
{
|
|
9
|
+
type: "rename",
|
|
10
|
+
scope: "single_file"
|
|
11
|
+
}
|
|
12
|
+
];
|
|
13
|
+
case "update_import":
|
|
14
|
+
return [
|
|
15
|
+
{
|
|
16
|
+
type: "update_import",
|
|
17
|
+
scope: "single_file"
|
|
18
|
+
}
|
|
19
|
+
];
|
|
20
|
+
case "add_comment":
|
|
21
|
+
return [
|
|
22
|
+
{
|
|
23
|
+
type: "insert_comment",
|
|
24
|
+
scope: "single_file",
|
|
25
|
+
position: "line_above_target"
|
|
26
|
+
}
|
|
27
|
+
];
|
|
28
|
+
case "safe_replace":
|
|
29
|
+
return [
|
|
30
|
+
{
|
|
31
|
+
type: "replace_text",
|
|
32
|
+
scope: "single_file",
|
|
33
|
+
matchMode: "exact"
|
|
34
|
+
}
|
|
35
|
+
];
|
|
36
|
+
case "unknown":
|
|
37
|
+
default:
|
|
38
|
+
return [];
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=buildPatchOperations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildPatchOperations.js","sourceRoot":"","sources":["../../src/patch-generation/buildPatchOperations.ts"],"names":[],"mappings":";;AAsBA,oDAwCC;AAxCD,SAAgB,oBAAoB,CAAC,MAAmB;IACtD,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,eAAe;YAClB,OAAO;gBACL;oBACE,IAAI,EAAE,QAAQ;oBACd,KAAK,EAAE,aAAa;iBACrB;aACF,CAAC;QAEJ,KAAK,eAAe;YAClB,OAAO;gBACL;oBACE,IAAI,EAAE,eAAe;oBACrB,KAAK,EAAE,aAAa;iBACrB;aACF,CAAC;QAEJ,KAAK,aAAa;YAChB,OAAO;gBACL;oBACE,IAAI,EAAE,gBAAgB;oBACtB,KAAK,EAAE,aAAa;oBACpB,QAAQ,EAAE,mBAAmB;iBAC9B;aACF,CAAC;QAEJ,KAAK,cAAc;YACjB,OAAO;gBACL;oBACE,IAAI,EAAE,cAAc;oBACpB,KAAK,EAAE,aAAa;oBACpB,SAAS,EAAE,OAAO;iBACnB;aACF,CAAC;QAEJ,KAAK,SAAS,CAAC;QACf;YACE,OAAO,EAAE,CAAC;IACd,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.classifyPatchIntent = classifyPatchIntent;
|
|
4
|
+
function normalizeTask(task) {
|
|
5
|
+
return task.trim().toLowerCase();
|
|
6
|
+
}
|
|
7
|
+
function includesAny(text, keywords) {
|
|
8
|
+
return keywords.some((keyword) => text.includes(keyword));
|
|
9
|
+
}
|
|
10
|
+
function classifyPatchIntent(task) {
|
|
11
|
+
const normalizedTask = normalizeTask(task);
|
|
12
|
+
if (!normalizedTask) {
|
|
13
|
+
return "unknown";
|
|
14
|
+
}
|
|
15
|
+
if (includesAny(normalizedTask, [
|
|
16
|
+
"update import",
|
|
17
|
+
"fix import",
|
|
18
|
+
"change import",
|
|
19
|
+
"import path",
|
|
20
|
+
"adjust import"
|
|
21
|
+
])) {
|
|
22
|
+
// If it's a test file context, let LLM handle it
|
|
23
|
+
const isTestContext = includesAny(normalizedTask, [
|
|
24
|
+
"spec", "test", "cypress", "playwright", "selenium",
|
|
25
|
+
"cucumber", "jest", "pytest", "feature", "step"
|
|
26
|
+
]);
|
|
27
|
+
if (isTestContext)
|
|
28
|
+
return "unknown";
|
|
29
|
+
return "update_import";
|
|
30
|
+
}
|
|
31
|
+
if (includesAny(normalizedTask, [
|
|
32
|
+
"rename function",
|
|
33
|
+
"rename variable",
|
|
34
|
+
"rename helper",
|
|
35
|
+
"rename method",
|
|
36
|
+
"rename class",
|
|
37
|
+
"change name",
|
|
38
|
+
"rename "
|
|
39
|
+
])) {
|
|
40
|
+
return "rename_symbol";
|
|
41
|
+
}
|
|
42
|
+
if (includesAny(normalizedTask, [
|
|
43
|
+
"add comment",
|
|
44
|
+
"insert comment",
|
|
45
|
+
"append comment",
|
|
46
|
+
"document with comment",
|
|
47
|
+
"add explanation comment"
|
|
48
|
+
])) {
|
|
49
|
+
return "add_comment";
|
|
50
|
+
}
|
|
51
|
+
if (includesAny(normalizedTask, [
|
|
52
|
+
"safe replace",
|
|
53
|
+
"replace exact text",
|
|
54
|
+
"replace string",
|
|
55
|
+
"update text",
|
|
56
|
+
"replace "
|
|
57
|
+
])) {
|
|
58
|
+
return "safe_replace";
|
|
59
|
+
}
|
|
60
|
+
return "unknown";
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=classifyPatchIntent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"classifyPatchIntent.js","sourceRoot":"","sources":["../../src/patch-generation/classifyPatchIntent.ts"],"names":[],"mappings":";;AAeA,kDAgEC;AAxED,SAAS,aAAa,CAAC,IAAY;IACjC,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AACnC,CAAC;AAED,SAAS,WAAW,CAAC,IAAY,EAAE,QAA2B;IAC5D,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;AAC5D,CAAC;AAED,SAAgB,mBAAmB,CAAC,IAAY;IAC9C,MAAM,cAAc,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IAE3C,IAAI,CAAC,cAAc,EAAE,CAAC;QACpB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,IACA,WAAW,CAAC,cAAc,EAAE;QAC1B,eAAe;QACf,YAAY;QACZ,eAAe;QACf,aAAa;QACb,eAAe;KAChB,CAAC,EACF,CAAC;QACD,iDAAiD;QACjD,MAAM,aAAa,GAAG,WAAW,CAAC,cAAc,EAAE;YAChD,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU;YACnD,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM;SAChD,CAAC,CAAC;QACH,IAAI,aAAa;YAAE,OAAO,SAAS,CAAC;QACpC,OAAO,eAAe,CAAC;IACzB,CAAC;IAEC,IACE,WAAW,CAAC,cAAc,EAAE;QAC1B,iBAAiB;QACjB,iBAAiB;QACjB,eAAe;QACf,eAAe;QACf,cAAc;QACd,aAAa;QACb,SAAS;KACV,CAAC,EACF,CAAC;QACD,OAAO,eAAe,CAAC;IACzB,CAAC;IAED,IACE,WAAW,CAAC,cAAc,EAAE;QAC1B,aAAa;QACb,gBAAgB;QAChB,gBAAgB;QAChB,uBAAuB;QACvB,yBAAyB;KAC1B,CAAC,EACF,CAAC;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,IACE,WAAW,CAAC,cAAc,EAAE;QAC1B,cAAc;QACd,oBAAoB;QACpB,gBAAgB;QAChB,aAAa;QACb,UAAU;KACX,CAAC,EACF,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatGeneratedPatchPlanPreview = formatGeneratedPatchPlanPreview;
|
|
4
|
+
function formatGeneratedPatchPlanPreview(plan) {
|
|
5
|
+
const operationCount = plan.operations.length;
|
|
6
|
+
return {
|
|
7
|
+
stage: "generated_patch_preview",
|
|
8
|
+
status: "info",
|
|
9
|
+
summary: operationCount === 1
|
|
10
|
+
? "Generated patch preview contains 1 operation."
|
|
11
|
+
: `Generated patch preview contains ${operationCount} operations.`,
|
|
12
|
+
details: operationCount > 0
|
|
13
|
+
? plan.operations
|
|
14
|
+
.map((operation, index) => {
|
|
15
|
+
const filePath = "filePath" in operation && typeof operation.filePath === "string"
|
|
16
|
+
? operation.filePath
|
|
17
|
+
: "unknown";
|
|
18
|
+
return `${index + 1}. ${operation.type} -> ${filePath}`;
|
|
19
|
+
})
|
|
20
|
+
.join("\n")
|
|
21
|
+
: "No operations were generated.",
|
|
22
|
+
operationCount
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=formatGeneratedPatchPlanPreview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatGeneratedPatchPlanPreview.js","sourceRoot":"","sources":["../../src/patch-generation/formatGeneratedPatchPlanPreview.ts"],"names":[],"mappings":";;AAEA,0EAyBC;AAzBD,SAAgB,+BAA+B,CAAC,IAAwB;IACtE,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAE9C,OAAO;QACL,KAAK,EAAE,yBAAyB;QAChC,MAAM,EAAE,MAAM;QACd,OAAO,EACL,cAAc,KAAK,CAAC;YAClB,CAAC,CAAC,+CAA+C;YACjD,CAAC,CAAC,oCAAoC,cAAc,cAAc;QACtE,OAAO,EACL,cAAc,GAAG,CAAC;YAChB,CAAC,CAAC,IAAI,CAAC,UAAU;iBACZ,GAAG,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE;gBACxB,MAAM,QAAQ,GACZ,UAAU,IAAI,SAAS,IAAI,OAAO,SAAS,CAAC,QAAQ,KAAK,QAAQ;oBAC/D,CAAC,CAAC,SAAS,CAAC,QAAQ;oBACpB,CAAC,CAAC,SAAS,CAAC;gBAEhB,OAAO,GAAG,KAAK,GAAG,CAAC,KAAK,SAAS,CAAC,IAAI,OAAO,QAAQ,EAAE,CAAC;YAC1D,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,CAAC;YACf,CAAC,CAAC,+BAA+B;QACrC,cAAc;KACN,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.generatePatchPlan = generatePatchPlan;
|
|
4
|
+
const buildPatchOperations_js_1 = require("./buildPatchOperations.js");
|
|
5
|
+
const classifyPatchIntent_js_1 = require("./classifyPatchIntent.js");
|
|
6
|
+
const isIntentAllowed_js_1 = require("./isIntentAllowed.js");
|
|
7
|
+
function mapDecisionModeToStrategy(mode) {
|
|
8
|
+
switch (mode) {
|
|
9
|
+
case "blocked":
|
|
10
|
+
return "blocked";
|
|
11
|
+
case "preview_only":
|
|
12
|
+
return "restricted";
|
|
13
|
+
case "safe_to_apply":
|
|
14
|
+
return "safe";
|
|
15
|
+
default:
|
|
16
|
+
return "blocked";
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function generatePatchPlan(input) {
|
|
20
|
+
const strategy = mapDecisionModeToStrategy(input.decision.mode);
|
|
21
|
+
const intent = (0, classifyPatchIntent_js_1.classifyPatchIntent)(input.task);
|
|
22
|
+
const derivedFrom = input.reasonCodes ?? [];
|
|
23
|
+
if (strategy === "blocked") {
|
|
24
|
+
return {
|
|
25
|
+
allowed: false,
|
|
26
|
+
strategy,
|
|
27
|
+
intent,
|
|
28
|
+
operations: [],
|
|
29
|
+
metadata: {
|
|
30
|
+
reason: "Patch generation blocked by decision mode.",
|
|
31
|
+
derivedFrom,
|
|
32
|
+
confidenceScore: input.decision.confidenceScore
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
if (intent === "unknown") {
|
|
37
|
+
return {
|
|
38
|
+
allowed: false,
|
|
39
|
+
strategy,
|
|
40
|
+
intent,
|
|
41
|
+
operations: [],
|
|
42
|
+
metadata: {
|
|
43
|
+
reason: "Patch generation blocked because task intent is unknown.",
|
|
44
|
+
derivedFrom,
|
|
45
|
+
confidenceScore: input.decision.confidenceScore
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
if (!(0, isIntentAllowed_js_1.isIntentAllowed)(intent, strategy)) {
|
|
50
|
+
return {
|
|
51
|
+
allowed: false,
|
|
52
|
+
strategy,
|
|
53
|
+
intent,
|
|
54
|
+
operations: [],
|
|
55
|
+
metadata: {
|
|
56
|
+
reason: `Patch intent is not allowed for strategy: ${strategy}.`,
|
|
57
|
+
derivedFrom,
|
|
58
|
+
confidenceScore: input.decision.confidenceScore
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
allowed: true,
|
|
64
|
+
strategy,
|
|
65
|
+
intent,
|
|
66
|
+
operations: (0, buildPatchOperations_js_1.buildPatchOperations)(intent),
|
|
67
|
+
metadata: {
|
|
68
|
+
reason: "Patch plan generated successfully from deterministic intent classification.",
|
|
69
|
+
derivedFrom,
|
|
70
|
+
confidenceScore: input.decision.confidenceScore
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=generatePatchPlan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generatePatchPlan.js","sourceRoot":"","sources":["../../src/patch-generation/generatePatchPlan.ts"],"names":[],"mappings":";;AA8CA,8CA4DC;AA1GD,uEAAsF;AACtF,qEAGkC;AAClC,6DAG8B;AAyB9B,SAAS,yBAAyB,CAAC,IAAkB;IACnD,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,SAAS;YACZ,OAAO,SAAS,CAAC;QACnB,KAAK,cAAc;YACjB,OAAO,YAAY,CAAC;QACtB,KAAK,eAAe;YAClB,OAAO,MAAM,CAAC;QAChB;YACE,OAAO,SAAS,CAAC;IACrB,CAAC;AACH,CAAC;AAED,SAAgB,iBAAiB,CAC/B,KAA6B;IAE7B,MAAM,QAAQ,GAAG,yBAAyB,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAChE,MAAM,MAAM,GAAG,IAAA,4CAAmB,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,EAAE,CAAC;IAE5C,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;QAC3B,OAAO;YACL,OAAO,EAAE,KAAK;YACd,QAAQ;YACR,MAAM;YACN,UAAU,EAAE,EAAE;YACd,QAAQ,EAAE;gBACR,MAAM,EAAE,4CAA4C;gBACpD,WAAW;gBACX,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,eAAe;aAChD;SACF,CAAC;IACJ,CAAC;IAED,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,OAAO;YACL,OAAO,EAAE,KAAK;YACd,QAAQ;YACR,MAAM;YACN,UAAU,EAAE,EAAE;YACd,QAAQ,EAAE;gBACR,MAAM,EAAE,0DAA0D;gBAClE,WAAW;gBACX,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,eAAe;aAChD;SACF,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,IAAA,oCAAe,EAAC,MAAM,EAAE,QAAQ,CAAC,EAAE,CAAC;QACvC,OAAO;YACL,OAAO,EAAE,KAAK;YACd,QAAQ;YACR,MAAM;YACN,UAAU,EAAE,EAAE;YACd,QAAQ,EAAE;gBACR,MAAM,EAAE,6CAA6C,QAAQ,GAAG;gBAChE,WAAW;gBACX,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,eAAe;aAChD;SACF,CAAC;IACJ,CAAC;IAED,OAAO;QACL,OAAO,EAAE,IAAI;QACb,QAAQ;QACR,MAAM;QACN,UAAU,EAAE,IAAA,8CAAoB,EAAC,MAAM,CAAC;QACxC,QAAQ,EAAE;YACR,MAAM,EAAE,6EAA6E;YACrF,WAAW;YACX,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,eAAe;SAChD;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generatedPatchPlanTypes.js","sourceRoot":"","sources":["../../src/patch-generation/generatedPatchPlanTypes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isIntentAllowed = isIntentAllowed;
|
|
4
|
+
const ALLOWED_INTENTS_BY_STRATEGY = {
|
|
5
|
+
blocked: [],
|
|
6
|
+
restricted: ["rename_symbol", "add_comment", "safe_replace"],
|
|
7
|
+
safe: ["rename_symbol", "update_import", "add_comment", "safe_replace"]
|
|
8
|
+
};
|
|
9
|
+
function isIntentAllowed(intent, strategy) {
|
|
10
|
+
if (intent === "unknown") {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
return ALLOWED_INTENTS_BY_STRATEGY[strategy].includes(intent);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=isIntentAllowed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isIntentAllowed.js","sourceRoot":"","sources":["../../src/patch-generation/isIntentAllowed.ts"],"names":[],"mappings":";;AAaA,0CASC;AAlBD,MAAM,2BAA2B,GAG7B;IACF,OAAO,EAAE,EAAE;IACX,UAAU,EAAE,CAAC,eAAe,EAAE,aAAa,EAAE,cAAc,CAAC;IAC5D,IAAI,EAAE,CAAC,eAAe,EAAE,eAAe,EAAE,aAAa,EAAE,cAAc,CAAC;CACxE,CAAC;AAEF,SAAgB,eAAe,CAC7B,MAAmB,EACnB,QAAiC;IAEjC,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,2BAA2B,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AAChE,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.renderGeneratedPatchPlan = renderGeneratedPatchPlan;
|
|
4
|
+
function renderOperation(operation) {
|
|
5
|
+
switch (operation.type) {
|
|
6
|
+
case "safe_replace":
|
|
7
|
+
return [
|
|
8
|
+
"- type: safe_replace",
|
|
9
|
+
` filePath: ${operation.filePath}`,
|
|
10
|
+
` find: ${operation.find}`,
|
|
11
|
+
` replaceWith: ${operation.replaceWith}`,
|
|
12
|
+
` matchMode: ${operation.matchMode}`
|
|
13
|
+
].join("\n");
|
|
14
|
+
case "rename_symbol":
|
|
15
|
+
return [
|
|
16
|
+
"- type: rename_symbol",
|
|
17
|
+
` filePath: ${operation.filePath}`,
|
|
18
|
+
` from: ${operation.from}`,
|
|
19
|
+
` to: ${operation.to}`
|
|
20
|
+
].join("\n");
|
|
21
|
+
case "update_import":
|
|
22
|
+
return [
|
|
23
|
+
"- type: update_import",
|
|
24
|
+
` filePath: ${operation.filePath}`,
|
|
25
|
+
` from: ${operation.from}`,
|
|
26
|
+
` to: ${operation.to}`
|
|
27
|
+
].join("\n");
|
|
28
|
+
case "add_comment":
|
|
29
|
+
return [
|
|
30
|
+
"- type: add_comment",
|
|
31
|
+
` filePath: ${operation.filePath}`,
|
|
32
|
+
` comment: ${operation.comment}`,
|
|
33
|
+
` target: ${operation.target}`
|
|
34
|
+
].join("\n");
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
function renderGeneratedPatchPlan(plan) {
|
|
38
|
+
const lines = [];
|
|
39
|
+
lines.push("=== GENERATED PATCH PLAN ===");
|
|
40
|
+
lines.push(`Intent: ${plan.intent}`);
|
|
41
|
+
lines.push(`Summary: ${plan.summary}`);
|
|
42
|
+
lines.push("");
|
|
43
|
+
if (plan.operations.length === 0) {
|
|
44
|
+
lines.push("Operations:");
|
|
45
|
+
lines.push("(none)");
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
lines.push("Operations:");
|
|
49
|
+
for (const operation of plan.operations) {
|
|
50
|
+
lines.push(renderOperation(operation));
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
if (plan.warnings.length > 0) {
|
|
54
|
+
lines.push("");
|
|
55
|
+
lines.push("Warnings:");
|
|
56
|
+
for (const warning of plan.warnings) {
|
|
57
|
+
lines.push(`- ${warning}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return lines.join("\n");
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=renderGeneratedPatchPlan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderGeneratedPatchPlan.js","sourceRoot":"","sources":["../../src/patch-generation/renderGeneratedPatchPlan.ts"],"names":[],"mappings":";;AA0CA,4DA2BC;AAhED,SAAS,eAAe,CAAC,SAAkC;IACzD,QAAQ,SAAS,CAAC,IAAI,EAAE,CAAC;QACvB,KAAK,cAAc;YACjB,OAAO;gBACL,sBAAsB;gBACtB,eAAe,SAAS,CAAC,QAAQ,EAAE;gBACnC,WAAW,SAAS,CAAC,IAAI,EAAE;gBAC3B,kBAAkB,SAAS,CAAC,WAAW,EAAE;gBACzC,gBAAgB,SAAS,CAAC,SAAS,EAAE;aACtC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEf,KAAK,eAAe;YAClB,OAAO;gBACL,uBAAuB;gBACvB,eAAe,SAAS,CAAC,QAAQ,EAAE;gBACnC,WAAW,SAAS,CAAC,IAAI,EAAE;gBAC3B,SAAS,SAAS,CAAC,EAAE,EAAE;aACxB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEf,KAAK,eAAe;YAClB,OAAO;gBACL,uBAAuB;gBACvB,eAAe,SAAS,CAAC,QAAQ,EAAE;gBACnC,WAAW,SAAS,CAAC,IAAI,EAAE;gBAC3B,SAAS,SAAS,CAAC,EAAE,EAAE;aACxB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEf,KAAK,aAAa;YAChB,OAAO;gBACL,qBAAqB;gBACrB,eAAe,SAAS,CAAC,QAAQ,EAAE;gBACnC,cAAc,SAAS,CAAC,OAAO,EAAE;gBACjC,aAAa,SAAS,CAAC,MAAM,EAAE;aAChC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjB,CAAC;AACH,CAAC;AAED,SAAgB,wBAAwB,CAAC,IAAwB;IAC/D,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,KAAK,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;IAC3C,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACrC,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACvC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC1B,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvB,CAAC;SAAM,CAAC;QACN,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC1B,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACxC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC7B,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACf,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACxB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpC,KAAK,CAAC,IAAI,CAAC,KAAK,OAAO,EAAE,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|