mdman is a command-line tool that allows you to write Unix manual pages using simple and familiar Markdown syntax. It parses Markdown files (including GitHub Flavored Markdown tables and YAML frontmatter) and converts them into valid roff-formatted man pages.
- Write man pages in Markdown (with optional frontmatter for metadata)
- Converts to man-page format using roff syntax
- Supports:
- Section and subsection headings
- Definition lists
- Paragraphs
- Code blocks and inline code
- Emphasis (italic, bold)
- Lists (ordered and unordered)
- Links
- Tables (with alignment)
 
- Print to stdout for preview or debugging
- Preview directly as man page
Clone and build using Cargo:
git clone https://github.com/matkrin/mdman.git
cd mdman
cargo build --releaseThe resulting binary will be in target/release/mdman.
mdman [OPTIONS] [<file.md>]If no file is provided, Markdown is read from stdin. If no output file is specified, output is printed to stdout.
-s, --section <SECTION>  Override section number for output (e.g., 1 for general commands)
-S, --stdout             Print to stdout instead of creating a file
-o, --output <OUTPUT>    Output filename (Overrides automatic naming)
-p, --pager              Preview the generated man page in a pager. (Overrides --output and --stdout)
-h, --help               Print help
-V, --version            Print version
From file to stdout:
mdman doc.md --stdoutFrom stdin to stdout:
cat doc.md | mdmanFrom stdin to file:
cat doc.md | mdman --output out.5Use bat as pager:
# Linux
mdman mytool.md --stout | man --pager=bat -l -
# macOS
mdman mytool.md --stdout | mandoc | batCreate HTML of the man page:
# Linux
mdman mytool.md --stdout | groff -Thtml -mandoc > out.html
# macOS
mdman mytool.md --stdout | mandoc -T html > out.htmlYou can see a full description of how markdown elements get converted in mdman(5).
Use YAML frontmatter to define required metadata for the .TH line:
---
name: mytool
section: 1
date: 2025-05-24
left-footer: MyTool Manual
center-footer: MyTool v1.0
---# NAME
**mytool** - does things
# SYNOPSIS
**mytool** [_OPTIONS_] <_INPUT_>
# DESCRIPTION
**mytool** is a small utility that...
# OPTIONS
---
- **-h**, **--help**
  Print help message
- **-v**, **--verbose**
  Enter verbose mode
---
## Subsection Example
- Lists work
  - Also nested ones
- So do **bold**, _italic_, and `inline code`
Tables work too:
| Column A | Column B |
| -------- | -------- |
| Left     | Right    |Generates .roff-formatted man pages using appropriate macros:
- .TH,- .SH,- .SS,- .PP,- .IP,- .EX,- .UR,- .TS, etc.
- Proper escaping of special characters
- Formatting of lists and nested structures