patat
(Presentations Atop The ANSI Terminal) is a small
tool that allows you to show presentations using only an ANSI terminal. It does
not require ncurses
.
Features:
- Leverages the great Pandoc library to support many input formats including Literate Haskell.
- Supports smart slide splitting.
- There is a live reload mode.
- Theming support.
- Optionally re-wrapping text to terminal width with proper indentation.
- Syntax highlighting for nearly one hundred languages generated from Kate syntax files.
- Written in Haskell.
You can build from source using stack install
or cabal install
. patat
is
also available from Hackage.
For people unfamiliar with the Haskell ecosystem, this means you can do either of the following:
- Install stack for your platform.
- Clone this repository.
- Run
stack setup
(if you're running stack for the first time) andstack install
. - Make sure
$HOME/.local/bin
is in your$PATH
.
- Install cabal for your platform.
- Run
cabal install patat
. - Make sure
$HOME/.cabal/bin
is in your$PATH
.
patat [--watch] presentation.md
Controls:
- Next slide:
space
,enter
,l
,→
- Previous slide:
backspace
,h
,←
- Go forward 10 slides:
j
,↓
- Go backward 10 slides:
k
,↑
- First slide:
0
- Last slide:
G
- Reload file:
r
- Quit:
q
The r
key is very useful since it allows you to preview your slides while you
are writing them. You can also use this to fix artifacts when the terminal is
resized.
If you provide the --watch
flag, patat
will watch the presentation file for
changes and reload automatically. This is very useful when you are writing the
presentation.
The input format can be anything that Pandoc supports. Plain markdown is usually the most simple solution:
---
title: This is my presentation
author: Jane Doe
...
# This is a slide
Slide contents. Yay.
---
# Important title
Things I like:
- Markdown
- Haskell
- Pandoc
Horizontal rulers (---
) are used to split slides.
However, if you prefer not use these since they are a bit intrusive in the
markdown, you can also start every slide with an h1
header. In that case, the
file should not contain a single horizontal ruler.
This means the following document is equivalent:
---
title: This is my presentation
author: Jane Doe
...
# This is a slide
Slide contents. Yay.
# Important title
Things I like:
- Markdown
- Haskell
- Pandoc
patat
is fairly configurable. The configuration is done using YAML. There
are two places where you can put your configuration:
- In the presentation file itself, using the Pandoc metadata header.
- In
$HOME/.patat.yaml
For example, we can turn on line wrapping by using the following file:
---
title: Presentation with wrapping
author: John Doe
patat:
wrap: true
...
This is a split
line which should
be re-wrapped.
Or we can use a normal presentation and have the following $HOME/.patat.yaml
:
wrap: true
Colors and other properties can also be changed using this configuration. For example, we can have:
---
author: 'Jasper Van der Jeugt'
title: 'This is a test'
patat:
wrap: true
theme:
emph: [vividBlue, onVividBlack, bold]
imageTarget: [onDullWhite, vividRed]
...
# This is a presentation
This is _emph_ text.
![Hello](foo.png)
The properties that can be given a list of styles are:
borders
header
codeBlock
bulletList
orderedList
blockQuote
definitionTerm
definitionList
tableHeader
tableSeparator
emph
strong
code
linkText
linkTarget
strikeout
quoted
math
imageText
imageTarget
The accepted styles are:
bold
dullBlack
dullBlue
dullCyan
dullGreen
dullMagenta
dullRed
dullWhite
dullYellow
onDullBlack
onDullBlue
onDullCyan
onDullGreen
onDullMagenta
onDullRed
onDullWhite
onDullYellow
onVividBlack
onVividBlue
onVividCyan
onVividGreen
onVividMagenta
onVividRed
onVividWhite
onVividYellow
underline
vividBlack
vividBlue
vividCyan
vividGreen
vividMagenta
vividRed
vividWhite
vividYellow
As part of theming, syntax highlighting is also configurable. This can be configured like this:
---
patat:
theme:
syntaxHighlighting:
decVal: [bold, onDullRed]
...
...
decVal
refers to "decimal values". This is known as a "token type". For a
full list of token types, see this list -- the names are derived from there in
an obvious way.
"Patat" is the Flemish word for a simple potato. Dutch people also use it to refer to French Fries but I don't really do that -- in Belgium we just call fries "Frieten".
The idea of patat
is largely based upon MDP which is in turn based upon
VTMC. I wanted to write a clone using Pandoc because I ran into a markdown
parsing bug in MDP which I could not work around. A second reason to do a
Pandoc-based tool was that I would be able to use Literate Haskell as well.
Lastly, I also prefer not to install Node.js on my machine if I can avoid it.