@sourcegraph/amp 0.0.1748361686-ga6cbdd → 0.0.1748377081-gc02396
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/dist/amp.js +3 -3
- package/dist/{client-DfrJv231.js → client-D37xwk4h.js} +2 -2
- package/dist/{client-DfrJv231.js.map → client-D37xwk4h.js.map} +1 -1
- package/dist/{color-Bf2jGwiV.js → color-BV9wbewg.js} +24 -20
- package/dist/color-BV9wbewg.js.map +1 -0
- package/dist/create_file.node-D2LDnTZ6.js +24 -0
- package/dist/create_file.node-D2LDnTZ6.js.map +1 -0
- package/dist/{edit_file.node-D2Wa6RXM.js → edit_file.node-Ccrf_Tyh.js} +3 -3
- package/dist/{edit_file.node-D2Wa6RXM.js.map → edit_file.node-Ccrf_Tyh.js.map} +1 -1
- package/dist/{executable-Cf6tmsfm.js → executable-DndKF3B_.js} +2 -2
- package/dist/{executable-Cf6tmsfm.js.map → executable-DndKF3B_.js.map} +1 -1
- package/dist/{files-U5BBkj-L.js → files-CApLN3XI.js} +2 -2
- package/dist/{files-U5BBkj-L.js.map → files-CApLN3XI.js.map} +1 -1
- package/dist/{glob.node-Cfv1JwiF.js → glob.node-C_0Pojo_.js} +3 -3
- package/dist/{glob.node-Cfv1JwiF.js.map → glob.node-C_0Pojo_.js.map} +1 -1
- package/dist/{list_directory.node-Dmx2XM_W.js → list_directory.node-CChuHPoL.js} +2 -2
- package/dist/{list_directory.node-Dmx2XM_W.js.map → list_directory.node-CChuHPoL.js.map} +1 -1
- package/dist/{load-profile-Bu7wgoOq.js → load-profile-CBXx5Izf.js} +2 -2
- package/dist/{load-profile-Bu7wgoOq.js.map → load-profile-CBXx5Izf.js.map} +1 -1
- package/dist/{main-CmK9yaC9.js → main-BznCgbIr.js} +841 -826
- package/dist/{main-CmK9yaC9.js.map → main-BznCgbIr.js.map} +1 -1
- package/dist/{node-DSPACSAV.js → node-B8I2GAD6.js} +3 -3
- package/dist/{node-DSPACSAV.js.map → node-B8I2GAD6.js.map} +1 -1
- package/dist/{node-7PIWGuuc.js → node-BGD834Zv.js} +4 -4
- package/dist/node-BGD834Zv.js.map +1 -0
- package/dist/{node-DUQOAXRE.js → node-BcU66Cp7.js} +3 -3
- package/dist/{node-DUQOAXRE.js.map → node-BcU66Cp7.js.map} +1 -1
- package/dist/{node-W217cnDV.js → node-DPzW5-VB.js} +3 -3
- package/dist/{node-W217cnDV.js.map → node-DPzW5-VB.js.map} +1 -1
- package/dist/{node-C1YHImbI.js → node-DgFnFiEl.js} +3 -3
- package/dist/{node-C1YHImbI.js.map → node-DgFnFiEl.js.map} +1 -1
- package/dist/{node-Bt-aqwyP.js → node-gL35nPzg.js} +2 -2
- package/dist/{node-Bt-aqwyP.js.map → node-gL35nPzg.js.map} +1 -1
- package/dist/{read_file.node-2sVFQX4N.js → read_file.node-FBiGQRUp.js} +2 -2
- package/dist/{read_file.node-2sVFQX4N.js.map → read_file.node-FBiGQRUp.js.map} +1 -1
- package/dist/{stdio-CNkqPrBz.js → stdio-pu7dwbvU.js} +3 -3
- package/dist/{stdio-CNkqPrBz.js.map → stdio-pu7dwbvU.js.map} +1 -1
- package/dist/storybook.js +1 -1
- package/dist/{undo_edit.node-CQG6mtZj.js → undo_edit.node-NCKppvcB.js} +2 -2
- package/dist/{undo_edit.node-CQG6mtZj.js.map → undo_edit.node-NCKppvcB.js.map} +1 -1
- package/package.json +1 -1
- package/dist/color-Bf2jGwiV.js.map +0 -1
- package/dist/create_file.node-BnMPGgD2.js +0 -22
- package/dist/create_file.node-BnMPGgD2.js.map +0 -1
- package/dist/node-7PIWGuuc.js.map +0 -1
@@ -1,22 +0,0 @@
|
|
1
|
-
#!/usr/bin/env node
|
2
|
-
import p from "node:path";
|
3
|
-
import { p as f, aV as u, a7 as d } from "./color-Bf2jGwiV.js";
|
4
|
-
const w = ({ args: t }, { dir: n, dirs: i, trackFileChange: c, filesystem: o }) => f(async (e) => {
|
5
|
-
if (u(n), typeof t.content != "string")
|
6
|
-
throw new Error("create_file: content must be specified");
|
7
|
-
e.throwIfAborted();
|
8
|
-
const a = await d(o, i, t.path, e), s = p.dirname(a);
|
9
|
-
await o.mkdirp(s, e);
|
10
|
-
let r = t.content;
|
11
|
-
return r.startsWith("\\") && (r = r.slice(1)), await c(a, async (l) => {
|
12
|
-
await o.writeFile(l, r, e);
|
13
|
-
}), {
|
14
|
-
status: "done",
|
15
|
-
result: `Successfully created file ${t.path}`,
|
16
|
-
files: [t.path]
|
17
|
-
};
|
18
|
-
});
|
19
|
-
export {
|
20
|
-
w as nodeCreateFileTool
|
21
|
-
};
|
22
|
-
//# sourceMappingURL=create_file.node-BnMPGgD2.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"create_file.node-BnMPGgD2.js","sources":["../../core/src/tools/builtin/filesystem/create_file.node.ts"],"sourcesContent":["import { promiseFactoryToObservable } from '@sourcegraph/observable'\nimport path from 'path'\nimport { checkDirURIIsFile } from '../node-helpers'\nimport type { createFileToolReg } from './create_file.common'\nimport { resolveArgumentPath } from './read_file.util'\n\nexport const nodeCreateFileTool: NonNullable<typeof createFileToolReg.fn> = (\n\t{ args },\n\t{ dir, dirs, trackFileChange, filesystem },\n) => {\n\treturn promiseFactoryToObservable(async (signal) => {\n\t\tcheckDirURIIsFile(dir)\n\t\tif (typeof args.content !== 'string') {\n\t\t\tthrow new Error('create_file: content must be specified')\n\t\t}\n\n\t\tsignal.throwIfAborted()\n\n\t\tconst fullPath = await resolveArgumentPath(filesystem, dirs, args.path, signal)\n\t\tconst dirname = path.dirname(fullPath)\n\t\tawait filesystem.mkdirp(dirname, signal)\n\n\t\tlet content = args.content\n\t\t// HACK: Gemini has a bug where it will sometimes add a leading backslash to\n\t\t// the beginning of its tool args. I've reported the bug, but it still\n\t\t// happens pretty regularly. For now, this attempts to get things working\n\t\t// by trimming any leading backslash\n\t\tif (content.startsWith('\\\\')) {\n\t\t\tcontent = content.slice(1)\n\t\t}\n\n\t\tawait trackFileChange(fullPath, async (path) => {\n\t\t\tawait filesystem.writeFile(path, content, signal)\n\t\t})\n\t\treturn {\n\t\t\tstatus: 'done',\n\t\t\tresult: `Successfully created file ${args.path}`,\n\t\t\tfiles: [args.path],\n\t\t}\n\t})\n}\n"],"names":["nodeCreateFileTool","args","dir","dirs","trackFileChange","filesystem","promiseFactoryToObservable","signal","checkDirURIIsFile","fullPath","resolveArgumentPath","dirname","path","content"],"mappings":";;;AAMa,MAAAA,IAA+D,CAC3E,EAAE,MAAAC,KACF,EAAE,KAAAC,GAAK,MAAAC,GAAM,iBAAAC,GAAiB,YAAAC,QAEvBC,EAA2B,OAAOC,MAAW;AAE/C,MADJC,EAAkBN,CAAG,GACjB,OAAOD,EAAK,WAAY;AACrB,UAAA,IAAI,MAAM,wCAAwC;AAGzD,EAAAM,EAAO,eAAe;AAEtB,QAAME,IAAW,MAAMC,EAAoBL,GAAYF,GAAMF,EAAK,MAAMM,CAAM,GACxEI,IAAUC,EAAK,QAAQH,CAAQ;AAC/B,QAAAJ,EAAW,OAAOM,GAASJ,CAAM;AAEvC,MAAIM,IAAUZ,EAAK;AAKf,SAAAY,EAAQ,WAAW,IAAI,MAChBA,IAAAA,EAAQ,MAAM,CAAC,IAGpB,MAAAT,EAAgBK,GAAU,OAAOG,MAAS;AAC/C,UAAMP,EAAW,UAAUO,GAAMC,GAASN,CAAM;AAAA,EAAA,CAChD,GACM;AAAA,IACN,QAAQ;AAAA,IACR,QAAQ,6BAA6BN,EAAK,IAAI;AAAA,IAC9C,OAAO,CAACA,EAAK,IAAI;AAAA,EAClB;AAAA,CACA;"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"node-7PIWGuuc.js","sources":["../../core/src/platform/fs/backups.node.ts","../../core/src/platform/fs/node.ts"],"sourcesContent":["import { homedir } from 'node:os'\nimport { join } from 'node:path'\n\nexport const BACKUP_DIR = join(homedir(), '.amp', 'file-changes')\n","import { execFile } from 'node:child_process'\nimport * as fs from 'node:fs'\nimport * as path from 'node:path'\nimport { promisify } from 'node:util'\nimport logger from '../../common/logger'\nimport { type FileChangeRecord } from '../../threads/file-tracking/common'\nimport type { ThreadID } from '../../threads/thread'\nimport { BACKUP_DIR } from './backups.node'\nimport { FileNotExistError, type FileSystem } from './fs'\n\nconst execFileAsync = promisify(execFile)\n\nexport function nodeFileSystem(threadID: ThreadID): FileSystem {\n\tconst backupDir = path.join(BACKUP_DIR, threadID)\n\treturn {\n\t\trelativePath: (a: string, b: string) => path.relative(a, b),\n\t\tjoinPath: (...paths: string[]) => path.join(...paths),\n\n\t\treadFile: async (path: string, signal?: AbortSignal) => {\n\t\t\ttry {\n\t\t\t\treturn await fs.promises.readFile(path, { encoding: 'utf8', signal })\n\t\t\t} catch (error) {\n\t\t\t\tif (isNodeFSNotExistError(error)) {\n\t\t\t\t\tthrow new FileNotExistError(path)\n\t\t\t\t}\n\t\t\t\tthrow error\n\t\t\t}\n\t\t},\n\t\treadBinaryFile: async (path: string, signal?: AbortSignal) => {\n\t\t\ttry {\n\t\t\t\t// Read as Buffer without encoding\n\t\t\t\treturn await fs.promises.readFile(path, { signal })\n\t\t\t} catch (error) {\n\t\t\t\tif (isNodeFSNotExistError(error)) {\n\t\t\t\t\tthrow new FileNotExistError(path)\n\t\t\t\t}\n\t\t\t\tthrow error\n\t\t\t}\n\t\t},\n\t\tgetMtime: async (path: string, signal?: AbortSignal) => {\n\t\t\ttry {\n\t\t\t\t// Node.js stat doesn't support AbortSignal directly\n\t\t\t\tconst stats = await fs.promises.stat(path)\n\t\t\t\treturn stats.mtimeMs\n\t\t\t} catch (error) {\n\t\t\t\tif (isNodeFSNotExistError(error)) {\n\t\t\t\t\tthrow new FileNotExistError(path)\n\t\t\t\t}\n\t\t\t\tthrow error\n\t\t\t}\n\t\t},\n\t\tstat: async (path: string) => {\n\t\t\ttry {\n\t\t\t\tconst stats = await fs.promises.stat(path)\n\t\t\t\treturn {\n\t\t\t\t\tsize: stats.size,\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tif (isNodeFSNotExistError(error)) {\n\t\t\t\t\tthrow new FileNotExistError(path)\n\t\t\t\t}\n\t\t\t\tthrow error\n\t\t\t}\n\t\t},\n\t\twriteFile: async (path, content, signal) => {\n\t\t\tawait fs.promises.writeFile(path, content, { encoding: 'utf-8', signal })\n\t\t},\n\t\tdeleteFile: async (path, signal?: AbortSignal) => {\n\t\t\ttry {\n\t\t\t\tawait fs.promises.unlink(path)\n\t\t\t} catch (error) {\n\t\t\t\tif (isNodeFSNotExistError(error)) {\n\t\t\t\t\tthrow new FileNotExistError(path)\n\t\t\t\t}\n\t\t\t\tthrow error\n\t\t\t}\n\t\t},\n\t\tmkdirp: async (path) => {\n\t\t\tawait fs.promises.mkdir(path, { recursive: true })\n\t\t},\n\t\tstoreFileChange: async (backupFileName: string, fileChange: FileChangeRecord) => {\n\t\t\tconst backupPath = path.join(backupDir, backupFileName)\n\t\t\tawait fs.promises.writeFile(backupPath, JSON.stringify(fileChange, null, 2), 'utf8')\n\t\t},\n\t\tlistBackupFiles: async () => {\n\t\t\ttry {\n\t\t\t\t// Ensure backup directory exists\n\t\t\t\tif (\n\t\t\t\t\t!(await fs.promises\n\t\t\t\t\t\t.stat(backupDir)\n\t\t\t\t\t\t.then((s) => s.isDirectory())\n\t\t\t\t\t\t.catch(() => false))\n\t\t\t\t) {\n\t\t\t\t\tawait fs.promises.mkdir(backupDir, { recursive: true })\n\t\t\t\t\treturn []\n\t\t\t\t}\n\t\t\t\treturn await fs.promises.readdir(backupDir)\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error('Error listing backup files:', error)\n\t\t\t\treturn []\n\t\t\t}\n\t\t},\n\t\tloadFileChange: async (backupFileName: string) => {\n\t\t\ttry {\n\t\t\t\tconst backupPath = path.join(backupDir, backupFileName)\n\t\t\t\tconst content = await fs.promises.readFile(backupPath, 'utf8')\n\t\t\t\treturn JSON.parse(content) as FileChangeRecord\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(`Error loading backup file ${backupFileName}:`, error)\n\t\t\t\treturn null\n\t\t\t}\n\t\t},\n\t\tcleanupBackupFiles: async () => {\n\t\t\ttry {\n\t\t\t\tif (\n\t\t\t\t\tawait fs.promises\n\t\t\t\t\t\t.stat(backupDir)\n\t\t\t\t\t\t.then((s) => s.isDirectory())\n\t\t\t\t\t\t.catch(() => false)\n\t\t\t\t) {\n\t\t\t\t\tawait fs.promises.rm(backupDir, { recursive: true, force: true })\n\t\t\t\t\tlogger.debug(`Cleaned up backup directory: ${backupDir}`)\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(`Error cleaning up backup files in ${backupDir}:`, error)\n\t\t\t}\n\t\t},\n\t\tlistFiles: async (dir: string) => listFilesGit(dir),\n\t\texclusiveWriter: false,\n\t}\n}\n\nfunction isNodeFSNotExistError(error: unknown): boolean {\n\treturn (\n\t\terror !== null &&\n\t\ttypeof error === 'object' &&\n\t\t'code' in error &&\n\t\t(error as { code: string }).code === 'ENOENT'\n\t)\n}\n\n/**\n * Lists files in a directory using git ls-files.\n * Exported for reuse by other filesystem implementations.\n */\nexport async function listFilesGit(dir: string): Promise<string[]> {\n\ttry {\n\t\tconst { stdout: trackedFiles } = await execFileAsync('git', ['ls-files'], {\n\t\t\tcwd: dir,\n\t\t})\n\n\t\tconst { stdout: untrackedFiles } = await execFileAsync(\n\t\t\t'git',\n\t\t\t['ls-files', '--others', '--exclude-standard'],\n\t\t\t{\n\t\t\t\tcwd: dir,\n\t\t\t},\n\t\t)\n\n\t\treturn [...trackedFiles.split('\\n'), ...untrackedFiles.split('\\n')].filter(Boolean)\n\t} catch {\n\t\treturn []\n\t}\n}\n"],"names":["BACKUP_DIR","join","homedir","execFileAsync","promisify","execFile","nodeFileSystem","threadID","backupDir","path","a","b","paths","signal","fs","error","isNodeFSNotExistError","FileNotExistError","content","backupFileName","fileChange","backupPath","s","logger","dir","listFilesGit","trackedFiles","untrackedFiles"],"mappings":"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"}
|