2018-01-21 18:29:48 -07:00
|
|
|
---
|
2018-03-11 16:16:41 -07:00
|
|
|
title: A Friendly Guide to LARBS
|
|
|
|
author: Luke Smith ([https://lukesmith.xyz](https://lukesmith.xyz))
|
2018-01-21 18:29:48 -07:00
|
|
|
output: pdf_document
|
|
|
|
linkcolor: blue
|
|
|
|
---
|
|
|
|
|
2018-08-01 20:37:35 -04:00
|
|
|
Use vim keys (`h`/`j`/`k`/`l`) to navigate this document. Pressing `s` will fit
|
|
|
|
it to window width (`a` to revert). `K` and `J` zoom in and out. `Mod+f` to
|
|
|
|
toggle fullscreen. `q` to quit. (These are general zathura shortcuts.)
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+F1` will show this document at any time.
|
|
|
|
+ By `Mod` I mean the Super Key, usually known as "the Windows Key."
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
Questions or suggestions? Email me at
|
|
|
|
[luke@lukesmith.xyz](mailto:luke@lukesmith.xyz).
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
# Welcome!
|
|
|
|
|
2018-01-21 18:29:48 -07:00
|
|
|
## Basic goals and principles of this system:
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ Naturalness -- Remove the border between mind and matter: everything
|
|
|
|
important should be as few keypresses as possible away from you, and you
|
|
|
|
shouldn't have to think about what you're doing. Immersion.
|
|
|
|
+ Economy -- Programs should be simple and light on system resources and highly
|
|
|
|
extensible. Because of this, many are terminal or small ncurses programs that
|
|
|
|
have all the magic inside of them.
|
|
|
|
+ Keyboard/vim-centrality -- All terminal programs (and other programs) use vim
|
|
|
|
keys when possible. Your hands never need leave the home row or thereabout.
|
2018-11-08 10:07:52 -05:00
|
|
|
+ Decentralization -- This system is a web of small, modifiable and
|
2018-07-05 13:03:35 -04:00
|
|
|
replaceable programs that users can easily customize.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
## General keyboard changes
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ Capslock is a useless key in high quality space. It's now remapped. If you
|
|
|
|
press it alone, it will function as escape, making vimcraft much more
|
|
|
|
natural, but you can also hold it down and it will act as another
|
|
|
|
Windows/super/mod key.
|
|
|
|
+ The menu button (usually between the right Alt and Ctrl) is an alternative
|
|
|
|
Super/Mod button. This is to make one-handing on my laptops easier.
|
|
|
|
+ The system also uses the US International keyboard by default. This allows
|
|
|
|
you to type a lot of characters in many different European languages.
|
2018-03-11 16:16:41 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
If you'd like to change any of these keyboard changes, you need only open and
|
2018-11-08 10:07:52 -05:00
|
|
|
change `~/.scripts/tools/remaps`. Actually, this should go without saying, but
|
2018-07-05 13:03:35 -04:00
|
|
|
*everything* here can easily be changed.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-08-04 19:55:13 -04:00
|
|
|
Additionally, while this isn't a part of i3, the default editing mode in the
|
|
|
|
shell is using vi bindings. If you want to learn more of this, run
|
|
|
|
`Mod+Super+E` and type and select the option for "vi mode in shell". This
|
|
|
|
setting can be changed if you don't like it by deleting or commenting out the
|
|
|
|
contents of `~/.inputrc`.
|
|
|
|
|
2018-05-07 09:07:47 -07:00
|
|
|
## The Status Bar
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
If you're new to i3, notice the status bar on the top of the screen. To the
|
|
|
|
left side, you'll see the numbers of your current workspace(s). On the right
|
|
|
|
side, you'll see various system status notifiers, the date, volume, even music
|
|
|
|
and local weather if possible etc. I'm sure you can figure it out. Several
|
|
|
|
modules will be click-sensitive, although if you're using my system as
|
2018-11-08 10:07:52 -05:00
|
|
|
indented, you probably won't be doing much clicking.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
The i3blocks config is `~/.config/i3blocks/config`, which you can access by the
|
|
|
|
terminal shortcut `cfib`. Notice that the config file refers to several module
|
2018-07-18 19:15:24 -04:00
|
|
|
scripts in the `~/.scripts/` directory. You can read a summary of all of these
|
|
|
|
scripts in the file `~/.scripts/SCRIPTS.md`.
|
2018-03-11 16:16:41 -07:00
|
|
|
|
2018-07-08 09:44:04 -04:00
|
|
|
## Deeper Tutorials
|
|
|
|
|
|
|
|
In addition to this guide and reading the dotfiles of programs manually, you
|
|
|
|
can also get program-specific information by running the `getkeys` command.
|
|
|
|
This will give you the bindings of what program you want. You can also press
|
|
|
|
`Mod+E` (that's a capital `E`) to get be able to watch tutorial videos on
|
|
|
|
specific programs or concepts directly from YouTube.
|
|
|
|
|
2018-01-21 18:29:48 -07:00
|
|
|
# Key Bindings
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
All of the bindings below are in the file `~/.config/i3/config` (easily
|
|
|
|
accessible by typing `cfi` in the terminal) and can all be easily changed.
|
2018-03-11 16:16:41 -07:00
|
|
|
|
2018-01-21 18:29:48 -07:00
|
|
|
## Window basics
|
|
|
|
|
2018-07-08 09:44:04 -04:00
|
|
|
Notice the case sensitivity of the shortcuts.^[To type capital letters, hold
|
2018-11-08 10:07:52 -05:00
|
|
|
down the `Shift` key---that might sound like an obvious and condescending thing
|
2018-07-08 09:44:04 -04:00
|
|
|
to tell you, but there have literally been multiple people (Boomers) who have
|
|
|
|
emailed me asking how to type a capital letter since caps lock isn't enabled.]
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
Be sure you play around with these. Be flexible with the basic commands and the
|
|
|
|
system will grow on you quick.
|
|
|
|
|
|
|
|
+ `Mod+Enter` -- Spawn terminal
|
|
|
|
+ `Mod+q/Q` -- Close window
|
|
|
|
+ `Mod+d` -- rofi (For running commands or programs without shortcuts)
|
|
|
|
+ `Mod+t` -- Toggle between spawning vertically and horizontally
|
|
|
|
+ `Mod+f` -- Fullscreen
|
|
|
|
+ `Mod+h/j/k/l` -- Move to different windows
|
|
|
|
+ `Mod+H/J/K/L` -- Move a window around
|
|
|
|
+ `Mod+Y/U/I/O` -- Resize windows
|
|
|
|
+ `Mod+/` -- Spawn vertical terminal
|
|
|
|
+ `Mod+'` -- Spawn horizontal terminal
|
|
|
|
+ `Mod+s/S` -- Increase/decrease inner gaps
|
|
|
|
+ `Mod+z/Z` -- Increase/decrease outer gaps
|
|
|
|
+ `Mod+D` -- Reduce gaps to 0 pixels
|
|
|
|
+ `Mod+T` -- Restore gaps to default (15 pixels)
|
2018-11-08 10:07:52 -05:00
|
|
|
+ `Mod+Shift+Space` -- Make a window float (it will still be resizeable)
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+Space` -- Switch focus from a floating window to a non-floating one (or
|
|
|
|
vice versa)
|
|
|
|
+ `Mod+o` -- Make floating window sticky (will stay on active workspace)
|
|
|
|
+ `Mod+b` -- Toggle status bar
|
|
|
|
+ `Mod+B` -- Make window float in bottom left corner (good for video watched
|
|
|
|
intermittently)
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Basic Programs
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
*Note:* LARBS will install nearly all of these programs by default, but some
|
2018-11-05 17:51:24 -05:00
|
|
|
only come if you chose an extra option. Naturally, you can use `yay` to look
|
2018-07-05 13:03:35 -04:00
|
|
|
for and install any you want to add.
|
|
|
|
|
|
|
|
+ `Mod+r` -- ranger (file browser/manager)
|
|
|
|
+ `Mod+e` -- mutt (email)
|
|
|
|
+ `Mod+m` -- ncmpcpp (music player)
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+w` -- nmtui (for connecting to wireless internet)
|
|
|
|
+ `Mod+a` -- R/Python calculator (hide with `mod+a`)
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+i` -- htop (system info)
|
|
|
|
+ `Mod+n` -- newsboat (RSS feed reader)
|
|
|
|
+ `Mod+y` -- calcurse (calendar and schedule)
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+u` -- "Dropdown" terminal (hide with `mod+u`)
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+A` -- pulsemixer (audio system control)
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+W` -- Web Browser
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+G` -- GIMP (for general image manipulation)
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## System
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+R` -- ranger as root user
|
|
|
|
+ `Mod+x` -- i3lock (Enter password to return)
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+X` -- shutdown (will ask to confirm)
|
|
|
|
+ `Mod+Shift+Backspace` -- reboot (will ask to confirm)
|
|
|
|
+ `Mod+Shift+Escape` -- exit i3 (will ask to confirm)
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+F1` -- Shows this document
|
|
|
|
+ `Mod+F2` -- Refresh i3
|
|
|
|
+ `Mod+F3` -- Select screen/display to use
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+F4` -- Hibernate (will ask to confirm)
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+F5` -- Reset Network Manager, search for new networks
|
|
|
|
+ `Mod+F6` -- transmission torrent client (cli)
|
2018-09-15 10:04:10 -04:00
|
|
|
+ `Mod+F7` -- Toggle on/off transmission client via dmenu
|
|
|
|
+ `Mod+F8` -- Check mail, if
|
2018-08-01 20:37:35 -04:00
|
|
|
[mutt-wizard](https://github.com/lukesmithxyz/mutt-wizard) is installed
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+F9` -- Mount a USB drive/hard drive or Android
|
|
|
|
+ `Mod+F10` -- Unmount a non-essential drive or Android
|
2018-10-11 19:45:23 -04:00
|
|
|
+ `Mod+F11` -- Search term on DuckDuckGo
|
2018-08-01 20:37:35 -04:00
|
|
|
+ `Mod+F12` -- Wifi-menu for selecting the wireless internet source.
|
|
|
|
|
2018-01-21 18:29:48 -07:00
|
|
|
## Audio
|
|
|
|
|
2018-11-08 10:07:52 -05:00
|
|
|
I use ncmpcpp as a music player, which is a front end for mpd.
|
2018-07-05 13:03:35 -04:00
|
|
|
|
|
|
|
+ `Mod+m` -- ncmpcpp music player
|
|
|
|
+ `Mod+.` -- Next track
|
|
|
|
+ `Mod+,` -- Previous track
|
|
|
|
+ `Mod+<` -- Restart track
|
|
|
|
+ `Mod+p` -- Pause
|
|
|
|
+ `Mod+M` -- Mute all audio
|
|
|
|
+ `Mod+v` -- visualizer
|
|
|
|
+ `Mod+-` -- Decrease volume (holding shift increases amount)
|
|
|
|
+ `Mod++` -- Increase volume (holding shift increases amount)
|
|
|
|
+ `Mod+[` -- Back 10 seconds (holding shift increases amount)
|
|
|
|
+ `Mod+]` -- Forward 10 seconds (holding shift increases amount)
|
|
|
|
+ `Mod+A` -- ncpamixer (general volume sink/source control)
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Workspaces
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
There are ten workspaces. They work just like those in vanilla i3 with some
|
|
|
|
additions.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+(Number)` -- Go to that number workspace
|
|
|
|
+ `Mod+Shift+(Number)` -- Send window to that workspace
|
|
|
|
+ `Mod+Tab` -- Go to previous workspace
|
|
|
|
+ `Mod+g` -- Go to left workspace
|
|
|
|
+ `Mod+;` -- Go to right workspace
|
|
|
|
+ `Mod+Shift+Delete` -- "Porno-mode" Press this key sequence if you want to hide
|
|
|
|
what you have on your screen. Moves to a totally new workspace, mutes sound,
|
|
|
|
pauses music and brings up distraction windows.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Recording
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
I use scrot and ffmpeg to make different recordings of the desktop and audio.
|
|
|
|
All of these recording shortcuts will output into `~`, and will not overwrite
|
2018-11-05 17:51:24 -05:00
|
|
|
previous recordings as their names are based on their exact times.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-08 09:44:04 -04:00
|
|
|
+ `PrintScreen` -- Take a scrot screenshot
|
2018-09-15 10:04:56 -04:00
|
|
|
+ `Shift+PrintScreen` -- Take a scrot screenshot of only selected window
|
|
|
|
+ `Mod+PrintScreen` -- Opens dmenu menu to select kind of audio/video recording
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+Delete` -- Kills any recording started in the above way.
|
2018-07-05 13:03:35 -04:00
|
|
|
+ `Mod+ScrollLock` -- Turn on and off screenkey (if installed) for visual typing display
|
2018-11-05 17:51:24 -05:00
|
|
|
+ `Mod+Shift+c` -- Toggles a webcam in the bottom right for screencasting.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Other buttons
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
I've mapped those extra buttons that some keyboards have (play and pause
|
2018-11-05 17:51:24 -05:00
|
|
|
buttons, screen brightness, email, web browsing buttons, etc.) to what you
|
|
|
|
would expect.
|
2018-03-09 17:22:57 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
# Special traits of this system
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Easy config access
|
|
|
|
|
2018-11-05 17:51:24 -05:00
|
|
|
Open a terminal and type `bf`. This will open a file where you will see
|
|
|
|
customizable pairs of key shortcuts and config files and other important text
|
|
|
|
files. Enter any of these shortcuts in bash or ranger to immediately open the
|
|
|
|
file in vim.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
You may add new entries here and they will be refreshed when you save the file
|
|
|
|
in vim. This will take effect immediately once you start a new instance of bash
|
2018-11-05 17:51:24 -05:00
|
|
|
or ranger or reload your previous sessions.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Folder and config shortcuts
|
|
|
|
|
2018-11-05 17:51:24 -05:00
|
|
|
Open a terminal and type `bd`. This opens a file when you can keep and create
|
|
|
|
directory/folder shortcuts. There are only a few here now, because I don't know
|
|
|
|
what your folder structure is going to look like, but on my machine, I have 109
|
|
|
|
and growing.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-11-05 17:51:24 -05:00
|
|
|
Each line has a shortcut key/keys and its target. These can be used in several
|
2018-07-05 13:03:35 -04:00
|
|
|
applications. In bash, simply press `d`, the shortcut for `~/Documents` and you
|
|
|
|
will cd there (and automatically `ls -a`).
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
ranger works similarly. When in ranger, just press `g` then the shortcut of the
|
|
|
|
folder you want to go to. You may also press `t` plus the shortcut to open a
|
|
|
|
new tab there. `m` plus the shortcut moves the selected files to the folder and
|
|
|
|
`Y` copies them there. **Get good at this. It will make management of even the
|
|
|
|
most complex file system easy.**
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
Lastly qutebrowser implements these shortcuts as well. When you see a file or
|
|
|
|
image you want to download, press `;` followed by the folder shortcut and
|
|
|
|
qutebrowser will let you select the file with its hint system. The file will
|
|
|
|
then download to the directory you chose.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
|
|
|
## Dynamically constructed configs
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
Each time you save changes to either the config shortcut file or the folder
|
|
|
|
shortcut file in vim, vim will automatically run a bash script that updates
|
|
|
|
your bash/ranger config, allowing you to use your new shortcuts in your next
|
|
|
|
instance of bash/ranger or after resourcing your rc files.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
# Other Housekeeping
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
## How do I change the background/wallpaper?
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
The easiest way is to use ranger, navigate to the file you want as your
|
|
|
|
background, and press `bg`. To be specific, i3 will always be looking to the
|
|
|
|
file in `~/.config/wall.png` for the wallpaper, this ranger command copies the
|
|
|
|
given file there and reruns feh to update it.
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
## How do I set up my email?
|
2018-03-09 17:22:57 -07:00
|
|
|
|
2018-03-11 16:16:41 -07:00
|
|
|
1. Create a GPG private/public key pair if you haven't already.
|
2018-08-01 20:37:35 -04:00
|
|
|
2. Download the mutt-wizard repository to the mutt config directory:
|
|
|
|
|
|
|
|
```
|
|
|
|
git clone https://github.com/lukesmithxyz/mutt-wizard ~/.config/mutt
|
|
|
|
```
|
|
|
|
|
|
|
|
3. There run `mutt-wizard.sh` and follow the directions, specifically:
|
2018-07-05 13:03:35 -04:00
|
|
|
a. Add an account.
|
|
|
|
b. Run `offlineimap -o` in the terminal.
|
|
|
|
c. Select the "Autodetect mailboxes" option.
|
2018-03-09 17:22:57 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
You should then be able to open your mail in mutt with Mod+e. And this is
|
|
|
|
somewhat of a miracle considering all of the moving pieces that have come
|
|
|
|
together to make this happen. Honestly, people give me all this credit for
|
|
|
|
making LARBS, but the mutt-wizard is probably my favorite work.
|
2018-03-11 16:16:41 -07:00
|
|
|
|
2018-08-01 20:37:35 -04:00
|
|
|
You can, through the mutt-wizard, schedule automatic mail checks every several
|
|
|
|
minutes. You can also press `Mod-F8` at any time to check for new mail in your
|
|
|
|
accounts. You might also want to run `notmuch setup` to set `notmuch` up as a
|
2018-11-08 10:07:52 -05:00
|
|
|
mail indexer. This will allow quick searches of your mail in mutt with `ctrl+f`.
|
2018-07-24 14:14:13 -04:00
|
|
|
The mailsync script will update the notmuch database once you do this.
|
2018-03-11 16:16:41 -07:00
|
|
|
|
|
|
|
## How do I set up my music?
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
By default, mpd, the music daemon assumes that `~/Music` is your music
|
|
|
|
directory. This can be changed in `~/.config/mpd/mpd.conf`. When you add music
|
|
|
|
to your music folder, you may have to run `mpc up` in the terminal to update
|
2018-11-08 10:07:52 -05:00
|
|
|
the database. mpd is controlled by ncmpcpp, which is accessible by Mod+m.
|
2018-03-09 17:22:57 -07:00
|
|
|
|
2018-01-21 18:29:48 -07:00
|
|
|
# Contact
|
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ [luke@lukesmith.xyz](mailto:luke@lukesmith.xyz) -- For questions!
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-08 09:44:04 -04:00
|
|
|
+ [https://lukesmith.xyz](http://lukesmith.xyz) -- For stalking!
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ [PayPal](https://paypal.me/LukeMSmith) -- For gratitude!
|
2018-03-11 16:16:41 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ [Patreon](https://patreon.com/lukesmith) -- For support!
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ [My Github Page](https://github.com/LukeSmithxyz) -- For the code behind it!
|
2018-01-21 18:29:48 -07:00
|
|
|
|
2018-07-05 13:03:35 -04:00
|
|
|
+ [RSS](http://lukesmith.xyz/rss.xml) -- For even better updates!
|