A CLI tool to run or list code blocks from Markdown files.
Project description
A CLI Tool for Executing Code Blocks in Markdown Files.
RunMD is a command-line tool designed to extract and execute code blocks from Markdown files. It's particularly useful for managing and running code snippets embedded in documentation or notes.
⚠ RunMD is intended for use with scripting languages only (e.g., Shell, Python, Ruby, JavaScript). It does not support compiled languages (e.g., C, C++, Java) as it cannot handle compilation and execution steps.
⚠ RunMD is different from interactive notebooks like Jupyter or Zepplin. Each code block is independent and executed separately.
Prerequisites
Before you begin, ensure you have the following installed:
- Python 3.9 or later
- pip (Python package installer)
- Git (for cloning the repository)
Installation
From Python Package Index
pip install runmd
From GitHub release
pip install git+https://github.com/PageotD/runmd@0.10.1
From source
Clone the GitHub repository:
git clone https://github.com/PageotD/runmd.git
cd runmd
Install Build and Wheel Dependencies:
pip install build wheel
Build and Install RunMD
python -m build
pip install dist/runmd-<version>-py3-none-any.whl
Initialize
runmd init
Usage
Synopsis
runmd [COMMAND] [OPTIONS]
Commands
RUN
Executes specified code blocks in a Markdown file.
runmd run [blockname] [--tag TAG] [--file FILE] [--env VAR=value ...]
blockname: The name of the code block to run, or "all" to run all blocks.-t [TAG], --tag [TAG]: Specify the tag of the code blocks to run.-f [FILE], --file [FILE]: Specify the path to the Markdown file containing the code blocks.--env VAR=value ...: Optional environment variables to set during the execution.
SHOW
Displays the content of a specified code block.
runmd show [blockname] [--file FILE]
blockname: The name of the code block to display.-f [FILE], --file [FILE]: Specify the path to the Markdown file.
LIST
Lists all the code blocks in a Markdown file.
runmd list [tag] [--file FILE]
-t [TAG], --tag [TAG]: Optional tag to filter the list of code blocks.-f [FILE], --file [FILE]: Specify the path to the Markdown file.
HIST
Displays or clears the history of runmd commands.
runmd hist [id] [--clear]
id: command line entry in history to execute.--clear: Clears definitely all the command line entries in history.
VAULT
Encrypt/Decrypt a markdown file using a password.
runmd vault --encrypt README.md --outfile README.enc
runmd vault --decrypt README.enc --outfile README.dec
-e [FILE], --encrypt [FILE]: Encrypt the specified markdown file.-d [FILE], --decrypt [FILE]: Decrypt the encrypted file.-o [FILE], --outfile [FILE]: Optional output file name (default: add.vaultsuffix to input file name).
Other options
Other options are quite standard:
--help: to show the help message--version: to get the installed version of runmd
Display the version of
Add executable code block
To add an executable code block to your Markdown file, use the following syntax:
# My executable code block
```sh {name=export-echo,tag=example}
EXPORT MYSTR="a simple export and echo"
echo $MYSTR
```
List Code Blocks
To list all code block names in Markdown files within the current directory:
runmd list
Show a Specific Code Block
To display the content of a specific code block:
runmd show <code-block-name>
Run a Specific Code Block
To execute a specific code block by name:
runmd run <code-block-name>
Run all code blocks with a given tag
To execute a specific code block by name:
runmd run -t <tag>
Run all code blocks
To execute a specific code block by name:
runmd run all
Run a Specific Code Block with nvironment variable
To execute a specific code block by name:
runmd run <code-block-name> --env <KEY1>=<VALUE1> <KEY2=VALUE2>
Run all code blocks
To execute all code blocks in Markdown files within the current directory:
runmd run all
Configuration
You can customize how different scripting languages are executed by creating a configuration file at ~/.config/runmd/config.json. Here’s an example configuration:
{
"sh": {
"command": "bash",
"options": ["-c"]
},
"python": {
"command": "python",
"options": []
},
"ruby": {
"command": "ruby",
"options": []
}
}
Troubleshooting
- No Output: Ensure the Markdown code blocks are correctly formatted and the specified commands are valid for the environment.
- Permission Denied: Check if you have the required permissions to execute the commands in the code blocks.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file runmd-0.12.0.tar.gz.
File metadata
- Download URL: runmd-0.12.0.tar.gz
- Upload date:
- Size: 24.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c249978d6d71304b8f6df043c9058fa48a82d8419ab175badc29ead7542d90a
|
|
| MD5 |
3d258470310a53a4c1c587d540cb7c17
|
|
| BLAKE2b-256 |
69bef34b8a8e493aae1467e9992849baa460cdb3299addd1572840e8a7b48864
|
File details
Details for the file runmd-0.12.0-py3-none-any.whl.
File metadata
- Download URL: runmd-0.12.0-py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c2c17d8ff725ecd1ce2fd5d74acce1ac3e371b10a2c38b997b17b8f1280f48e5
|
|
| MD5 |
6e9f2c84e7e8a08b6fc8aaa6881aebc6
|
|
| BLAKE2b-256 |
dcc87f3215a82b2b2aa1b8a082889d6090b08c922e39838e08b32d0feff0ad2b
|