πŸ“„ File detail

components/FileEditToolDiff.tsx

🧩 .tsxπŸ“ 181 linesπŸ’Ύ 21,900 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes FileEditToolDiff β€” mainly types, interfaces, or factory objects. Dependencies touch React UI and text diffing. It composes internal code from hooks, ink, tools, utils, and StructuredDiffList (relative imports).

Generated from folder role, exports, dependency roots, and inline comments β€” not hand-reviewed for every path.

🧠 Inline summary

import { c as _c } from "react/compiler-runtime"; import type { StructuredPatchHunk } from 'diff'; import * as React from 'react'; import { Suspense, use, useState } from 'react'; import { useTerminalSize } from '../hooks/useTerminalSize.js';

πŸ“€ Exports (heuristic)

  • FileEditToolDiff

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react
  • diff

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import type { StructuredPatchHunk } from 'diff';
import * as React from 'react';
import { Suspense, use, useState } from 'react';
import { useTerminalSize } from '../hooks/useTerminalSize.js';
import { Box, Text } from '../ink.js';
import type { FileEdit } from '../tools/FileEditTool/types.js';
import { findActualString, preserveQuoteStyle } from '../tools/FileEditTool/utils.js';
import { adjustHunkLineNumbers, CONTEXT_LINES, getPatchForDisplay } from '../utils/diff.js';
import { logError } from '../utils/log.js';
import { CHUNK_SIZE, openForScan, readCapped, scanForContext } from '../utils/readEditContext.js';
import { firstLineOf } from '../utils/stringUtils.js';
import { StructuredDiffList } from './StructuredDiffList.js';
type Props = {
  file_path: string;
  edits: FileEdit[];
};
type DiffData = {
  patch: StructuredPatchHunk[];
  firstLine: string | null;
  fileContent: string | undefined;
};
export function FileEditToolDiff(props) {
  const $ = _c(7);
  let t0;
  if ($[0] !== props.edits || $[1] !== props.file_path) {
    t0 = () => loadDiffData(props.file_path, props.edits);
    $[0] = props.edits;
    $[1] = props.file_path;
    $[2] = t0;
  } else {
    t0 = $[2];
  }
  const [dataPromise] = useState(t0);
  let t1;
  if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
    t1 = <DiffFrame placeholder={true} />;
    $[3] = t1;
  } else {
    t1 = $[3];
  }
  let t2;
  if ($[4] !== dataPromise || $[5] !== props.file_path) {
    t2 = <Suspense fallback={t1}><DiffBody promise={dataPromise} file_path={props.file_path} /></Suspense>;
    $[4] = dataPromise;
    $[5] = props.file_path;
    $[6] = t2;
  } else {
    t2 = $[6];
  }
  return t2;
}
function DiffBody(t0) {
  const $ = _c(6);
  const {
    promise,
    file_path
  } = t0;
  const {
    patch,
    firstLine,
    fileContent
  } = use(promise);
  const {
    columns
  } = useTerminalSize();
  let t1;
  if ($[0] !== columns || $[1] !== fileContent || $[2] !== file_path || $[3] !== firstLine || $[4] !== patch) {
    t1 = <DiffFrame><StructuredDiffList hunks={patch} dim={false} width={columns} filePath={file_path} firstLine={firstLine} fileContent={fileContent} /></DiffFrame>;
    $[0] = columns;
    $[1] = fileContent;
    $[2] = file_path;
    $[3] = firstLine;
    $[4] = patch;
    $[5] = t1;
  } else {
    t1 = $[5];
  }
  return t1;
}
function DiffFrame(t0) {
  const $ = _c(5);
  const {
    children,
    placeholder
  } = t0;
  let t1;
  if ($[0] !== children || $[1] !== placeholder) {
    t1 = placeholder ? <Text dimColor={true}>…</Text> : children;
    $[0] = children;
    $[1] = placeholder;
    $[2] = t1;
  } else {
    t1 = $[2];
  }
  let t2;
  if ($[3] !== t1) {
    t2 = <Box flexDirection="column"><Box borderColor="subtle" borderStyle="dashed" flexDirection="column" borderLeft={false} borderRight={false}>{t1}</Box></Box>;
    $[3] = t1;
    $[4] = t2;
  } else {
    t2 = $[4];
  }
  return t2;
}
async function loadDiffData(file_path: string, edits: FileEdit[]): Promise<DiffData> {
  const valid = edits.filter(e => e.old_string != null && e.new_string != null);
  const single = valid.length === 1 ? valid[0]! : undefined;

  // SedEditPermissionRequest passes the entire file as old_string. Scanning for
  // a needle β‰₯ CHUNK_SIZE allocates O(needle) for the overlap buffer β€” skip the
  // file read entirely and diff the inputs we already have.
  if (single && single.old_string.length >= CHUNK_SIZE) {
    return diffToolInputsOnly(file_path, [single]);
  }
  try {
    const handle = await openForScan(file_path);
    if (handle === null) return diffToolInputsOnly(file_path, valid);
    try {
      // Multi-edit and empty old_string genuinely need full-file for sequential
      // replacements β€” structuredPatch needs before/after strings. replace_all
      // routes through the chunked path below (shows first-occurrence window;
      // matches within the slice still replace via edit.replace_all).
      if (!single || single.old_string === '') {
        const file = await readCapped(handle);
        if (file === null) return diffToolInputsOnly(file_path, valid);
        const normalized = valid.map(e => normalizeEdit(file, e));
        return {
          patch: getPatchForDisplay({
            filePath: file_path,
            fileContents: file,
            edits: normalized
          }),
          firstLine: firstLineOf(file),
          fileContent: file
        };
      }
      const ctx = await scanForContext(handle, single.old_string, CONTEXT_LINES);
      if (ctx.truncated || ctx.content === '') {
        return diffToolInputsOnly(file_path, [single]);
      }
      const normalized = normalizeEdit(ctx.content, single);
      const hunks = getPatchForDisplay({
        filePath: file_path,
        fileContents: ctx.content,
        edits: [normalized]
      });
      return {
        patch: adjustHunkLineNumbers(hunks, ctx.lineOffset - 1),
        firstLine: ctx.lineOffset === 1 ? firstLineOf(ctx.content) : null,
        fileContent: ctx.content
      };
    } finally {
      await handle.close();
    }
  } catch (e) {
    logError(e as Error);
    return diffToolInputsOnly(file_path, valid);
  }
}
function diffToolInputsOnly(filePath: string, edits: FileEdit[]): DiffData {
  return {
    patch: edits.flatMap(e => getPatchForDisplay({
      filePath,
      fileContents: e.old_string,
      edits: [e]
    })),
    firstLine: null,
    fileContent: undefined
  };
}
function normalizeEdit(fileContent: string, edit: FileEdit): FileEdit {
  const actualOld = findActualString(fileContent, edit.old_string) || edit.old_string;
  const actualNew = preserveQuoteStyle(edit.old_string, actualOld, edit.new_string);
  return {
    ...edit,
    old_string: actualOld,
    new_string: actualNew
  };
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["StructuredPatchHunk","React","Suspense","use","useState","useTerminalSize","Box","Text","FileEdit","findActualString","preserveQuoteStyle","adjustHunkLineNumbers","CONTEXT_LINES","getPatchForDisplay","logError","CHUNK_SIZE","openForScan","readCapped","scanForContext","firstLineOf","StructuredDiffList","Props","file_path","edits","DiffData","patch","firstLine","fileContent","FileEditToolDiff","props","$","_c","t0","loadDiffData","dataPromise","t1","Symbol","for","t2","DiffBody","promise","columns","DiffFrame","children","placeholder","Promise","valid","filter","e","old_string","new_string","single","length","undefined","diffToolInputsOnly","handle","file","normalized","map","normalizeEdit","filePath","fileContents","ctx","truncated","content","hunks","lineOffset","close","Error","flatMap","edit","actualOld","actualNew"],"sources":["FileEditToolDiff.tsx"],"sourcesContent":["import type { StructuredPatchHunk } from 'diff'\nimport * as React from 'react'\nimport { Suspense, use, useState } from 'react'\nimport { useTerminalSize } from '../hooks/useTerminalSize.js'\nimport { Box, Text } from '../ink.js'\nimport type { FileEdit } from '../tools/FileEditTool/types.js'\nimport {\n  findActualString,\n  preserveQuoteStyle,\n} from '../tools/FileEditTool/utils.js'\nimport {\n  adjustHunkLineNumbers,\n  CONTEXT_LINES,\n  getPatchForDisplay,\n} from '../utils/diff.js'\nimport { logError } from '../utils/log.js'\nimport {\n  CHUNK_SIZE,\n  openForScan,\n  readCapped,\n  scanForContext,\n} from '../utils/readEditContext.js'\nimport { firstLineOf } from '../utils/stringUtils.js'\nimport { StructuredDiffList } from './StructuredDiffList.js'\n\ntype Props = {\n  file_path: string\n  edits: FileEdit[]\n}\n\ntype DiffData = {\n  patch: StructuredPatchHunk[]\n  firstLine: string | null\n  fileContent: string | undefined\n}\n\nexport function FileEditToolDiff(props: Props): React.ReactNode {\n  // Snapshot on mount — the diff must stay consistent even if the file changes\n  // while the dialog is open. useMemo on props.edits would re-read the file on\n  // every render because callers pass fresh array literals.\n  const [dataPromise] = useState(() =>\n    loadDiffData(props.file_path, props.edits),\n  )\n  return (\n    <Suspense fallback={<DiffFrame placeholder />}>\n      <DiffBody promise={dataPromise} file_path={props.file_path} />\n    </Suspense>\n  )\n}\n\nfunction DiffBody({\n  promise,\n  file_path,\n}: {\n  promise: Promise<DiffData>\n  file_path: string\n}): React.ReactNode {\n  const { patch, firstLine, fileContent } = use(promise)\n  const { columns } = useTerminalSize()\n  return (\n    <DiffFrame>\n      <StructuredDiffList\n        hunks={patch}\n        dim={false}\n        width={columns}\n        filePath={file_path}\n        firstLine={firstLine}\n        fileContent={fileContent}\n      />\n    </DiffFrame>\n  )\n}\n\nfunction DiffFrame({\n  children,\n  placeholder,\n}: {\n  children?: React.ReactNode\n  placeholder?: boolean\n}): React.ReactNode {\n  return (\n    <Box flexDirection=\"column\">\n      <Box\n        borderColor=\"subtle\"\n        borderStyle=\"dashed\"\n        flexDirection=\"column\"\n        borderLeft={false}\n        borderRight={false}\n      >\n        {placeholder ? <Text dimColor>…</Text> : children}\n      </Box>\n    </Box>\n  )\n}\n\nasync function loadDiffData(\n  file_path: string,\n  edits: FileEdit[],\n): Promise<DiffData> {\n  const valid = edits.filter(e => e.old_string != null && e.new_string != null)\n  const single = valid.length === 1 ? valid[0]! : undefined\n\n  // SedEditPermissionRequest passes the entire file as old_string. Scanning for\n  // a needle ≥ CHUNK_SIZE allocates O(needle) for the overlap buffer — skip the\n  // file read entirely and diff the inputs we already have.\n  if (single && single.old_string.length >= CHUNK_SIZE) {\n    return diffToolInputsOnly(file_path, [single])\n  }\n\n  try {\n    const handle = await openForScan(file_path)\n    if (handle === null) return diffToolInputsOnly(file_path, valid)\n    try {\n      // Multi-edit and empty old_string genuinely need full-file for sequential\n      // replacements — structuredPatch needs before/after strings. replace_all\n      // routes through the chunked path below (shows first-occurrence window;\n      // matches within the slice still replace via edit.replace_all).\n      if (!single || single.old_string === '') {\n        const file = await readCapped(handle)\n        if (file === null) return diffToolInputsOnly(file_path, valid)\n        const normalized = valid.map(e => normalizeEdit(file, e))\n        return {\n          patch: getPatchForDisplay({\n            filePath: file_path,\n            fileContents: file,\n            edits: normalized,\n          }),\n          firstLine: firstLineOf(file),\n          fileContent: file,\n        }\n      }\n\n      const ctx = await scanForContext(handle, single.old_string, CONTEXT_LINES)\n      if (ctx.truncated || ctx.content === '') {\n        return diffToolInputsOnly(file_path, [single])\n      }\n      const normalized = normalizeEdit(ctx.content, single)\n      const hunks = getPatchForDisplay({\n        filePath: file_path,\n        fileContents: ctx.content,\n        edits: [normalized],\n      })\n      return {\n        patch: adjustHunkLineNumbers(hunks, ctx.lineOffset - 1),\n        firstLine: ctx.lineOffset === 1 ? firstLineOf(ctx.content) : null,\n        fileContent: ctx.content,\n      }\n    } finally {\n      await handle.close()\n    }\n  } catch (e) {\n    logError(e as Error)\n    return diffToolInputsOnly(file_path, valid)\n  }\n}\n\nfunction diffToolInputsOnly(filePath: string, edits: FileEdit[]): DiffData {\n  return {\n    patch: edits.flatMap(e =>\n      getPatchForDisplay({\n        filePath,\n        fileContents: e.old_string,\n        edits: [e],\n      }),\n    ),\n    firstLine: null,\n    fileContent: undefined,\n  }\n}\n\nfunction normalizeEdit(fileContent: string, edit: FileEdit): FileEdit {\n  const actualOld =\n    findActualString(fileContent, edit.old_string) || edit.old_string\n  const actualNew = preserveQuoteStyle(\n    edit.old_string,\n    actualOld,\n    edit.new_string,\n  )\n  return { ...edit, old_string: actualOld, new_string: actualNew }\n}\n"],"mappings":"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","ignoreList":[]}