2018-10-01 12:05:34 +02:00
# sudo
2021-12-29 16:26:35 +01:00
Easily prefix your current or previous commands with `sudo` by pressing < kbd > esc</ kbd > twice.
2018-10-01 12:05:34 +02:00
2020-03-11 19:57:46 +01:00
To use it, add `sudo` to the plugins array in your zshrc file:
2018-10-01 12:05:34 +02:00
2020-03-11 19:57:46 +01:00
```zsh
plugins=(... sudo)
```
2018-10-01 12:05:34 +02:00
2020-03-11 19:57:46 +01:00
## Usage
2018-10-01 12:05:34 +02:00
### Current typed commands
Say you have typed a long command and forgot to add `sudo` in front:
```console
$ apt-get install build-essential
```
By pressing the < kbd > esc</ kbd > key twice, you will have the same command with `sudo` prefixed without typing:
```console
$ sudo apt-get install build-essential
```
2022-01-18 18:46:14 +01:00
The same happens for editing files with your default editor (defined in `$SUDO_EDITOR` , `$VISUAL` or `$EDITOR` , in that order):
If the editor defined were `vim` :
```console
$ vim /etc/hosts
```
By pressing the < kbd > esc</ kbd > key twice, you will have the same command with `sudo -e` instead of the editor, that would open that editor with root privileges:
```console
$ sudo -e /etc/hosts
```
2018-10-01 12:05:34 +02:00
### Previous executed commands
Say you want to delete a system file and denied:
```console
$ rm some-system-file.txt
-su: some-system-file.txt: Permission denied
$
```
By pressing the < kbd > esc</ kbd > key twice, you will have the same command with `sudo` prefixed without typing:
```console
$ rm some-system-file.txt
-su: some-system-file.txt: Permission denied
$ sudo rm some-system-file.txt
Password:
$
```
2021-12-29 16:26:35 +01:00
2022-01-18 18:46:14 +01:00
The same happens for file editing, as told before.
2021-12-29 16:26:35 +01:00
## Key binding
By default, the `sudo` plugin uses < kbd > Esc</ kbd >< kbd > Esc</ kbd > as the trigger.
If you want to change it, you can use the `bindkey` command to bind it to a different key:
```sh
bindkey -M emacs '< seq > ' sudo-command-line
bindkey -M vicmd '< seq > ' sudo-command-line
bindkey -M viins '< seq > ' sudo-command-line
```
where `<seq>` is the sequence you want to use. You can find the keyboard sequence
by running `cat` and pressing the keyboard combination you want to use.