# Custom system config. This is my own custom config that I use on my GNU/Linux machines. Not meant to be used by anyone else. # Table of contents. 1. [Bootstrap.](#bootstrap) 2. [General info.](#general-info) 3. [Load Gnome settings.](#load-gnome-settings) 4. [Navigation.](#navigation) 5. [Nvim config.](#nvim-config) 6. [Bash commands.](#bash-commands) 7. [To-do later.](#to-do-later) # Bootstrap. **CAREFUL!** This will overwrite files with the same name in your home directory! ```text curl -s https://git.voronind.com/voronind/linux/raw/branch/master/.bootstrap.sh | bash && source .bashrc ``` # General info. It includes: 1. Git config (excluding user info). 2. Bash scripts and environment. 3. Tmux config. 4. Basic directory structure as well as redefining them as default. 5. Custom bin directory. 6. Collection of Linux configs (sshd, gnome, sysctl etc). 7. GTK 3/4 configs. 8. Htop config. 9. Nvim config. 10. SSH config. 11. Custom background. 12. Flatpak overrides. 13. Custom fonts. # Load Gnome settings. To load Gnome settings run `dconf_load`. # Navigation. Navigation principles are shared between Gnome, Tmux and Nvim. The only difference is the *"Leader"* key. Gnome uses *Super* key, Tmux uses *Meta (alt)* key and Nvim uses *Space*. The rest somewhat repeats itself. ## Gnome Key|Action ---|--- `Super+Esc`|Lauch Terminal emulator. `Super+q`|Switch to the left workspace. `Super+e`|Switch to the right workspace. `Super+Q`|Move window to the left workspace. `Super+E`|Move window to the right workspace. `Super+\|`|None. `Super+-`|None. `Super+w`|Toggle window maximize. `Super+s`|Minimize window. `Super+a`|Snap window to the left. `Super+d`|Snap window to the right. `Super+z`|Lock session. `Super+x`|Close window. `Super+c`|Minimize all windows. `Super+v`|Take a screenshot. `Super+f`|Toggle window fullscreen. ## Tmux. Key|Action ---|--- `Meta+Esc`, `Meta+t`|New window. `Meta+t` is for the Termux Android app as it can't send the `Meta+Esc` combo. `Meta+q`|Switch to the left window. `Meta+e`|Switch to the right window. `Meta+Q`|Move window to the left. `Meta+E`|Move window to the right. `Meta+\|`|Split vertically. `Meta+-`|Split horizontally. `Meta+w`|Switch to the above split. `Meta+s`|Switch to the below split. `Meta+a`|Switch to the left split. `Meta+d`|Switch to the right split. `Meta+z`|Detach from session. `Meta+x`|Close window. `Meta+c`|Close split. `Meta+v`|Visual selection. `y` to copy. `Meta+f`|None. ## Nvim. Key|Action ---|--- `Space+Esc`|None. `Space+q`|Switch to the left buffer. `Space+e`|Switch to the right buffer. `Space+Q`|Move buffer to the left. `Space+E`|Move buffer to the right. `Space+\|`|Split vertically. `Space+-`|Split horizontally. `Space+w`|Switch to the above split. `Space+s`|Switch to the below split. `Space+a`|Switch to the left split. `Space+d`|Switch to the right split. `Space+z`|Save all and exit. `Space+x`|Close buffer. `Space+c`|Close split. `Space+v`|Visual selection (or just default `v`). `Space+f`|None. More info in [Nvim config.](#nvim-config) # Nvim config. TODO: preserve default shortcuts, only add new ones when adding new functionality. ## General info. * Run `:Update` to update everything. * File tree shows everything by default, telescope ingores git-ignored files. ## Keymaps. ### Common. TODO: separate visual and others from common. Mode|Key|Action ---|---|--- Normal, Visual|`5dd`|Repeat following command N (5) times. Normal|`.`|Repeat input on selected line. Normal, Visual|`.`|Repeat command on selected line(s). Normal|`zz`|Save all files. Normal|`ZZ`, `z`|Save all and quit. Normal|`ZQ`|Quit without saving. Normal|`v`, `v`|Visual selection (cursor). Normal|`V`|Visual selection (lines). Normal|``|Visual selection (block). Normal|`gh`|Go to the start of the line. Normal|`gl`|Go to the end of the line. Normal|`gj`|Go to the end of the file. Normal|`gk`|Go to the top of the file. Normal|`u`|Undo action. Normal|`U`|Redo action (*remaps*: undo whole line), (*default*: ``). Visual|`u`|Convert selection to lowercase. Visual|`U`|Convert selection to uppercase. Visual|`~`|Toggle case. Normal, Visual|`;`|Enter command mode (*default*: `:`). Normal|`0`|Open shortcuts help. ### Align. Mode|Key|Action ---|---|--- Visual|`A`|Align selection from the right. Visual|`a`|Align selection from the left. ### Autocomplete. Mode|Key|Action ---|---|--- Input|``|Autocomplete. Normal|``|LSP autocomplete. ### Comments. Mode|Key|Action ---|---|--- Normal, Visual|`/`|Toggle selected line(s) comment. ### File tree. Mode|Key|Action ---|---|--- Normal|`1`|Toggle file tree. Normal|``|Toggle directory or open file for preview. Normal|`a`|Create file/directory. Normal|`x`|Cut file/directory. Normal|`p`|Paste file/directory. Normal|`f`|Filter. Normal|`F`|Reset filter. Normal|`d`|Delete file/directory. Normal|`r`|Rename file. Normal|`R`|Refresh. Normal|`s`|Open in system app. Normal|`S`|Search. Normal|`I`|Toggle gitignore filter. Normal|`y`|Copy name. Normal|`Y`|Copy relative path. ### Fold. Mode|Key|Action ---|---|--- Normal|`o`|Toggle fold. Normal|`O`|Fold everything. ### Git. Mode|Key|Action ---|---|--- Normal|`g`|Toggle git inspection mode. ### Macros. Mode|Key|Action ---|---|--- Visual|`mwx`|Unwrap selection (select the stuff inside wraps). Visual|`mw"`|Wrap selection in ". Visual|`mw3"`|Wrap selection in 3x ". Visual|`mw'`|Wrap selection in '. Visual|`mw(`|Wrap selection in (). Visual|`mw{`|Wrap selection in {}. Visual|`mw[`|Wrap selection in []. Visual|`` mw` ``|Wrap selection in \`. Visual|`` mw3` ``|Wrap selection in 3x \`. Visual|`mw*`|Wrap selection in *. Visual|`mw2*`|Wrap selection in 2x *. Visual|`mw3*`|Wrap selection in 3x *. Visual|`mw `|Wrap selection in spaces. Normal, Visual|`mmx`|Markdown: set - [ ] as completed. Normal, Visual|`mm `|Markdown: set - [x] as not completed. Normal|`mmp`|Markdown: insert paragrapg (2x non-breakable spaces). Visual|`mmb`|Markdown: make selection bold. Visual|`mmi`|Markdown: make selection italic. Visual|`mms`|Markdown: make selection strikethrough. Visual|`mmr`|Markdown: make selection a reference. Visual|`mmc`|Markdown: make selection a code block. Normal|`mi`|Copy and increment selected line. Normal|`ma`|Select all. ### Navigation. Mode|Key|Action ---|---|--- Normal|`w`|Switch to the split above. Normal|`a`|Switch to the split left. Normal|`s`|Switch to the split below. Normal|`d`|Switch to the split right. Normal|`q`|Swtich to the buffer left. Normal|`e`|Swtich to the buffer right. Normal|`Q`|Move the buffer left. Normal|`E`|Move the buffer right. Normal|`x`|Close the buffer. Normal|`X`|Close all invisible buffers. Normal|`m`|Move split. Normal|`\|`|Split vertically. Normal|`-`|Split horizontally. Normal|`c`|Close split. Input|``|Move left. Input|``|Move right. Input|``|Move down. Input|``|Move up. ### Telescope. Mode|Key|Action ---|---|--- Normal|`ff`|Find files. Normal|`fg`|Find grep (find text within files). Normal|`fb`|Find buffer. Normal|`fh`|Find help. Normal|`ft`|Find treesitter (vars, functions etc). Normal|`fa`|Find all (default treesitter window). ### Terminal. Mode|Key|Action ---|---|--- Normal|`4`|Open terminal. Terminal|``|Detach from terminal. ### To-do. Write `TODO:` or `NOTE:` to make it searchable. Mode|Key|Action ---|---|--- Normal|`3`|Open to-do list. ### Trouble. Mode|Key|Action ---|---|--- Normal|`2`|Open LSP trouble list. ### Which key. Mode|Key|Action ---|---|--- Normal|`0`|Show context hotkey help. ### Window management. Mode|Key|Action ---|---|--- Normal|`-`|Decrease split size vertically. Normal|`_`|Increase split size vertically. Normal|`\`|Decrease split size horizontally. Normal|`\|`|Increase split size horizontally. Normal|`=`|Equalize split sizes. # Bash commands. ## Android. Command|Description ---|--- `emulator`|Start android emulator. Not portable, it has to be named "default". ## Archive. Those are self-written scripts to create archives. They are basically compressed tar archives with SHA1 hashes in their names. They are exported so also available in `parallel` like this: `ls | parallel -j 8 -- archive {}` Command|Description ---|--- `archive [FILES]`|Create archive with the best compression (slow). If no args given, archives all files in current directory as separate archives. `archive_fast [FILES]`|Like normal `archive` but with minimal compression. `archive_check [ARCHIVES]`|Check specified archives or all archives in current directory. `archive_name [ARCHIVES] [NAME]`|Rename specified archive ro specified name or simplify name for specified archive or simplify names for all archives. `archive_prune [NAME]`|Delete old versions of an archive, or all archives by default. `unarchive [ARCHIVES]`|Check specified or all archives and extract if they are correct. ## Autocomplete. Thos are functions that provide tab-completions. ```bash _foo() { _autocomplete "{foo,bar}" } complete -F _foo foo ``` Command|Description ---|--- `_autocomplete `|Provide completion based on provided arguments separated by spaces. `_autocomplete_first `|Same as `_autocomplete` but works only once for first argument. `_autocomplete_grep `|Ls autocomplete with specified grep filter. `_autocomplete_nested`|Provides nested completions, just like `sudo` does. ## Battery. Command|Description ---|--- `battery_level`|Print battery charge level (if available). ## Bootstrap. Shortcuts to install different stuff. Command|Description ---|--- `bootstrap_cargo`|Install cargo. `bootstrap_texlive`|Install TeXLive package. `bootstrap_grub`|Install grub theme. Requires root. `bootstrap_ffmpeg`|Install ffmpeg in flatpak to make `~/app/bin/ffmpeg` work. ## Checksum. Command|Description ---|--- `checksum new`|Create checksums recursively. `checksum check`|Check previously created checksums. ## Chmod. Command|Description ---|--- `x `|Make file executable. ## Color. ### How to use. Most of the time you want to use it with `echo`. To make `echo` respect colors, you need to use `-e` flag like that: ```bash export color_default="\033[0m" export color_red="\033[0;31m" echo -e "${color_red}hello world!${color_default}" # will print "hello world!" in red. ``` Don't forget to use `color_default` at the end, or your whole terminal will be red. ### List of colors. Please note that colors depend on Terminal Emulator and may vary based on its settings. |Color|Code| |---|---| |default|`\033[0m`| |blue|`\033[0;34m`| |blue (bold)|`\033[1;34m`| |cyan|`\033[0;36m`| |cyan (bold)|`\033[1;36m`| |green|`\033[0;32m`| |green (bold)|`\033[1;32m`| |purple|`\033[0;35m`| |purple (bold)|`\033[1;35m`| |red|`\033[0;31m`| |red (bold)|`\033[1;31m`| |white|`\033[0;37m`| |white (bold)|`\033[1;37m`| |yellow|`\033[0;33m`| |yellow (bold)|`\033[1;33m`| ## Convert. `convert [FILES]`|Convert between different formats. ## Copy/paste. Command|Description ---|--- `echo a \| copy`|Copy `a` to system clipboard. `paste > file.txt`|Paste system clipboard to a file (or pipe). ## File copy (cp). Command|Description ---|--- `cp `|Copy files or dirs. Actually, it is an alias for `rsync -ahP`. Multiple `` could be specified. `cp_merge `|Mirror directories. Same as `rsync --delete`. `cp_link `|Copy directory by recursively creating hardlinks and directories. `bcp `|Default `cp` command. ## Date. Command|Description ---|--- `today`|Return today's date in `YYYYmmdd` format. `dow`|Return today's day of week, where 1 is Monday. ## Dconf (gnome settings). Command|Description ---|--- `dconf_load`|Load custom settings. `dconf_save`|Export all current setting in a file to inspect. ## Disk. Command|Description ---|--- `df`|Show free disk space (only physical media). `du [FILES]`|Show disk usage. ## Docker. Command|Description ---|--- `docker_volumes `|Show volumes of a specified container. `docker_health`|Show containers that exited with an error code. `docker_prune`|Heavy cleanup to free up space. `docker_ip `|Show IP of a specified container. `docker_update`|Update all Docker images. `dc`|Short for `docker compose`. `dcu [SERVICE]`|Start a compose service. `dcd [SERVICE]`|Remove a compose service. `dcp [SERVICE]`|Pull image for a compose service. `dcl [SERVICE]`|Show logs for a compose service. `dcr [SERVICE]`|Restart a compose service. `dcs [SERVICE]`|Stop a compose service. `dcdu [SERVICE]`|Recreate a compose service. `dcpu [SERVICE]`|Update and recreate a compose service. `dcul [SERVICE]`|Start a compose service and show its logs. ## Environment variables. Variable|Description ---|--- `PATH`|Defines where to find binaries. Modified to also include `$HOME/app/bin/` recursively. `LANGUAGE`|Specifies `UTF-8` as default. `EDITOR`|Specifies nvim as a default editor. `MANPAGER`|Specifies nvim as a default `man` viewer. `JAVA_HOME`|Specifies where JDK is stored. `ANDROID_SDK_ROOT`|Specifies where Android SDK is stored. `TEXMFVAR`, `TEXMFCONFIG`, `TEXMFLOCAL`|Specifies paths for TeXLive user directories. ## Ffmpeg. Command|Description ---|--- `ffmpeg_mux_audio `|Mux external audio into one container with video (replaces original audio). Run inside dir with original video. names should be the same for each video. ## Files. Command|Description ---|--- `o `|Open file with the default GUI app. ## Fix. Contains simple fixes for various issues. Command|Description ---|--- `fix_ethernet_speed `|Specify ethernet speed if it failed to set correct speed automatically. [SPEED] can be 10/100/1000 etc. `fix_files_sftp`|Make Nautilus forget incorrect password for SFTP connection. ## Git. Command|Description ---|--- `gps`|Git push. `gpsf`|Git push --force. `gpl`|Git pull. `gl`|Git log. `gs`|Git status. `gst`|Git stash. `gd`|Git diff. `gc [MESSAGE]`|Git commit. `gch`|Git checkout. `gchb`|Git checkout branch. `gb`|Git branch. `gbd [BRANCH]`|Delete specified Git branch. `gbda`|Delete all local branches except the current one. `gf`|Git fetch --all. `gt`|Git tag. `gi`|Delete files updated in git ignore. `gpc`|Git patch create. `gp`|Git patch (apply). `ga`|Git add with preview. `gr [COUNT]`|Git rebase. 2 last commits by default. 0 means from root. `gu [EMAIL]`|Configure git user as Dmitry Voronin with specified email (project). `gg `|Get git repo from my own git. ## Ls. Command|Description ---|--- `l`|List files in current dir. `ll`|List including hidden files. `lll [DEPTH] [PATH]`|Show file tree. `llll`|List everything recursively. `la`|List alphabetically. `laa`|List all alphabetically. ## Name. Those are scripts to manipulate file names. They are all exported and available for `parallel`. If no [FILES] specified, it applies to all files inside current directory. Command|Description ---|--- `name [FILES]`|Replace all non-alphanumeric characters in file with underscores. `name_hash [FILES]`|Replace all file names with hashes, keep extension. `name_hash_check [FILES]`|Check all file hashes. `name_series [FILES]`|Rename files to Jellyfin's show format: `Episode S01E01.mkv`. `name_manga [FILES]`|Rename files to Kavita's manga format: `Name Vol.1 Ch.01.cbr`. `name_ext [FILES]`|Change file extensions. `name_prefix [OLD] [NEW] [FILES]`|Change file prefix. ## Ncdu. Command|Description ---|--- `ncdu [DIR]`|Show recursive disk usage. Only on the same filesystem. ## Notify. Command|Description ---|--- `notify `|Send notification. `notify_silent `|Send silent notification. ## Own. Command|Description ---|--- `own [USER] [FILE]`|Change ownership & permissions to specified user. Ownership changes only when root. ## Pack. Command|Description ---|--- `pack [FILES]`|Create desired file format from other files. `unpack [FILES]`|Attempt to extract file content. ## Permissions. Command|Description ---|--- `perm`|Recursively change permissions not to share: 700 for dirs and 600 for files. `perm_share`|Recursively change permissions to share: 755 for dirs and 644 for files. ## Ps. Command|Description ---|--- `ps `|Show process info for matching [PROGRAM] name. ## Recursive. Command|Description ---|--- `recursive `|Cd into every directory recursively and run specified command in each dir. `recursive1 `|Cd into every directory in current directory and run specified command in each dir. ## Rust. Command|Description ---|--- `rust_book`|Open Rust book in a browser. ## Shopt. Shopt|Description ---|--- `dotglob`|When using `*` to match files, hidden files that start with a dot are also included. `globstar`|Allows the use of `**` for recursive search. `autocd`|Change directories without writing `cd`. ## Su. Command|Description ---|--- `s`|An alias for `su` cause I'm lazy. ## Terminal. Command|Description ---|--- `tsize`|Prints terminal size. ## Tmux. Command|Description ---|--- `ta [NAME]`|Attach to session by name. Default is `main`. `td`|Detach from session. `tl`|List all sessions. `tr [NAME]`|Rename session. Uses current dir name by default. `tn [NAME]`|Name window. Uses current dir name by default. `tk [NAME]`|Kill session. Default is `main`. `tka`|Kill all sessions. ## To-do. Command|Description ---|--- `todo`|Open editor for `~/.todo.md` file. ## Toolbx. Command|Description ---|--- `tb [NAME]`|Attach to box by name. Default is `main`. `tbk [NAME]`|Kill box by name. Default is `main`. `tb_rpmfusion [NAME]`|Install RPMFusion package to box by name. Default is `main`. `tbl`|List all boxes. ## Try. Command|Description ---|--- `try `|Repeat the command every 2 seconds until it exits with success. ## Umask. By default, umask is `077` which means group and others have no access when files are created. ## Vdl. Command|Description ---|--- `vdl [LINK]`|Download a video/playlist. When no link provided, tries to update previously downloaded link. ## Vi. Command|Description ---|--- `vi`|Run vim. `v`|Run neovim. ## Wallpaper. Command|Description ---|--- `wallpaper `|Set specified file as a wallpaper. ## Watch. Command|Description ---|--- `w `|Alias for `watch`. `ww `|Alias for `watch` that updates every 0.1 seconds. # To-do later. - [ ] Add tmux shortcuts to combo, too.