A command-line tool to concatenate files and directories in a structured way to a single prompt for use with large language models and other applications.
files-to-prompt.ts
is a stand-alone, dependency free1 script that combines multiple text or code files into a single, continuous stream of content. This can be useful when working with LLMs, where you may want to provide a comprehensive set of information as input to the model, rather than individual files.
This is a TypeScript port of the original files-to-prompt
tool written in Python by Simon Willison, which is available at https://github.com/simonw/files-to-prompt.
- Extracts the contents of text files and presents them in a formatted way
- Supports including or excluding hidden files and directories
- Allows ignoring files based on patterns or .gitignore rules
- Converts Jupyter Notebook (.ipynb) files to ASCII or Markdown
- Supports redirecting output to a file
- Runs out-of-box on the Bun runtime environment
- Compatible with Deno and Node.js (minified)
To use the files-to-prompt.ts
tool, you'll need to have the Bun TypeScript engine installed on your system. You can download and install Bun from the official website: https://bun.sh/
Once you have Bun installed, you can clone the repository and run the tool:
git clone https://github.com/fry69/files-to-prompt-ts.git
cd files-to-prompt-ts
bun run files-to-prompt.ts [options] [paths]
Alternatively you can download the script directly:
- from jsr.io:
curl https://jsr.io/@fry69/files-to-prompt-ts/0.5.2/files-to-prompt.ts > ftp.ts
- from GitHub:
curl https://raw.githubusercontent.com/fry69/files-to-prompt-ts/v0.5.2/files-to-prompt.ts > ftp.ts
Don't forget to make the script executable with chmod +x ftp.ts
and move it to a location where it is accessible from your system's $PATH
(optional).
Minified, Node.js compatible builds of this script can be found in the minified directory (automatically generated).
The tool accepts the following command-line arguments:
--version Output the version of the tool
--include-hidden Include hidden files and directories
--ignore-gitignore Ignore .gitignore files
-i, --ignore <pattern> Ignore files matching the specified pattern
-o, --output <file> Redirect output to the specified file
--nbconvert <command> Specify the external nbconvert command to use for .ipynb files
Specify 'internal' for fast internal converter
--format <format> Specify the format to convert .ipynb files to ('asciidoc' or 'markdown')
[paths] One or more file or directory paths to process
The tool can also accept file paths from stdin. The input can be in the following formats:
- One file path per line
- File paths with a colon separator, as in the output of grep or ripgrep
By default, the tool outputs the file contents to the console. You can redirect the output to a file using the --output
or -o
option.
If the --nbconvert
option is provided, the tool will attempt to convert any .ipynb
(Jupyter Notebook) files to the specified format (--format asciidoc
or --format markdown
) using the provided nbconvert
command name or path. By default asciidoc
will be used.
Without conversion (or if the provided command cannot be found) Notebook files will get included verbatim in their JSON
format (including base64
encoded images etc).
Each external Notebook conversion happens in a freshly created temporary directory (via mktemp
API), which gets deleted automatically after successful (or unsucessful) completion.
New (v0.5.0): Crazy fast (100x compared to
nbconvert
) internal converter, use with--nbconvert internal
ftp.ts ./my-project --include-hidden -i *.lockdb -i *.env | \
llm -s "Check the provided code for spelling errors, inconsistencies,
dead code and other minor issues I might have overlooked."
This will concatenate all files (including hidden files) in the ./my-project
directory, excluding any files matching the *.lockdb
or *.env
patterns, and then send the result to the llm command, which adds a system prompt and sends it to a LLM API for processing.
$ ./ftp.ts testfolder/
testfolder/file3.txt
---
File 3 contents
---
Warning: Skipping binary file testfolder/binary.data
Note: Warnings and errors will get sent to
stderr
, piping the output to another command is safe. The script tries its best to keep the output stream clean.
This repository includes a comprehensive test script to ensure files-to-prompt.ts
works as expected. You can run the tests using the following command:
bun test --coverage
Recent test status (v0.5.2, using nbconvert-shim):
bun test v1.1.4 (fbe2fe0c)
::group::files-to-prompt.test.ts:
(pass) files-to-prompt.ts > should include single file passed on the command line [5.28ms]
(pass) files-to-prompt.ts > should include multiple files passed on the command line [1.10ms]
(pass) files-to-prompt.ts > should include files in directories passed on the command line [0.76ms]
(pass) files-to-prompt.ts > should include files a few levels deep in a directory structure [0.73ms]
(pass) files-to-prompt.ts > should exclude files matching patterns passed via --ignore [0.73ms]
(pass) files-to-prompt.ts > should exclude files matching patterns passed via multiple --ignore [0.63ms]
(pass) files-to-prompt.ts > should fail when --ignore gets passed without an argument [0.38ms]
(pass) files-to-prompt.ts > should exclude files matching patterns in .gitignore [0.70ms]
(pass) files-to-prompt.ts > should exclude directory matching patterns in .gitignore [0.83ms]
(pass) files-to-prompt.ts > should exclude directory matching patterns in .gitignore in different directories [0.55ms]
(pass) files-to-prompt.ts > should include hidden files and directories when --include-hidden is passed [0.89ms]
(pass) files-to-prompt.ts > should ignore .gitignore files when --ignore-gitignore is passed [0.75ms]
(pass) files-to-prompt.ts > should skip binary files [1.07ms]
(pass) files-to-prompt.ts > should fail silently if isBinaryFile() gets called with invalid path [0.15ms]
(pass) files-to-prompt.ts > should skip FIFOs [3.97ms]
(pass) files-to-prompt.ts > should fail with error message if path does not exist [0.09ms]
(pass) files-to-prompt.ts > should parse file paths with parseFilePathsFromStdin() correctly [0.22ms]
(pass) files-to-prompt.ts > should de-duplicate file paths with parseFilePathsFromStdin() [0.07ms]
(pass) files-to-prompt.ts > should parse file paths with one file path per line [0.09ms]
(pass) files-to-prompt.ts > should handle mixed input formats [0.06ms]
(pass) files-to-prompt.ts > should handle empty lines in stdin data [0.04ms]
(pass) files-to-prompt.ts > should handle binary data in stdin [0.08ms]
(pass) files-to-prompt.ts > should handle common text/code files in stdin [0.06ms]
(pass) files-to-prompt.ts > should handle long file paths in stdin [0.29ms]
(pass) files-to-prompt.ts > should ignore file paths with the null character [0.06ms]
(pass) files-to-prompt.ts > should ignore file paths with control characters [0.07ms]
(pass) files-to-prompt.ts > should output version string when --version is passed [0.09ms]
(pass) files-to-prompt.ts > should output error for unsupported options [0.07ms]
(pass) files-to-prompt.ts > should output to a file when --output is passed [1.46ms]
(pass) files-to-prompt.ts > should output to a file when -o is passed [0.73ms]
(pass) files-to-prompt.ts > should output error if --output is passed without a file path [0.16ms]
(pass) files-to-prompt.ts > should output error if -o is passed without a file path [0.14ms]
(pass) files-to-prompt.ts > should output error if output file cannot be written [0.24ms]
(pass) files-to-prompt.ts > should include .ipynb files verbatim whitout --nbconvert [0.64ms]
(pass) files-to-prompt.ts > should include .ipynb files verbatim when --nbconvert is set to invalid command [1.45ms]
(pass) files-to-prompt.ts > should convert .ipynb files to ASCII when --nbconvert --format asciidoc is passed [46.95ms]
(pass) files-to-prompt.ts > should convert .ipynb files to Markdown when --nbconvert --format markdown is passed [46.59ms]
(pass) files-to-prompt.ts > should convert .ipynb files to ASCII when --nbconvert --format asciidoc is passed using internal converter [0.60ms]
(pass) files-to-prompt.ts > should convert .ipynb files to Markdown when --nbconvert --format markdown is passed using internal converter [0.85ms]
::endgroup::
--------------------|---------|---------|-------------------
File | % Funcs | % Lines | Uncovered Line #s
--------------------|---------|---------|-------------------
All files | 83.33 | 85.25 |
files-to-prompt.ts | 83.33 | 85.25 | 69,82,97,108-111,137,187,221,240-242,249-250,272-274,280-281,308-309,325,450-461,574-575,592-593,596-597,665-668,670-672,686-689,691-692
--------------------|---------|---------|-------------------
39 pass
0 fail
95 expect() calls
Ran 39 tests across 1 files. [150.00ms]
This script is compatible with the Deno runtime.
The minified build of this script is compatible with the Node runtime.
If you find any issues or have suggestions for improvements, feel free to open an issue or submit a pull request on the GitHub repository.
This project is licensed under the MIT License.
Large Language Models were used to create this tool. All generated code was curated by me before inclusion and nearly all codepaths get thorougly tested. Despite best efforts and intentions, there may be bugs.
Footnotes
-
The script needs a TypeScript engine to run, of course. ↩