ruudk / readme-examples-sync-hook
Automatically sync PHP code examples with readme file
Requires
- php: ^8.4
Requires (Dev)
README
A CaptainHook action that automatically syncs PHP code examples in your README.md with actual source files. This ensures your documentation always shows up-to-date, working code examples.
Installation
composer require --dev ruudk/readme-examples-sync-hook
Configuration
Add the hook to your captainhook.json
configuration file in the pre-commit
section:
{ "pre-commit": { "enabled": true, "actions": [ { "action": "\\Ruudk\\ReadmeExamplesSyncHook\\SyncReadmeExamples" } ] } }
How It Works
This hook scans your README.md file for special HTML comments that mark code examples:
- Source code sync: Updates code blocks marked with
<!-- source: ... -->
with the actual content from source files - Output sync (optional): When you add
<!-- output: ... -->
comments, the hook executes PHP files and captures their output to display results
The hook automatically stages the updated README.md if changes are detected, ensuring your documentation stays in sync with your code.
Usage
Syncing Source Code
To sync a code example with a source file, add a comment before your code block:
<!-- source: examples/demo.php --> ```php // This code will be replaced with content from examples/demo.php ```
Syncing Output (Optional)
To show the output of executing a PHP file, use:
<!-- output: examples/demo.php --> ```php // This will be replaced with the output from executing examples/demo.php ```
Example
Here's how it looks in practice: ruudk/code-generator.
License
MIT