GitXplorerGitXplorer
r

markterm

public
7 stars
0 forks
0 issues

Commits

List of commits on branch main.
Unverified
70212ee7f6a923b9a73aa721aa3033cf3068444e

fix: show image targets as links when images are not supported

rralsina committed 5 months ago
Unverified
ec330fad6bc7f177da3cdbe05a7b59008482c5d9

feat: highlight HTML blocks and inline HTML

rralsina committed 5 months ago
Unverified
c7f0265e95cbb8a1a589259fd60fc3167ff6744b

chore: adjusted markdown check

rralsina committed 5 months ago
Unverified
531c3f7a640993a6579c537bd407917d2fdce334

fix: always colorize even when piped, so you can use a pager

rralsina committed 5 months ago
Unverified
1ea74a5ba694ebe42e6e492acfd222c92497e52b

docs: update building instructions

rralsina committed 5 months ago
Unverified
8b88a5c765487f88927b6068799cbe3183047512

docs: add TODO

rralsina committed 5 months ago

README

The README file for this repository.

MARKTerm

Markterm is a library and program to render Markdown to a terminal. It's inspired by Glow and implemented using Markd

Features

  • It will syntax highlight code blocks
  • It will try to handle light and dark terminal themes. Since it uses the terminal's colors, it should match things like vs code themes in the vs code terminal, etc.
  • In general it tries to look good and not gaudy
  • It will do the right thing if output is not a tty
  • Can be used as a library or as a program

markterm on a light terminal markterm on a dark terminal

TODO

  • ✅ Configurable themes
  • ✅ Implement HTML-style links as supported in kitty/alacritty
  • ✅ Don't break paragraphs on soft breaks
  • ✅ Implement images as supported in kitty (requires timg, kinda buggy)
  • ✅ Images in all terminals (requires catimg, kinda useless)
  • ✅ Implement HTML block support
  • ✅ Better textual image display when images are not supported
  • ✅ Maybe only support timg with options
  • ✅ Support being used in a pipeline
  • Implement internal piping to $PAGER
  • Allow enabling/disabling images/html-style-links via CLI (partly done)
  • Use crystal-term/color to detect color capabilities
  • Fix whatever bug is there

Usage as a program

Either get a static binary from the releases page or build from source:

  • Install crystal
  • Checkout the repo
  • run shards build

This is the help:

Markterm - A tool to render markdown to the terminal

Usage:
  markterm <file> [-t <theme>][--code-theme <code-theme>][-l]
  markterm -h | --help
  markterm --version

Options:
  -h --help                  Show this screen.
  -t <theme>                 Theme to use for coloring output
  --code-theme <code-theme>  Theme to use for coloring code blocks
  --version                  Show version.
  -l                         Force html-like links

If you use "-" as the file argument, markterm will read from stdin.

Usage as a library

  1. Add the dependency to your shard.yml:

    dependencies:
      markterm:
        github: ralsina/markterm

In your code, use it like this:

  puts Markd.to_term(source)

Contributing

  1. Fork it (https://github.com/ralsina/markterm/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors