#syntax-highlighting #markdown #paper #text #document #viewer #command-line

app paper-terminal

Writes a file to a paper in your terminal. Especially if that file is Markdown.

20 releases (9 stable)

3.1.0 Jan 4, 2025
3.0.0 Nov 14, 2023
2.2.1 Jun 25, 2022
2.1.2 Apr 2, 2021
0.2.0 Jun 12, 2019

#2097 in Command line utilities

Download history 11/week @ 2024-09-21 2/week @ 2024-09-28 23/week @ 2024-12-07 14/week @ 2024-12-14 147/week @ 2025-01-04

161 downloads per month

MIT license

195KB
1.5K SLoC

Paper terminal

dependency status

See paper.png to see what this looks like!

Writes a file to a paper in your terminal. Especially if that file is Markdown! Features supported include:

  1. The usual text, and paragraphs with automatic line-wrapping. You can manually wrap with hard breaks as expected.

    Otherwise, paragraphs will be nicely spaced.

  2. Headings

  3. Bold / Italic / Bold and Italic / Strikethrough

  4. Lists

    • Ordered
    • Unordered
      • Nested

    Definition : This is a definition

  5. Rules

  6. Inline code

  7. Code blocks, with syncat integration for syntax highlighting. Note that you must install syncat and make the syncat executable available on your path for this to work.

    fn main() {
        println!("Hello world");
    }
    
  8. Blockquotes

    Blockquotes

    And even nested block quotes

    [!IMPORTANT] Also alert blockquotes

  9. And even images! Here's a photo of my cat

    My cat. His name is Cato

  10. Task lists:

    • Easy
    • Hard
  11. Footnotes[^ft]

    [^ft]: This is the footnote!

  12. Tables

Comparison with other command line Markdown renderers

Not a very good comparison... this is more of an example of a table!

Tool CommonMark Paper Paging Wrapping Syntax Images Tables Looks good*
foxfriends/paper-terminal Yes Yes No Yes syncat Pixelated Yes Yes
ttscoff/mdless Yes No Yes No pygmentize Sometimes Yes No
lunaryorn/mdcat Yes No No No syntect Sometimes No No

* subjective

Styling

Paper uses syncat stylesheets to allow full customization of styling. See the default stylesheet (src/default.syncat) as an example of how this works. To override the default styles, create paper.syncat in your active syncat theme.

  • Different scopes are represented as nodes, inspired by the corresponding HTML tag names.

    • h1 through h6
    • strong
    • emphasis
    • strikethrough
    • code
    • blockquote
    • ul, ol, li
    • footnote-ref, footnote-def, footnote
    • table
    • caption
    • link
  • The paper and shadow can be matched with paper and shadow. Styles applied to paper are applied to everything.

  • The "prefix" and "suffix" tokens can be used to match the decorations

    • List item bullets
    • Blockquote markers
    • Code block margins
  • The "lang-tag" token matches the language name written in the bottom corner of the code block

  • You can apply styles to code blocks with a specific language by using the language name as the token

For now, the prefix/suffix contents are not customizable, but this may be added in future if it is desired.

Installation

Paper can be installed from crates.io using Cargo:

cargo install paper-terminal

Usage

# Print the help
paper --help

# Render README.md
paper README.md

# Render README.md, with syntax highlighting
paper README.md -s
Prints papers in your terminal

Usage: paper [OPTIONS] [FILE]...

Arguments:
  [FILE]...  Files to print

Options:
  -m, --margin <MARGIN>            Margin (shortcut for horizontal and vertical margin set to the same value) [default: 6]
      --h-margin <H_MARGIN>        Horizontal margin (overrides --margin)
      --v-margin <V_MARGIN>        Vertical margin (overrides --margin)
  -w, --width <WIDTH>              The width of the paper (including the space used for the margin) [default: 92]
  -p, --plain                      Don't parse as Markdown, just render the plain text on a paper
  -t, --tab-length <TAB_LENGTH>    The length to consider tabs as [default: 4]
  -U, --hide-urls                  Hide link URLs
  -I, --no-images                  Disable drawing images
  -l, --left                       Position paper on the left edge of the terminal, instead of centred
  -r, --right                      Position paper on the right edge of the terminal, instead of centred
  -s, --syncat                     Use syncat to highlight code blocks. Requires you have syncat installed
      --dev                        Print in debug mode
      --completions <COMPLETIONS>  Generate shell completions [possible values: bash, elvish, fish, powershell, zsh]
  -h, --help                       Print help

Dependencies

~12–23MB
~342K SLoC