📚 Collaborative cheatsheets for console commands

Darío Hereñú 1c176f4bf9 {: add Spanish translation 4 dní pred
.devcontainer a838b6f175 devcontainer: add `gh` CLI (#13905) 3 mesiacov pred
.github aca52e94a6 build(deps): bump tj-actions/changed-files from 45.0.4 to 45.0.5 (#15406) 6 dní pred
.husky 576070dd0c build(deps-dev): bump husky from 8.0.3 to 9.0.7 (#12175) 11 mesiacov pred
contributing-guides 6613e0f525 14851: Do not use serial comma in negative example (#14852) 1 mesiac pred
images 969b2daa48 README: replace animation with PNG for accessibility (#8720) 1 rok pred
pages 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.ar c52053bcd2 rm: add Arabic translation (#15377) 1 týždeň pred
pages.bn 900d3771eb arch: update documentation link (#15060) 1 mesiac pred
pages.bs 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.ca 7c6bdce13b ls: update documentation link (#15168) 3 týždňov pred
pages.cs f1aa0a8fe5 Revert "pages/*: add standard translation and links (#11331)" (#11374) 1 rok pred
pages.da 7ed998ee1a pages.*/*: remove double spaces (#14856) 1 mesiac pred
pages.de 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.es 1c176f4bf9 {: add Spanish translation 4 dní pred
pages.fa 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.fi eca02da748 pages*/linux: replace manpages.debian.org with manned.org (#13725) 3 mesiacov pred
pages.fr 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.hi 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.id 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.it 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.ja 7f80baebe8 echo: update documentation link (#15191) 3 týždňov pred
pages.ko 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.lo b70772cd22 linux/pwd: delete translations (#14967) 1 mesiac pred
pages.ml 1d950b2127 chmod: update documentation link (#15039) 1 mesiac pred
pages.ne 7c6bdce13b ls: update documentation link (#15168) 3 týždňov pred
pages.nl 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.no 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.pl 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.pt_BR 1376970b35 common/c~d*: fix outdated Brazilian Portuguese pages (#14702) 6 dní pred
pages.pt_PT 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.ro f1aa0a8fe5 Revert "pages/*: add standard translation and links (#11331)" (#11374) 1 rok pred
pages.ru f7ad51e6ec cut: update documentation link (#15189) 3 týždňov pred
pages.sh 379a3803e0 sh: update Serbian-Croatian translation (#11922) 1 rok pred
pages.sr 7f80baebe8 echo: update documentation link (#15191) 3 týždňov pred
pages.sv 3f4013f703 false: update documentation link (#15431) 5 dní pred
pages.ta 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.th 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.tr 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.uk 4a00a569f9 cp: update documentation link (#15144) 3 týždňov pred
pages.uz 6bec2f3637 snoop, truss, locale, bugreportz, dumpsys: fix linter issues (#12698) 8 mesiacov pred
pages.zh 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
pages.zh_TW 22e99987ec gawk: fix alias page (#15392) 1 týždeň pred
scripts a6927a8856 scripts/wrong-filename: add extra exceptions (#15387) 1 týždeň pred
.editorconfig a7724b7c2f .editorconfig: set trim_trailing_whitespace to false (#7958) 2 rokov pred
.flake8 3fa29ea1c2 tooling: add black and flake8 for python formatting/linting (#6454) 3 rokov pred
.gitattributes 16d7c72f7c .gitattributes: specify eol as LF (#9892) 1 rok pred
.gitignore dff913f486 `scripts/_common.py`: add a shared Python file to move duplicated code (#12755) 7 mesiacov pred
.markdownlint.json 5e6dc70b2c style-guide: organize content and update sections; *: fix Markdownlint errors (#12148) 8 mesiacov pred
CLIENT-SPECIFICATION.md 552a22da2b CLIENT-SPECIFICATION: switch to https and remove `www.` (#13910) 3 mesiacov pred
COMMUNITY-ROLES.md 1adda9dd4e README, COMMUNITY-ROLES: fix typos (#12914) 7 mesiacov pred
CONTRIBUTING.md b596b78b18 pages/*: standardize mentioning subcommands without the main command (#13626) 3 mesiacov pred
GOVERNANCE.md 9902092002 cleanup: fix typos in governance page (#11865) 1 rok pred
LICENSE.md a9053792ec LICENSE: switch to https (#13909) 3 mesiacov pred
MAINTAINERS.md 1dad6ac4e3 MAINTAINERS: remove @navarroaxel from Org; CODEOWNERS: update file (#14832) 1 mesiac pred
README.md 9f2dde3c36 cleanup: update README (#14534) 2 mesiacov pred
package-lock.json 631d44ffb9 build(deps): bump markdownlint-cli from 0.42.0 to 0.43.0 (#15014) 1 mesiac pred
package.json 631d44ffb9 build(deps): bump markdownlint-cli from 0.42.0 to 0.43.0 (#15014) 1 mesiac pred
pages.en af2f6d9d3e Symlink `pages.en` to `pages` (#11139) 1 rok pred
requirements.txt 0ea4ea29a8 build(deps): bump black from 24.8.0 to 24.10.0 (#14532) 2 mesiacov pred

README.md

tldr-pages

[![Build status][github-actions-image]][github-actions-url] [![Matrix chat][matrix-image]][matrix-url] [![Merged PRs][prs-merged-image]][prs-merged-url] [![GitHub contributors][contributors-image]][contributors-url] [![license][license-image]][license-url] [![Mastodon][mastodon-image]][mastodon-url]

What is tldr-pages?

The tldr-pages project is a collection of community-maintained help pages for command-line tools, that aims to be a simpler, more approachable complement to traditional man pages.

Maybe you're new to the command-line world. Perhaps you're just a little rusty or can't always recall the arguments for commands like lsof, or tar?

It certainly doesn't help that, in the past, the first option explained in man tar was:

$ man tar
...
-b blocksize
   Specify the block size, in 512-byte records, for tape drive I/O.
   As a rule, this argument is only needed when reading from or writing to tape drives,
   and usually not even then as the default block size of 20 records (10240 bytes) is very common.
...

There is room for simpler help pages focused on practical examples. How about:

<source media="(prefers-color-scheme: dark)" srcset="https://github.com/tldr-pages/tldr/blob/main/images/tldr-dark.png">
<source media="(prefers-color-scheme: light)" srcset="https://github.com/tldr-pages/tldr/blob/main/images/tldr-light.png">
<img alt="Screenshot of the tldr client displaying the tar command." src="https://github.com/tldr-pages/tldr/blob/main/images/tldr-dark.png">

This repository is just that: an ever-growing collection of examples for the most common UNIX, Linux, macOS, FreeBSD, NetBSD, OpenBSD, SunOS, Android, and Windows command-line tools.

How do I use it?

[!TIP] For browsing without installing a client on your computer, see the web client at https://tldr.inbrowser.app (with offline support using PWA).

A popular and convenient way to access these pages on your computer is to install the official Node.js client:

npm install -g tldr

Alternatively, you can also use the official Python client, which can be installed via pip3 (or other package managers):

pip3 install tldr

Linux and Mac users can also install the official Rust Client using Homebrew (or other package managers on other operating systems):

brew install tlrc

Then you have direct access to simplified, easy-to-read help for commands, such as tar, accessible through typing tldr tar instead of the standard man tar.

If you don't want to install any software, check out the PDF version instead.

[!NOTE] PDFs for translations are available for most languages. You can find them in the release assets of the latest release.

There are also various other clients provided by the community, both for the command-line and for other platforms. For a comprehensive list of clients, head over to our Wiki.

How do I contribute to tldr-pages?

All contributions are welcome!

Some ways to contribute include:

  • Adding your favorite command that isn't covered.
  • Adding examples or improving the content of an existing page.
  • Adding requested pages from our issues with the help wanted label.
  • Translating pages into different languages.

All tldr pages are written in Markdown so that they can be edited quite easily and changes can be submitted in pull requests here using Git on the command-line or using the GitHub web interface.

We strive to maintain a welcoming and collaborative community. If it's your first time contributing, have a look at the contributing guidelines, and go ahead!

If you'd like to contribute to translations, you can visit https://lukwebsforge.github.io/tldri18n/ to see the overall progress of all translations, and which translations are missing or outdated.

You are also welcome to join us on the matrix chatroom!

Similar projects

  • Command Line Interface Pages allows you to write standardized help pages for CLI, directories, and configs.

  • Cheat allows you to create and view interactive cheatsheets on the command-line. It was designed to help remind Unix system administrators of options for commands that they use frequently, but not frequently enough to remember.

  • cheat.sh Aggregates cheat sheets from multiple sources (including tldr-pages) into 1 unified interface.

  • devhints Rico's cheatsheets are not just focused on the command-line and include a plethora of other cheatsheets related to programming.

  • eg provides detailed examples with explanations on the command-line. Examples come from the repository, but eg supports displaying custom examples and commands alongside the defaults.

  • kb is a minimalist command-line knowledge base manager. kb can be used to organize your notes and cheatsheets in a minimalist and clean way. It also supports non-text files.

  • navi is an interactive cheatsheet tool, which allows you to browse through specific examples or complete commands on the fly.

  • bropages (deprecated) are a highly readable supplement to man pages. It shows concise, common-case examples for Unix commands. The examples are submitted by the user base, and can be voted up or down; the best entries are what people see first when they look up a command.

What does "tldr" mean?

TL;DR stands for "Too Long; Didn't Read". It originated as Internet slang, where it is used to indicate that a long text (or parts of it) has been skipped as too lengthy. Read more in How-To Geek's article.