Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ExplainDev/kmdr-cli
π§ The CLI tool for learning commands from your terminal
https://github.com/ExplainDev/kmdr-cli
bash bash-shell cli command-line shell terminal
Last synced: about 2 months ago
JSON representation
π§ The CLI tool for learning commands from your terminal
- Host: GitHub
- URL: https://github.com/ExplainDev/kmdr-cli
- Owner: ExplainDev
- License: mit
- Archived: true
- Created: 2017-09-07T17:51:46.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-02-27T08:42:25.000Z (almost 3 years ago)
- Last Synced: 2024-10-30T02:37:02.416Z (about 2 months ago)
- Topics: bash, bash-shell, cli, command-line, shell, terminal
- Language: TypeScript
- Homepage: https://kmdr.sh/
- Size: 11.4 MB
- Stars: 250
- Watchers: 9
- Forks: 28
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# kmdr-cli ![npm](https://img.shields.io/npm/v/kmdr?color=green&style=flat-square)![npm](https://img.shields.io/npm/dt/kmdr?color=blue&style=flat-square)
> The CLI tool for learning commands from your terminal
`kmdr` provides command explanations for hundreds of programs including `git`, `docker`, `kubectl`,`npm`, `go` and more straight forward programs such as those built into `bash`. See the full list at https://app.kmdr.sh/program.
## Installation
You will need to install the kmdr program and sign-in to begin using kmdr on the CLI.
### Requirements
- Node.js v8.x and above
- A package manager like `npm` or `yarn`#### With `npm`
```bash
npm install kmdr --global
```#### With `yarn`
```bash
yarn global add kmdr
```### Check installation
Run the command `kmdr` to check if it was correctly installed on your system.
```bash
$ kmdr
Usage: kmdr [options] [command]The CLI tool for learning commands from your terminal
Learn more at https://kmdr.sh/
Options:
-v, --version output the version number
-h, --help output usage informationCommands:
explain|e Explain a shell command
info|i Display system-wide information
login|l [email] Log in to kmdr
logout Log out from kmdr
settings|s Adjust options and preferences
version|v Print current version and check for newer release
```#### Troubleshooting installation
##### Command not found: kmdr
Add the line below to your `.bashrc` or `.zshrc` if using `zsh`
```bash
export PATH="$(yarn global bin):$PATH"
```### Sign In
1. Log in on the kmdr CLI tool
```bash
kmdr login
```2. Enter your email when prompted
3. Check your inbox and click on the link provided in the email.## Usage
### Explain a command
Once `kmdr-cli` is installed on your system, enter `kmdr explain` to return a prompt for entering the command you would like explained.
When the `Enter your command:` prompt is returned, enter the command you would like explained and hit the `Enter` key.
`kmdr` will return syntax highlighting to assist you in differentiating parts of the command followed by the explanation of each of these parts.
An example explanation of `git commit -am "Initial commit"` can be seen below.
```bash
$ kmdr explain
β Enter your command Β· git commit -am "Initial Commit"git commit -am "Initial Commit"
DEFINITIONS
git
The stupid content tracker
commit
Record changes to the repository
-a, --all
Tell the command to automatically stage files that have been modified and deleted
-m, --message "Initial Commit"
Use the given as the commit message
```### Examples
#### Explaining commands with subcommands
```bash
$ kmdr explain
? Enter your command: npm install kmdr@latest --globalnpm install kmdr@latest --global
DEFINITIONS
npm
Package manager for the Node JavaScript platform
install
Install a package
kmdr@latest
The CLI tool for learning commands from your terminal
-g, --global
Install the package globally rather than locally
```#### Explanining commands with grouped options
```bash
$ kmdr explain
? Enter your command: rsync -anv file1 file2rsync -anv file1 file2
DEFINITIONS
rsync
A fast, versatile, remote (and local) file-copying tool
-a, --archive
This is equivalent to -rlptgoD.
-n, --dry-run
This makes rsync perform a trial run that doesnβt make any changes
(and produces mostly the same output as a real run).
-v, --verbose
This option increases the amount of information you are given during
the transfer.
```#### Explaining commands with redireciton
```bash
$ kmdr explain
? Enter your command: ls -alh > contents.txtls -alh > contents.txt
DEFINITIONS
ls
List directory contents
-a, --all
Do not ignore entries starting with .
-l
Use a long listing format
-h, --human-readable
With -l and/or -s, print human readable sizes (e.g., 1K 234M 2G)
> contents.txt
Redirect stdout to contents.txt.
```#### Explaining list of commands
```bash
$ kmdr explain
? Enter your command: dmesg | grep 'usb' > output.log 2>error.logdmesg | grep 'usb' > output.log 2> error.log
DEFINITIONS
dmesg
Print or control the kernel ring buffer
|
A pipe serves the sdout of the previous command as input (stdin) to the next one
grep
Print lines matching a pattern
> output.log
Redirect stdout to output.log.
2> error.log
Redirect stderr to error.log.
```So what is the reason for signing in? why should it be included in CLI readme?
## Supported programs
We add new programs every day! See the full list here: https://app.kmdr.sh/program.
## Stay tuned for more updates
- Visit our website
- Follow us on twitter