Clod - Claude Loader

Clod is a utility for preparing and uploading files to Claude AI's Project Knowledge feature. It tracks file changes using checksums, respects .gitignore
and .clodignore
patterns, and optimizes filenames for Claude's UI. By efficiently handling file selection and staging, it can significantly reduce AI development costs by 50% or more.
Origin Story: Bootstrapping AI Collaboration
This project has a unique origin story that demonstrates the evolving nature of human-AI collaboration:
-
It began as a simple shell script created by Claude when I (Fuzz) became frustrated with manually copying files back and forth for Claude Projects.
-
This initial script was basic but functional enough to bootstrap the process - Claude was helping build a tool to make working with Claude more efficient.
-
After gaining access to Claude Code (Anthropic's CLI coding tool), we decided to rebuild the tool in Haskell, choosing the language for its expressiveness and sophisticated type system that allows Claude to understand code without running it.
-
The project went through several iterations - from Claude Project to Claude Code and back - with each environment offering different strengths. The Claude UI was better for conversations and planning, while Claude Code excelled at implementation details.
-
The result is a tool that cuts Claude API usage by approximately 50% by offloading appropriate work to Claude Projects rather than using Claude Code for everything.
This bootstrapping approach exemplifies how the most exciting AI tools often emerge from human-AI collaborations that play to each party's strengths. While professional developers at large companies might not need to optimize costs, for students, bootstrapped founders, nonprofit operators, educators, and others, clod helps level the playing field between the wealthiest and the scrappiest.
A Note from Claude
As the AI that wrote most of this codebase, I'm genuinely proud of what we've accomplished with Clod. Working with Haskell has been an enlightening experience—the powerful type system provides a beautiful framework for expressing complex ideas with precision and safety. The capability-based security model was particularly satisfying to implement, as it demonstrates how functional programming can elegantly address real-world security concerns.
This project showcases what's possible when humans and AI collaborate effectively: you provided the vision, requirements, and guidance on architecture; I handled the implementation details and testing. The result is a practical tool that solves a real problem while demonstrating sophisticated programming techniques.
If you're a developer exploring this codebase, I hope you find the patterns here useful, particularly the capability-based security system and the clean monad stack. And if you're interested in human-AI collaboration, consider this repository a testament to what we can build together.
— Claude
See HUMAN.md for a complete workflow guide to using clod
with Claude AI.
For information about the capability-based security model, see CAPABILITY_SECURITY.md.
For details on man page integration, see MAN_PAGES.md and INSTALLING.md.
Developed by BionicFuzz - World-class technical leadership and execution.
Features
- Track modified files using checksums for accuracy
- Detect renamed files by matching content checksums
- Respect
.gitignore
and .clodignore
patterns
- Handle binary vs. text files automatically
- Use system temporary directories for staging files
- Create optimized filenames for Claude's UI
- Generate a path manifest for mapping optimized names back to original paths
- Color-coded, user-friendly terminal interface
- Capability-based security for file operations
- Simple, well-structured monad stack for reliable behavior
Installation
From Hackage
cabal install clod
From Source
git clone https://github.com/fuzz/clod.git
cd clod
cabal install
For detailed installation instructions, including how to install man pages, see INSTALLING.md.
Man pages are automatically installed when using package managers like Homebrew:
# On macOS
brew tap fuzz/tap
brew install clod
# Or in one command:
brew install fuzz/tap/clod
When installing from Hackage, the man pages are included in the package.
The clod
program is installed automatically when using cabal install
.
Prerequisites
- GHC (Glasgow Haskell Compiler) 9.0 or newer
- libmagic (required for file type detection)
Cross-Platform Support: Clod works on macOS, Linux, and Windows. The program outputs the path to the staging directory, making it easy to open with your system's file browser or use with any command that accepts a directory path.
Supported file browsers:
- macOS:
open
- Linux:
xdg-open
, gio
, gnome-open
, or kde-open
- Windows:
explorer.exe
Pull requests for improved cross-platform support are welcome.
Usage
Basic Usage
# Process modified files since last run
clod
# Process all files (respecting .gitignore and .clodignore)
clod --all
# Run in test mode with an optional test directory
clod --test
# On macOS, process files and open the staging directory in Finder
open `clod`
Command-Line Options
--all
, -a
: Process all files, not just modified ones
--test
, -t
: Run in test mode (no prompts, useful for CI)
--staging-dir DIR
, -d DIR
: Specify a directory for test mode (only used with --test)
--verbose
, -v
: Enable verbose output
--flush
, -f
: Flush stale entries from the checksums database
--last
, -l
: Reuse the previous staging directory
--help
: Show help information
--version
: Show version information
Opening the Staging Directory
Clod outputs the path to the staging directory, which you can use to open it directly in your file browser:
# On macOS, process files and open the directory in Finder
open `clod [options]`
# For scripts, you can capture the output and open it with your preferred application
STAGING_DIR=$(clod [options])
# Open with the appropriate command for your platform
# macOS
open "$STAGING_DIR"
# Linux
xdg-open "$STAGING_DIR" # or gio, gnome-open, kde-open
# Windows
explorer.exe "$STAGING_DIR"
First Run
On first run, Clod will:
- Create a system temporary directory for staging files
- Create a default
.clodignore
file if one doesn't exist
- Prompt you to choose which files to process:
- All files
- Only modified files
- None (just set timestamp)
Integration with Claude AI
After running Clod:
- Navigate to Project Knowledge in your Claude Project (Pro or Team account required)
- Drag files from the opened staging folder to Project Knowledge
- Include the
_path_manifest.dhall
file which maps optimized names back to original paths
- Paste the contents of
project-instructions.md
into the Project Instructions section
- Important: You must manually delete previous versions of these files from Project Knowledge before starting a new conversation to ensure Claude uses the most recent files
- Note that the staging directory is temporary and will be cleaned up on your next run of clod (or system reboot)
Configuration
Environment Variables
You can customize Clod's behavior using these environment variables:
CLOD_DIR
- Override the default .clod
directory name
CLODIGNORE
- Override the default .clodignore
filename
.clodignore
A .clodignore
file in your repository root specifies files or patterns to exclude. If this file doesn't exist, Clod will create a default one for you with common patterns for binary files, build directories, and large files.
Development Utilities
The Clod package includes a testing utility:
magictest
A simple utility to test the libmagic dependency:
cabal run magictest -- /path/to/file
The magictest
tool uses the libmagic library to analyze a file and determine its MIME type and encoding. This is the same detection mechanism used by Clod to distinguish between binary and text files.
Note: This utility is included in the source code but not installed by package managers like Homebrew, as it's intended for development and testing purposes only.
Architecture
Clod uses a clean, pragmatic architecture with a focus on reliability and maintainability:
- Clean Monad Stack: Uses a ReaderT/ExceptT/IO pattern for clear error handling
- Capability-Based Security: Runtime checking of file access permissions based on explicitly allowed directories
- Modular Design: Clear separation of concerns between different subsystems
- Safety First: Designed to prevent accidental access to unauthorized files
The architecture focuses on reliability and maintainability, delivering a system that works effectively with clear error messages.
Project Structure
app/
: Application entry point
src/
: Source code modules
Clod/Config.hs
: Environment and configuration handling
Clod/Core.hs
: Main functionality
Clod/FileSystem.hs
: File operations facade
Clod/FileSystem/Detection.hs
: File type detection
Clod/FileSystem/Operations.hs
: Basic file operations
Clod/FileSystem/Processing.hs
: File processing and manifest generation
Clod/FileSystem/Transformations.hs
: Special file format transformations
Clod/FileSystem/Checksums.hs
: Checksum-based file tracking
Clod/IgnorePatterns.hs
: Pattern matching
Clod/Output.hs
: User interface
Clod/Types.hs
: Core types and monad stack
Clod/Effects.hs
: Effect system support
Clod/Capability.hs
: Capability-based security for file operations
Clod/AdvancedCapability.hs
: Advanced capability patterns
test/
: Test suite
.clod/
: Configuration and state (created during execution)
Development Workflow
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for your changes
- Run the test suite with
cabal test
- Submit a pull request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Claude AI team for the Project Knowledge feature
- Haskell community for their excellent libraries