2013-08-11 01:08:21 +02:00
|
|
|
cheat
|
2013-07-31 04:48:07 +02:00
|
|
|
=====
|
2013-08-11 00:56:50 +02:00
|
|
|
`cheat` allows you to create and view interactive cheatsheets on the
|
2013-08-11 21:57:11 +02:00
|
|
|
command-line. It was designed to help remind \*nix system administrators of
|
2013-08-11 00:56:50 +02:00
|
|
|
options for commands that they use frequently, but not frequently enough to
|
|
|
|
remember.
|
|
|
|
|
|
|
|
![The obligatory xkcd](http://imgs.xkcd.com/comics/tar.png 'The obligatory xkcd')
|
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
`cheat` depends only on `python` and `pip`.
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2014-05-29 03:59:40 +02:00
|
|
|
PyPI status:
|
|
|
|
|
|
|
|
[![Latest Version](https://pypip.in/version/cheat/badge.png)](https://pypi.python.org/pypi/cheat/)
|
|
|
|
[![Downloads](https://pypip.in/download/cheat/badge.png)](https://pypi.python.org/pypi/cheat/)
|
2013-08-11 21:57:11 +02:00
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
Example
|
|
|
|
-------
|
2013-08-11 00:56:50 +02:00
|
|
|
The next time you're forced to disarm a nuclear weapon without consulting
|
|
|
|
Google, you may run:
|
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
cheat tar
|
2013-08-11 00:56:50 +02:00
|
|
|
|
|
|
|
You will be presented with a cheatsheet resembling:
|
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
```
|
2013-08-24 17:10:16 +02:00
|
|
|
# To extract an uncompressed archive:
|
2013-08-11 00:56:50 +02:00
|
|
|
tar -xvf /path/to/foo.tar
|
|
|
|
|
2013-08-24 17:10:16 +02:00
|
|
|
# To extract a .gz archive:
|
2013-08-11 00:56:50 +02:00
|
|
|
tar -xzvf /path/to/foo.tgz
|
|
|
|
|
2013-08-24 17:10:16 +02:00
|
|
|
# To create a .gz archive:
|
2013-08-11 00:56:50 +02:00
|
|
|
tar -czvf /path/to/foo.tgz /path/to/foo/
|
|
|
|
|
2013-08-24 17:10:16 +02:00
|
|
|
# To extract a .bz2 archive:
|
2013-08-11 00:56:50 +02:00
|
|
|
tar -xjvf /path/to/foo.tgz
|
|
|
|
|
2013-08-24 17:10:16 +02:00
|
|
|
# To create a .bz2 archive:
|
2013-08-11 00:56:50 +02:00
|
|
|
tar -cjvf /path/to/foo.tgz /path/to/foo/
|
|
|
|
```
|
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
To see what cheatsheets are availble, run `cheat -l`.
|
2013-08-11 00:56:50 +02:00
|
|
|
|
|
|
|
Note that, while `cheat` was designed primarily for *nix system administrators,
|
|
|
|
it is agnostic as to what content it stores. If you would like to use `cheat`
|
|
|
|
to store notes on your favorite cookie recipes, feel free.
|
|
|
|
|
|
|
|
|
|
|
|
Installing
|
2014-04-27 16:47:04 +02:00
|
|
|
----------
|
2014-06-09 06:49:19 +02:00
|
|
|
|
2014-06-04 04:34:50 +02:00
|
|
|
### Using pip ###
|
2014-05-29 04:01:25 +02:00
|
|
|
|
|
|
|
sudo pip install cheat
|
2014-06-04 04:34:50 +02:00
|
|
|
|
2014-06-22 23:17:27 +02:00
|
|
|
### Using homebrew ###
|
|
|
|
|
|
|
|
brew install cheat
|
|
|
|
|
2014-06-04 04:34:50 +02:00
|
|
|
### Manually ###
|
2014-05-29 04:01:25 +02:00
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
First install the required python dependencies with:
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
sudo pip install docopt pygments
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
Then, clone this repository, `cd` into it, and run:
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2013-08-16 10:19:04 +02:00
|
|
|
sudo python setup.py install
|
|
|
|
|
2013-09-07 20:38:13 +02:00
|
|
|
|
2013-08-11 00:56:50 +02:00
|
|
|
Modifying Cheatsheets
|
2014-04-27 16:47:04 +02:00
|
|
|
---------------------
|
2013-08-11 00:56:50 +02:00
|
|
|
The value of `cheat` is that it allows you to create your own cheatsheets - the
|
|
|
|
defaults are meant to serve only as a starting point, and can and should be
|
|
|
|
modified.
|
|
|
|
|
2013-08-11 21:57:11 +02:00
|
|
|
Cheatsheets are stored in the `~/.cheat/` directory, and are named on a
|
|
|
|
per-keyphrase basis. In other words, the content for the `tar` cheatsheet lives
|
2014-04-27 16:47:04 +02:00
|
|
|
in the `~/.cheat/tar` file.
|
|
|
|
|
|
|
|
Provided that you have an `EDITOR` environment variable set, you may edit
|
|
|
|
cheatsheets with:
|
|
|
|
|
|
|
|
cheat -e foo
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
If the 'foo' cheatsheet already exists, it will be opened for editing.
|
|
|
|
Otherwise, it will be created automatically.
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2013-08-11 21:57:11 +02:00
|
|
|
After you've customized your cheatsheets, I urge you to track `~/.cheat/` along
|
2013-08-11 00:56:50 +02:00
|
|
|
with your [dotfiles][].
|
|
|
|
|
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
Configuring
|
|
|
|
-----------
|
2013-08-22 05:00:22 +02:00
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
### Setting a DEFAULT_CHEAT_DIR ###
|
2013-09-01 19:56:49 +02:00
|
|
|
Personal cheatsheets are saved in the `~/.cheat` directory by default, but you
|
|
|
|
can specify a different default by exporting a `DEFAULT_CHEAT_DIR` environment
|
|
|
|
variable:
|
2013-08-29 17:19:19 +02:00
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
export DEFAULT_CHEAT_DIR=/path/to/my/cheats
|
2013-08-29 17:19:19 +02:00
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
### Setting a CHEATPATH ###
|
2013-09-01 19:56:49 +02:00
|
|
|
You can additionally instruct `cheat` to look for cheatsheets in other
|
|
|
|
directories by exporting a `CHEATPATH` environment variable:
|
2013-08-16 00:52:32 +02:00
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
export CHEATPATH=/path/to/my/cheats
|
2013-08-16 00:52:32 +02:00
|
|
|
|
|
|
|
You may, of course, append multiple directories to your `CHEATPATH`:
|
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
export CHEATPATH=$CHEATPATH:/path/to/more/cheats
|
2013-08-16 00:52:32 +02:00
|
|
|
|
2013-09-07 20:38:13 +02:00
|
|
|
You may view which directories are on your `CHEATPATH` with `cheat -d`.
|
|
|
|
|
2014-04-27 16:47:04 +02:00
|
|
|
### Enabling Syntax Highlighting ###
|
2013-08-22 05:02:58 +02:00
|
|
|
`cheat` can apply syntax highlighting to your cheatsheets if so desired. To
|
2013-08-27 03:05:05 +02:00
|
|
|
enable this feature, set a `CHEATCOLORS` environment variable:
|
2013-08-22 05:00:22 +02:00
|
|
|
|
2014-04-27 05:31:13 +02:00
|
|
|
export CHEATCOLORS=true
|
2013-08-22 05:00:22 +02:00
|
|
|
|
2014-05-29 02:47:49 +02:00
|
|
|
### Enabling Command-line Autocompletion ###
|
|
|
|
The `cheat/autocompletion` directory contains scripts to enable command-line
|
|
|
|
autocompletion for various shells. To activate autocompletion, simply copy the
|
|
|
|
appropriate script to the appropriate path on your system. (The "appropriate
|
|
|
|
path" will vary on a per-platform basis, so this documentation shall not
|
|
|
|
speculate as to where that may be.)
|
|
|
|
|
2013-08-16 00:52:32 +02:00
|
|
|
|
2013-08-16 00:38:13 +02:00
|
|
|
Related Projects
|
2014-04-27 16:47:04 +02:00
|
|
|
----------------
|
2013-08-17 03:38:31 +02:00
|
|
|
|
2013-08-16 00:38:13 +02:00
|
|
|
- [lucaswerkmeister/cheats][1]: An implementation of this concept in pure bash
|
|
|
|
that also allows not only for numerical indexing of subcomands but also
|
|
|
|
supports running commands interactively.
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2013-09-15 01:41:00 +02:00
|
|
|
- [jahendrie/cheat][2]: A bash-only implementation that additionally allows for
|
2013-08-16 00:38:13 +02:00
|
|
|
cheatsheets to be created and `grep` searched from the command-line.
|
|
|
|
([jahendrie][] contributed key ideas to this project as well.)
|
2013-08-11 00:56:50 +02:00
|
|
|
|
2013-08-22 05:35:04 +02:00
|
|
|
- [`cheat` RubyGem][3]: A clever gem from 2006 that clearly had similar
|
|
|
|
motivations. It is unclear whether or not it is currently maintained.
|
|
|
|
|
2014-08-07 04:04:19 +02:00
|
|
|
- [`tldr`][tldr]: "Simplified and community-driven man pages".
|
|
|
|
|
2013-08-22 05:35:04 +02:00
|
|
|
|
2013-08-16 00:38:13 +02:00
|
|
|
[dotfiles]: http://dotfiles.github.io/
|
|
|
|
[jahendrie]: https://github.com/jahendrie
|
|
|
|
[1]: https://github.com/lucaswerkmeister/cheats
|
|
|
|
[2]: https://github.com/jahendrie/cheat
|
2013-08-22 05:35:04 +02:00
|
|
|
[3]: http://errtheblog.com/posts/21-cheat
|
2013-09-07 20:38:13 +02:00
|
|
|
[4]: https://github.com/chrisallenlane/cheat/pull/77
|
2014-08-07 04:04:19 +02:00
|
|
|
[tldr]: https://github.com/tldr-pages/tldr
|