Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dawsbot/pluc

:ok_hand: Instant terminal aliases
https://github.com/dawsbot/pluc

alias developer-tools shell terminal

Last synced: about 2 months ago
JSON representation

:ok_hand: Instant terminal aliases

Awesome Lists containing this project

README

        


logo

> :ok_hand: Create permanent terminal aliases instantly

⚠️Under construction, beware of breaking changes ⚠️


[![NPM version][npm-image]][npm-url] [![Build Status][travis-image]][travis-url]

## Usage

Save a new alias forever

```sh
$ pluc
```

Leave out "`command`" and pluc will use your last command from shell history.

```sh
$ pluc
```


Here's what this could look like:

```sh
$ pluc serve "python -m SimpleHTTPServer"

πŸ‘Œ Aliased "serve" to "python -m SimpleHTTPServer" πŸ‘Œ
```

or

```sh
$ pluc ya "yarn add"

πŸ‘Œ Aliased "ya" to "yarn add" πŸ‘Œ

$ ya react #Your new alias is instantly usable

```


## Install

1. npm install

```sh
$ npm install --global pluc
```

2. Source pluc in your shell

Now source the pluc output file in your shell. Paste this in your bash profile (~/.bashrc, ~/.zshrc, ~/.bash_profile, , or ~/.profile).

```sh
source "$(pluc-cli --destinationPath)" #source pluc aliases on shell startup
function pluc() { #call pluc-cli and source new alias immediatly
pluc-cli "$@"
source "$(pluc-cli --destinationPath)"
}
```

Should you ignore the above bash code, you'd need to manually resource the pluc shell file per session **and** after adding a new alias.


## Verify Installation

```sh
$ pluc --sourcePath
# Should output a json filepath, not an error.
```

Your bash aliases are generated from that JSON object. You don't need to pay attention to that in most cases. That's covered in depth in the "About" section below.


## More Examples

Imagine you ssh to this machine often:

```sh
$ ssh [email protected]
# ssh: Successfully ssh'd to example.org!
```

But truly, you do that most days. Why should you type it out?

```sh
$ pluc sshme
# πŸ‘Œ Aliased "sshme" to "ssh [email protected]" πŸ‘Œ

$ sshme
# ssh: Successfully ssh'd to example.org!
```

Not only is the alias `sshme` instantly available, it's forever available in any new sessions. The alternative is to save an `alias` in your bash profile. It's not only time consuming to open and edit, but you won't be able to use that alias until you `source` it.


Or let's say you do web development and need a web server often:

```sh
$ pluc serve "python -m SimpleHTTPServer"
# πŸ‘Œ Aliased "serve" to "python -m SimpleHTTPServer" πŸ‘Œ

$ serve
# Serving HTTP on 0.0.0.0 port 8000 ...
```

Although it's always recommended that you quote the command for safety with bash argument splitting, your second argument **can** contain spaces! Parsing of this is done on your behalf by `pluc`. If your command contains flags though, you must quote it, which is why it's not a good habit.


If you want to see the full list of commands:

```sh
$ pluc --help
```


## About

`pluc` uses a single JSON object to store aliases. Since JSON is already key-value based, it's a perfect data format. To manually edit the JSON source file (**you absolutely will eventually**) enter

```sh
$ $EDITOR $(pluc --sourcePath)
```

After any new alias is added to `pluc`, the `render` function is called which builds a shell file. The shell output is what you `source`'d at the very beginning. To see it right now, enter

```sh
$ $EDITOR $(pluc --destinationPath)
```

:warning: Do not edit the output shell file, it gets deleted on re-render (often) :warning:


## Backup important aliases

Are you saving important aliases or a large amount of them? If so, back these up.

#### Backup to Dropbox

First find the path your config file is saved in:

```sh
$ pluc --sourcePath
# /Users/dawsonbotsford/Library/Preferences/pluc-nodejs/config.json
```

This file needs to be moved into Dropbox and symlinked back to the original location

```sh
mv /Users/dawsonbotsford/Library/Preferences/pluc-nodejs/config.json ~/Dropbox/
ln -s ~/Dropbox/config.json /Users/dawsonbotsford/Library/Preferences/pluc-nodejs/config.json
```

#### Backup to git

Alternatively, use git to manually version control.

```sh
$ pluc --sourcePath
# /Users/dawsonbotsford/Library/Preferences/pluc-nodejs/config.json
$ cd /Users/dawsonbotsford/Library/Preferences/pluc-nodejs
$ git init
# add remote, and push!
```


## FAQ

* Why not use the `source` command in my terminal?
* `source` is only available within your current shell. As soon as you start a new session, your alias is gone.

* How can I edit my aliases?
* `$ $EDITOR $(pluc --sourcePath)`

* Why store the data as a JSON object?
* If JSON objects are used as the source of truth, a variety of render methods can be used. This means that **any** output format (`vimrc`, sublime snippets, etc.) which is key-value based can be generated using `pluc`.

* What's one of these "pluc JSON objects" actually look like?

```json
{
"gi": "git init",
"ga": "git add"
}
```

* The history inferred by `pluc ` alone is not accurate.
* History is obtained with [@dawsbot/shell-history](https://github.com/dawsbot/shell-history). Please open an issue there.

## Compatibility Issues

* `pluc` will not create valid aliases on Windows. Windows does not save terminal history.

* `pluc` will not work with `fish` shell. It likely will not work for shells beyond bash or zsh. This is because of the `parse` function in [`@dawsbot/shell-history`](https:///github.com/dawsbot/shell-history) package. PR's welcome.

## License

MIT Β© [Dawson Botsford](http://dawsonbotsford.com)

[npm-image]: https://badge.fury.io/js/pluc.svg
[npm-url]: https://npmjs.org/package/pluc
[travis-image]: https://travis-ci.org/dawsbot/pluc.svg?branch=master
[travis-url]: https://travis-ci.org/dawsbot/pluc
[xo-image]: https://img.shields.io/badge/code_style-XO-5ed9c7.svg
[xo-url]: https://github.com/sindresorhus/xo