geo-ai-search-optimization 1.3.10 → 1.3.11
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 +8 -0
- package/package.json +1 -1
- package/src/cli-planning-delivery-commands.js +22 -34
- package/src/cli-shared.js +42 -0
package/README.md
CHANGED
|
@@ -909,6 +909,14 @@ geo-ai-search-optimization help
|
|
|
909
909
|
- `src/cli-agent-execution-commands.js`、`src/cli-flow-commands.js`、`src/cli-planning-delivery-commands.js` 现在统一复用这些 builder
|
|
910
910
|
- CLI 架构进一步接近“adapter registry + shared option builders + shared composition primitives”的模式
|
|
911
911
|
|
|
912
|
+
## New in 1.3.11
|
|
913
|
+
|
|
914
|
+
- 继续收敛原本仍较特殊的命令编排
|
|
915
|
+
- `src/cli-shared.js` 新增 `buildTaskOutputDirOptions / buildTaskFormatOutputDirOptions / createContentCommandHandler`
|
|
916
|
+
- `src/cli-planning-delivery-commands.js` 中的 `report` 已改成统一 content handler
|
|
917
|
+
- `export-pack / html-pack / publish-pack` 也开始复用共享 output-dir / task builder
|
|
918
|
+
- CLI 更接近统一的 command registry,而不是混合少数特例 handler
|
|
919
|
+
|
|
912
920
|
## New in 1.2.20
|
|
913
921
|
|
|
914
922
|
- 新增 `agent-continue`
|
package/package.json
CHANGED
|
@@ -19,11 +19,13 @@ import { createRoadmap, renderRoadmapMarkdown, writeRoadmapOutput } from "./road
|
|
|
19
19
|
import { createSharePack, renderSharePackMarkdown, writeSharePackOutput } from "./share-pack.js";
|
|
20
20
|
import {
|
|
21
21
|
buildFormatOptions,
|
|
22
|
+
buildTaskFormatOutputDirOptions,
|
|
23
|
+
buildTaskOutputDirOptions,
|
|
24
|
+
createContentCommandHandler,
|
|
22
25
|
buildTaskFormatOptions,
|
|
23
26
|
createArtifactCommandHandler,
|
|
24
27
|
createPackCommandHandler,
|
|
25
28
|
getFlagValue,
|
|
26
|
-
getRequiredInput,
|
|
27
29
|
parsePositiveInteger
|
|
28
30
|
} from "./cli-shared.js";
|
|
29
31
|
|
|
@@ -94,31 +96,21 @@ const handleExportPack = createPackCommandHandler({
|
|
|
94
96
|
commandName: "export-pack",
|
|
95
97
|
writePack: writeExportPack,
|
|
96
98
|
renderMarkdown: renderExportPackMarkdown,
|
|
97
|
-
getOptions:
|
|
98
|
-
format: getFlagValue(args, "--format"),
|
|
99
|
-
taskId: getFlagValue(args, "--task"),
|
|
100
|
-
outputDir: getFlagValue(args, "--out-dir")
|
|
101
|
-
})
|
|
99
|
+
getOptions: buildTaskFormatOutputDirOptions
|
|
102
100
|
});
|
|
103
101
|
|
|
104
102
|
const handleHtmlPack = createPackCommandHandler({
|
|
105
103
|
commandName: "html-pack",
|
|
106
104
|
writePack: writeHtmlPack,
|
|
107
105
|
renderMarkdown: renderHtmlPackMarkdown,
|
|
108
|
-
getOptions:
|
|
109
|
-
taskId: getFlagValue(args, "--task"),
|
|
110
|
-
outputDir: getFlagValue(args, "--out-dir")
|
|
111
|
-
})
|
|
106
|
+
getOptions: buildTaskOutputDirOptions
|
|
112
107
|
});
|
|
113
108
|
|
|
114
109
|
const handlePublishPack = createPackCommandHandler({
|
|
115
110
|
commandName: "publish-pack",
|
|
116
111
|
writePack: writePublishPack,
|
|
117
112
|
renderMarkdown: renderPublishPackMarkdown,
|
|
118
|
-
getOptions:
|
|
119
|
-
taskId: getFlagValue(args, "--task"),
|
|
120
|
-
outputDir: getFlagValue(args, "--out-dir")
|
|
121
|
-
})
|
|
113
|
+
getOptions: buildTaskOutputDirOptions
|
|
122
114
|
});
|
|
123
115
|
|
|
124
116
|
const handleExecSummary = createArtifactCommandHandler({
|
|
@@ -175,26 +167,22 @@ const handleRoadmap = createArtifactCommandHandler({
|
|
|
175
167
|
getOptions: buildFormatOptions
|
|
176
168
|
});
|
|
177
169
|
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
process.stdout.write(report.content);
|
|
197
|
-
}
|
|
170
|
+
const handleReport = createContentCommandHandler({
|
|
171
|
+
commandName: "report",
|
|
172
|
+
execute: async (input, args) => {
|
|
173
|
+
const maxFileSizeValue = getFlagValue(args, "--max-file-size");
|
|
174
|
+
const maxExamplesValue = getFlagValue(args, "--max-examples");
|
|
175
|
+
|
|
176
|
+
return generateReport(input, {
|
|
177
|
+
mode: getFlagValue(args, "--mode"),
|
|
178
|
+
format: getFlagValue(args, "--format"),
|
|
179
|
+
maxFileSize: maxFileSizeValue ? parsePositiveInteger(maxFileSizeValue, "--max-file-size") : undefined,
|
|
180
|
+
maxExamples: maxExamplesValue ? parsePositiveInteger(maxExamplesValue, "--max-examples") : undefined
|
|
181
|
+
});
|
|
182
|
+
},
|
|
183
|
+
getContent: (report) => report.content,
|
|
184
|
+
writeOutput: writeReportOutput
|
|
185
|
+
});
|
|
198
186
|
|
|
199
187
|
export const PLANNING_DELIVERY_COMMAND_HANDLERS = {
|
|
200
188
|
"agent-handoff": handleAgentHandoff,
|
package/src/cli-shared.js
CHANGED
|
@@ -57,6 +57,12 @@ export function buildTaskOptions(args) {
|
|
|
57
57
|
};
|
|
58
58
|
}
|
|
59
59
|
|
|
60
|
+
export function buildOutputDirOptions(args) {
|
|
61
|
+
return {
|
|
62
|
+
outputDir: getFlagValue(args, "--out-dir")
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
|
|
60
66
|
export function buildProgressOptions(args) {
|
|
61
67
|
return {
|
|
62
68
|
currentTaskId: getFlagValue(args, "--current"),
|
|
@@ -79,6 +85,20 @@ export function buildTaskFormatOptions(args) {
|
|
|
79
85
|
};
|
|
80
86
|
}
|
|
81
87
|
|
|
88
|
+
export function buildTaskOutputDirOptions(args) {
|
|
89
|
+
return {
|
|
90
|
+
...buildTaskOptions(args),
|
|
91
|
+
...buildOutputDirOptions(args)
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
export function buildTaskFormatOutputDirOptions(args) {
|
|
96
|
+
return {
|
|
97
|
+
...buildFormatOptions(args),
|
|
98
|
+
...buildTaskOutputDirOptions(args)
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
|
|
82
102
|
export function buildIntentTaskFormatOptions(args) {
|
|
83
103
|
return {
|
|
84
104
|
...buildIntentOptions(args),
|
|
@@ -202,3 +222,25 @@ export function createActionCommandHandler({
|
|
|
202
222
|
}
|
|
203
223
|
};
|
|
204
224
|
}
|
|
225
|
+
|
|
226
|
+
export function createContentCommandHandler({
|
|
227
|
+
commandName,
|
|
228
|
+
execute,
|
|
229
|
+
getContent,
|
|
230
|
+
writeOutput
|
|
231
|
+
}) {
|
|
232
|
+
return async function contentCommandHandler(args) {
|
|
233
|
+
const input = getRequiredInput(args, commandName);
|
|
234
|
+
const result = await execute(input, args);
|
|
235
|
+
const content = getContent(result);
|
|
236
|
+
const outputPath = getFlagValue(args, "--out");
|
|
237
|
+
|
|
238
|
+
if (outputPath) {
|
|
239
|
+
const resolvedOutputPath = await writeOutput(outputPath, content);
|
|
240
|
+
process.stdout.write(`已保存${commandName === "report" ? "报告" : ` ${commandName} 结果`}:${resolvedOutputPath}\n`);
|
|
241
|
+
return;
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
process.stdout.write(content);
|
|
245
|
+
};
|
|
246
|
+
}
|