gpenghe / tealdeer

A very fast implementation of tldr in Rust.

Home Page:https://github.com/tldr-pages/tldr

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

tealdeer

teal deer

Crate Linux macOS
Crates.io Circle CI Travis CI

A very fast implementation of tldr in Rust: Simplified, example based and community-driven man pages.

screenshot

If you pronounce "tldr" in English, it sounds somewhat like "tealdeer". Hence the project name :)

In case you're in a hurry and just want to quickly try tealdeer, you can find static binaries on the GitHub releases page!

Goals

High level project goals:

  • Download and cache pages
  • Don't require a network connection for anything besides updating the cache
  • Command line interface similar or equivalent to the NodeJS client
  • Be fast

A tool like tldr should be as frictionless as possible to use. It should be easy to invoke (just tldr tar, not using another subcommand like tldr find tar) and it should show the output as fast as possible.

tealdeer reaches these goals. During a (highly non-scientific) test (see #38 for details), I tested the invocation speed of tldr <command> for a few of the existing clients:

Client Times (ms) Avg of 5 (ms)
Tealdeer 15/11/5/5/11 9.4
C client 11/5/12/11/15 10.8
Bash client 15/19/22/25/24 21.0
Go client by k3mist 98/96/100/95/101 98.8
Python client 152/148/151/158/140 149.8
NodeJS client 169/171/170/170/170 170.0

tealdeer was the winner here, although the C client and the Bash client are in the same speed class. Interpreted languages are clearly much slower to invoke, a delay of 170 milliseconds is definitely noticeable and increases friction for the user.

These are the clients I tried but failed to compile or run: Haskell client, Ruby client, Perl client, Go client by anoopengineer, PHP client.

Usage

tldr [options] <command>
tldr [options]

Options:

    -h --help           Show this screen
    -v --version        Show version information
    -l --list           List all commands in the cache
    -f --render <file>  Render a specific markdown file
    -o --os <type>      Override the operating system [linux, osx, sunos]
    -u --update         Update the local cache
    -c --clear-cache    Clear the local cache

Examples:

    $ tldr tar
    $ tldr --list

To control the cache:

    $ tldr --update
    $ tldr --clear-cache

To render a local file (for testing):

    $ tldr --render /path/to/file.md

Installing

Static Binaries (Linux)

Static binary builds (currently for Linux only) are available on the GitHub releases page. Simply download the binary for your platform and run it!

Builds for other platforms are planned.

Cargo Install (any platform)

Build and install the tool via cargo...

$ cargo install tealdeer

From Source (any platform)

tealdeer requires at least Rust 1.19.

Debug build with logging enabled:

$ cargo build --features logging

Release build without logging:

$ cargo build --release

To enable the log output, set the RUST_LOG env variable:

$ export RUST_LOG=tldr=debug

From AUR (Arch Linux)

If you're an Arch Linux user, you can also install the package from the AUR:

$ yaourt -S tealdeer

(Or tealdeer-git if you prefer the current development version.)

Bash Autocompletion

To get bash autocompletion, simply rename the file bash_tealdeer to tldr and copy it to /usr/share/bash-completion/completions/tldr.

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Thanks to @SShrike for coming up with the name "tealdeer"!

About

A very fast implementation of tldr in Rust.

https://github.com/tldr-pages/tldr

License:Apache License 2.0


Languages

Language:Rust 94.5%Language:Shell 5.5%