227 lines
18 KiB
JavaScript
227 lines
18 KiB
JavaScript
"use strict";
|
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
}
|
|
Object.defineProperty(o, k2, desc);
|
|
}) : (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
o[k2] = m[k];
|
|
}));
|
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
}) : function(o, v) {
|
|
o["default"] = v;
|
|
});
|
|
var __importStar = (this && this.__importStar) || (function () {
|
|
var ownKeys = function(o) {
|
|
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
var ar = [];
|
|
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
return ar;
|
|
};
|
|
return ownKeys(o);
|
|
};
|
|
return function (mod) {
|
|
if (mod && mod.__esModule) return mod;
|
|
var result = {};
|
|
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
__setModuleDefault(result, mod);
|
|
return result;
|
|
};
|
|
})();
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.run = exports.processRun = void 0;
|
|
const path = __importStar(require("path"));
|
|
const glob_1 = require("glob");
|
|
const dir_1 = require("@plastichub/fs/dir");
|
|
const exists_1 = require("@plastichub/fs/exists");
|
|
const write_1 = require("@plastichub/fs/write");
|
|
const read_1 = require("@plastichub/fs/read");
|
|
const osr_commons_1 = require("@plastichub/osr-commons");
|
|
const primitives_1 = require("@plastichub/core/primitives");
|
|
const __1 = require("../");
|
|
const client_1 = require("../client");
|
|
const zod_schema_1 = require("../zod_schema");
|
|
const source_1 = require("../source");
|
|
const array_1 = require("../utils/array");
|
|
const collector_1 = require("../collector");
|
|
const profile_1 = require("../profile");
|
|
const tools_1 = require("../tools");
|
|
const prompt_1 = require("../prompt");
|
|
const variables_1 = require("../variables");
|
|
const zod_schema_2 = require("../zod_schema");
|
|
const run_completion_1 = require("./run-completion");
|
|
const run_tools_1 = require("./run-tools");
|
|
const run_assistant_1 = require("./run-assistant");
|
|
const models_1 = require("../models");
|
|
const processRun = async (opts) => {
|
|
let options = null;
|
|
const target = path.resolve(opts.output || opts.path);
|
|
if (!(0, exists_1.sync)(target)) {
|
|
(0, dir_1.sync)(target);
|
|
}
|
|
opts.disable = (0, array_1.flatten)(opts.disable);
|
|
opts.disableTools = (0, array_1.flatten)(opts.disableTools);
|
|
opts.include = (0, array_1.flatten)(opts.include);
|
|
opts.variables = await (0, profile_1.load)(opts);
|
|
try {
|
|
options = (0, zod_schema_1.OptionsSchema)().parse(opts);
|
|
}
|
|
catch (error) {
|
|
__1.logger.error('Failed to parse options:', error.message, error.issues);
|
|
return;
|
|
}
|
|
const client = (0, client_1.createClient)(options);
|
|
options.variables = { ...options.variables, ...(0, variables_1.variables)(options) };
|
|
if (!client) {
|
|
__1.logger.error('Failed to create client');
|
|
return;
|
|
}
|
|
options.client = client;
|
|
options.collector = (0, collector_1.collector)(options, client);
|
|
let messages = [];
|
|
messages.push(await (0, prompt_1.prompt)(opts));
|
|
messages.push(await (0, prompt_1.preferences)(opts));
|
|
let files = await (0, source_1.get)(path.resolve(options.path), options.include) || [];
|
|
files = files.map(f => { return { ...f, role: 'user' }; });
|
|
messages = [...messages, ...files];
|
|
const params = {
|
|
model: options.model,
|
|
messages,
|
|
tools: []
|
|
};
|
|
if (options.mode === zod_schema_2.ChatCompletionType.TOOLS || options.mode === zod_schema_2.ChatCompletionType.ASSISTANT) {
|
|
params.tools = await (0, tools_1.load)(options);
|
|
params.tool_choice = 'auto';
|
|
params.parallel_tool_calls = false;
|
|
}
|
|
const logDir = path.resolve((0, osr_commons_1.resolve)(opts.logs));
|
|
const paramsPath = path.join(logDir, 'params.json');
|
|
(0, write_1.sync)(paramsPath, JSON.stringify({ ...params }, null, 2));
|
|
__1.logger.debug(`Read ${files.length} files from project ${path.resolve(options.path)} with ${options.include}`, files.map(f => f.path), options.variables, params.tools.map(t => `${t.function.name} : ${t.function.description}`));
|
|
let ret = null;
|
|
try {
|
|
switch (options.mode) {
|
|
case zod_schema_2.ChatCompletionType.COMPLETION:
|
|
ret = await (0, run_completion_1.runCompletion)(client, params, options);
|
|
break;
|
|
case zod_schema_2.ChatCompletionType.TOOLS:
|
|
ret = await (0, run_tools_1.runTools)(client, params, options);
|
|
break;
|
|
case zod_schema_2.ChatCompletionType.ASSISTANT:
|
|
ret = await (0, run_assistant_1.runAssistant)(client, params, options);
|
|
break;
|
|
default:
|
|
throw new Error(`Unsupported mode: ${options.mode}`);
|
|
}
|
|
}
|
|
catch (e) {
|
|
__1.logger.error(`Error running ${options.mode} mode: ${e.message}`);
|
|
}
|
|
opts.variables['LAST'] = ret;
|
|
return ret;
|
|
};
|
|
exports.processRun = processRun;
|
|
/**
|
|
* Extract file paths (Windows or POSIX style) from a single string,
|
|
* preserving any spaces within the paths. Needed for Salamand File Manager selections (eg: kbot "summarize, as json" -i "$(ListOfSelectedFullNames)")
|
|
* - For Windows, it looks for patterns like "C:\" (any drive letter).
|
|
* - For POSIX, it looks for a leading slash "/".
|
|
*
|
|
* Returns an array of path strings. If no matches are found, returns [].
|
|
*
|
|
*/
|
|
function extractPaths(input) {
|
|
if ((0, exists_1.sync)(path.resolve((0, osr_commons_1.resolve)(input)))) {
|
|
return [input];
|
|
}
|
|
// Matches either a Windows drive pattern like "C:\" or a forward slash "/".
|
|
// Parentheses group with `|` to match either part correctly.
|
|
const pathStartRegex = /([A-Za-z]:\\)|\//g;
|
|
const matchIndices = [];
|
|
let match;
|
|
// Collect the start index of each path
|
|
while ((match = pathStartRegex.exec(input)) !== null) {
|
|
matchIndices.push(match.index);
|
|
}
|
|
// If none found, return empty
|
|
if (!matchIndices.length) {
|
|
return [];
|
|
}
|
|
// Slice from each index to just before the next
|
|
const paths = [];
|
|
for (let i = 0; i < matchIndices.length; i++) {
|
|
const start = matchIndices[i];
|
|
const end = i < matchIndices.length - 1 ? matchIndices[i + 1] : input.length;
|
|
const path = input.substring(start, end).trim();
|
|
if (path) {
|
|
paths.push(path);
|
|
}
|
|
}
|
|
return paths;
|
|
}
|
|
function flattenArrays(arrays) {
|
|
return arrays.reduce((accumulator, current) => {
|
|
return accumulator.concat(current);
|
|
}, []);
|
|
}
|
|
const run = async (opts) => {
|
|
const ret = [];
|
|
if (opts.include) {
|
|
if ((0, primitives_1.isString)(opts.include)) {
|
|
opts.include = [opts.include];
|
|
}
|
|
if ((0, primitives_1.isArray)(opts.include)) {
|
|
opts.include = flattenArrays(opts.include.map(extractPaths));
|
|
}
|
|
opts.include = Array.from(new Set(opts.include));
|
|
}
|
|
if (opts.each) {
|
|
let items = [];
|
|
if ((0, primitives_1.isArray)(opts.each)) {
|
|
items = opts.each;
|
|
}
|
|
else if ((0, exists_1.sync)(opts.each) && (0, osr_commons_1.isFile)(opts.each) && path.parse(opts.each).ext === '.json') {
|
|
items = (0, read_1.sync)(opts.each, 'json') || [];
|
|
}
|
|
else if ((0, glob_1.hasMagic)(opts.each)) {
|
|
const info = (0, osr_commons_1.pathInfoEx)((0, osr_commons_1.forward_slash)(path.resolve((0, osr_commons_1.resolve)(opts.each))));
|
|
items = info.FILES;
|
|
}
|
|
else if ((0, osr_commons_1.isFile)(opts.each) && (0, exists_1.sync)(opts.each)) {
|
|
items = [opts.each];
|
|
}
|
|
else if ((0, primitives_1.isString)(opts.each)) {
|
|
items = opts.each.split(',');
|
|
}
|
|
if (items.length === 0) {
|
|
__1.logger.warn(`No files matching pattern ${opts.each} found in ${opts.path}`);
|
|
return ret;
|
|
}
|
|
__1.logger.info(`Processing ${items.length} items matching pattern ${opts.each}...`);
|
|
const _models = (0, models_1.all)();
|
|
for (const item of items) {
|
|
const itemOpts = {
|
|
...opts,
|
|
ITEM: item,
|
|
variables: { ITEM: item }
|
|
};
|
|
//override model if item is a model id
|
|
const model = _models.find(m => m.id === item);
|
|
if (model) {
|
|
itemOpts.model = item;
|
|
}
|
|
itemOpts.include = [...opts.include, ...[(0, osr_commons_1.forward_slash)(item)]];
|
|
ret.push(await (0, exports.processRun)(itemOpts));
|
|
}
|
|
}
|
|
else {
|
|
ret.push(await (0, exports.processRun)(opts));
|
|
}
|
|
return ret;
|
|
};
|
|
exports.run = run;
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run.js","sourceRoot":"","sources":["../src/commands/run.ts"],"names":[],"mappings":"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"}
|