Hint exists to get help on commands from the command line, without switching context or applications.
Project status
This is currently a POC project I’m using to see what I find useful and how I want the project to develop. For all intents and purposes this tool is completely unsupported. I make no guarantees about backwards compatibility or commitment to responding to issues or PRs. It is a personal project which I’m happy to share, as open source software licensed with the MIT license if you find it useful and/or want any changes I would suggest forking this repo.
Installation
Recommended installation method is with pipx.
pipx install hint-cli
Usage
The first time you run hint <topic>
it will prompt for configuration values for the following:
- Git repository for the hint source - Address of the remote repository to clone containing your hint content. Use the sample repo from GitHub of
git@github.com:agarthetiger/hint-cli-samples.git
to get started. It is expected that you will create your own content and configure your own repo later. The only topic in the example repo isbash
. Note that while both the ssh and https clone addresses will work to view content, much of the functionality to add and modify content will require the ssh style repo address.
Then run hint <topic>
where topic is the name of a markdown file in the repository root, without the .md file extension.
hint bash
- Display the formatted contents of https://raw.githubusercontent.com/agarthetiger/hint/trunk/docs/examples/bash.mdhint bash curl
- Display only thecurl
subsection from the bash.md file. Valid subsections are any level headings in the markdown document. To display only an H4 subsection, just use the H4 heading text as the 2nd argument.hint --help
- Get help
Upgrading
This project is still in an unstable state and minor version bumps may be breaking until 1.0.0 is released. When upgrading I recommend deleting the config file ~/.hintrc
before running the new version, so that the correct config options are set.
From 1.0.0 onwards, releases will be versioned semantically according to semver.org 2.0.0.
Creating content
hint
is written for you to create your own content, for whatever useful information you would like to access from the command line. It is expected that you will setup your own repository with your own hints.
The repository is expected to contain markdown files with a .md file extension in the root of the repository. Each file name is considered a topic, and each heading a subsection. There is some basic formatting applied to the markdown before being displayed using Click’s echo and style support.
- Section headings are displayed in bold and cyan.
- Text surrounded by ` characters is displayed in bold and blue.
- All other text is displayed as typed in the markdown file.
Switching hint repositories
Version 0.4.0 changes from using requests to using GitPython to clone the remote repository for the hint content. If you are using >=0.4.0 and want to change the remote repository, update the value for repo
in ~/.hintrc
and delete the folder ~/.hints.d/hints
before running hint again.
Alternatives
If you want a tool which pulls community content rather than writing your own, look at cheat.sh. It provides “unified access to the best community driven cheat sheets repositories of the world”.
System Requirements
- Python3
- Pip3
- Access to pypi.org or another pip repo with the
hint-cli
python package and dependencies - Network access to the hints git repository. This may be internet access to GitHub.com but could also be an internal Git server.
Concept
I use GitHub Pages and MKDocs as well as other Notes applications to collect technical information which I personally find useful. I have a few cheat-sheets with reminders on commands I use regularly but infrequently. The man
and info
commands provide help on most commands, however they are very detailed and more useful commands often involve multiple cli tools. Examples bridge the gap between the low level documentation and complex infrequent commands which won’t necessarily be in the command history for the current system.
Often I’m using a terminal within PyCharm or VS Code and it’s undesirable to switch context to a different application, navigate to a site which may not be open, get the right page and click or scroll to the relevant section. It’s not an insurmountable problem, but a workflow which I wanted to optimise.
This tool was inspired in multiple ways by Thomas Stringer’s post on My Personal Wiki … Now Through the Terminal. The fact that I stumbled across this while searching for something else is validation for having a tool and workflow which enables me to remain in the IDE and not switch to a browser. It’s similar to taking an alcoholic to a pub and constantly offering them a drink, then saying it’s his fault if he ends up drinking. Sure, there is some level of personal responsibility with the alcoholic to resist but a better solution would be to avoid the pub. hint
keeps me focused, puts the information I need at my fingertips away from distractions.
Backlog of ideas for improvement
Err, it’s vast. My ability to dream up cool things I could add to hint easily outstrips my available time to implement them. The ones I think are worthy of at least writing down will end up on the project page.