Skip to content

A Bash reimplementation of Chris Lane's cheat sheet script

License

Notifications You must be signed in to change notification settings

GeekaholicLin/cheat

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

================================================================================
    cheat.sh(based version) |   version 1.22    |   GPL v3 (see LICENSE)    | 2017-05-01
    James Hendrie          |   [email protected]
================================================================================


================================================================================
    cheat.sh(custom version) |   version 1.22    |   GPL v3 (see LICENSE)    | 2017-09-21
    GeekaholicLin            |   [email protected]
================================================================================

TOC:
    1.  What is this?
    2.  Install / Uninstall
    3.  How do I use it?
    4.  Who made it?
    5.  What is new in custom version(this repo)?


1.  What is this?

    'cheat' is a cheat-sheet script for people who are too impatient to browse
    the manual page for a given program.  It's well-suited for those who might
    use a program only occasionally, and need only brief reminders on the
    'important bits'; the cliff-notes version of man pages, if you will.

    This particular version, written as a Bash script, is a reimplementation of
    a Python script originally written by Chris Lane.  The other version is the
    'main' version; this is the off-shoot.


2.  Install / Uninstall

    To install this script, as root, run 'make install' from inside the top
    directory to which you've downloaded/extracted the program; it should be the
    same directory where you found this README file.

    To uninstall the program, as root and from that same directory (or whichever
    directory contains the Makefile), run 'make uninstall'.


3.  How do I use it?

    Using this script is straightforward enough, in the typical UNIX/Linux
    fashion:

    cheat [OPTION] FILE[S]

    Options:
        -a or --add:        Add a text file to the cheat sheet directory
        -A:                 Add and compress (gzip) a text file
        -e or --edit:       Edit a cheat sheet, using editor in $EDITOR variable
        -k:                 Grep for keyword(s) in file names
        -g:                 Grep for keyword(s) inside file text
        -G:                 Same as above, but list full paths if found
        -l or --link:       Link a file instead of copying it to the cheat dir
        -L:                 List all cheat sheets with full paths
        -h or --help:       List the help
        --version:          List version and author info
        -u or --update:     Update cheat sheets (safe way)
        -U:                 Overwrite all cheat sheets with downloaded versions


    Examples:

        cheat ap:           List all files with 'ap' in the filename; if there
                            is only one result, it will be displayed
        cheat -k:           List all available cheat sheets (in ~/.cheat)
        cheat -k tar:       Grep for all cheat sheets with 'tar' in the filename
        cheat -k tar sh:    Grep for sheets with 'tar' or 'sh' in filenames
        cheat -a foo:       Add 'foo' to the cheat sheet directory
        cheat -a foo bar:   Add both 'foo' and 'bar' to the cheat sheet dir
        cheat -A *.txt:     Add and compress all .txt files in current dir
        cheat -l foo.png    Create a link to foo.png in the cheat directory


    There are a few useful variables for people who use this script a lot:
    DEFAULT_CHEAT_DIR, CHEATPATH, CHEAT_TEXT_VIEWER, CHEAT_IMAGE_VIEWER and
    CHEAT_PDF_VIEWER.

    DEFAULT_CHEAT_DIR is the directory in which cheat sheets are stored by 
    default.  This is set to $HOME/.cheat if left unspecified by the user.

    CHEATPATH is similar to the PATH variable, except it's used for cheat
    sheets.  If you're referencing cheat sheets from multiple directories, 
    you'll want to make use of this environment variable.  If this variable is
    not set by the user, it's populated by DEFAULT_CHEAT_DIR.  If the user does
    set this variable, it's up to them to include every directory in which cheat
    sheets are kept, as DEFAULT_CHEAT_DIR is not automatically added to the
    CHEATPATH variable.

    CHEAT_TEXT_VIEWER is the program used to view the normal cheat sheets.  It's
    assumed to accept text from stdin ('cat' and 'less' are good options).
    'cat' is used by default.

    CHEAT_IMAGE_VIEWER is the program which is used to display image files, and
    CHEAT_PDF_VIEWER is the program which will display PDFs.  These variables
    are optional, but if you can't get the script to display images/PDFs, set
    them to the programs you want.


4.  Who made it?

    Custom version: GeekaholicLin
                        [email protected]
                        https://github.com/GeekaholicLin

    Based version:   James Hendrie
                        [email protected]
                        https://github.com/jahendrie

    Main version:   Chris Lane
                        [email protected]
                        https://github.com/chrisallenlane

5. What is new in custom version(this repo)?
   
   Thank James Hendrie for this awesome tool.
   
   I have changed something in src/cheat.sh depending on my own status.

   You can use it in git-for-windows instead of the well-known python version maked by chrisallenlane,
   which can not work well in Windows.

   The changes can be list as following:
   - Copy the file when it exits in CHEATPATH but not in DEFAULT_CHEAT_DIR(defualt $HOME/.cheat)
   - Change CHEATPATH always to includes DEFAULT_CHEAT_DIR
   - Use offical cheet sheets and DEFAULT_CHEAT_DIR sheets as default
   - Add some more hints when you edit a exiting cheat or cheat a cheat

   (If the CHEATPATH variable is set, cheats come from DEFAULT_CHEAT_DIR and CHEATPATH you have set.
   Or CHEATPATH will includes DEFAULT_CHEAT_DIR cheets and this repo official data.)
  

About

A Bash reimplementation of Chris Lane's cheat sheet script

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 94.6%
  • Makefile 5.4%