#markdown #script #shell #executable #makefile

app makedown

Executable Markdown shell scripts

1 unstable release

0.0.0 Oct 17, 2024

#25 in #makefile

Download history 176/week @ 2024-10-14 9/week @ 2024-10-21 3/week @ 2024-11-04

188 downloads per month

MIT license

4KB

makedown - A Markdown powered Makefile alternative

makedown (aka Makefile + Markdown) is motivated by developers need to define multiple scripts in one file next to their documentation, and have a handy way to run them from terminal.

Makefiles are great for this, but are lucking some of the makedown features, such as syntax highlighting, hierarchical scanning of .md files with embedded documentation.

There are also package.json scripts in node.js world, but users are forced to write script commands in one line.

It is implemented in Python for portability reasons, since most Unix-like systems already have a Python interpreter installed.

Here is DEMO.md file with examples of usage.


This is a fresh project still under active development.

Feel free to open and issue or PR.

We also have have a Discord server for quick discussions and sharing ideas or feedback.


Key Features

  • Executable Markdown Scripting: Use markdown files (.md) to organize commands and their documentation.
  • Multilingual Execution: Supports zsh, bash, javascript, python and infinitely many more, using custom hashbangs.
  • Syntax Highlighting: Leverages markdown code blocks for readability.

Install

pip install makedown

Use

Define commands in a .md file:

# my_scripts.md

Here are a few examples of commands:

## [hello]() Prints "hello" using bash

```bash
echo "hello"
```

## [world]() Prints "world" using python

This is a more detailed description of the command.

```python
#!/usr/bin/env python

print("world")
```

To run commands in a markdown file, execute makedown from the same directory or any subdirectory:

makedown hello

A shorter version is also available:

m world

To see all the available commands with their short descriptions, use one of the following:

makedown --help

or just run it without any arguments:

m

To get more details about a specific command, use:

makedown world --help

Upgrade

pip install --upgrade makedown

Uninstall

pip uninstall makedown

No runtime deps