diff --git a/btop/.config/btop/btop.conf b/btop/.config/btop/btop.conf deleted file mode 100644 index de1273a..0000000 --- a/btop/.config/btop/btop.conf +++ /dev/null @@ -1,248 +0,0 @@ -#? Config file for btop v. 1.3.2 - -#* Name of a btop++/bpytop/bashtop formatted ".theme" file, "Default" and "TTY" for builtin themes. -#* Themes should be placed in "../share/btop/themes" relative to binary or "$HOME/.config/btop/themes" -color_theme = "/usr/share/btop/themes/tokyo-night.theme" - -#* If the theme set background should be shown, set to False if you want terminal background transparency. -theme_background = False - -#* Sets if 24-bit truecolor should be used, will convert 24-bit colors to 256 color (6x6x6 color cube) if false. -truecolor = True - -#* Set to true to force tty mode regardless if a real tty has been detected or not. -#* Will force 16-color mode and TTY theme, set all graph symbols to "tty" and swap out other non tty friendly symbols. -force_tty = False - -#* Define presets for the layout of the boxes. Preset 0 is always all boxes shown with default settings. Max 9 presets. -#* Format: "box_name:P:G,box_name:P:G" P=(0 or 1) for alternate positions, G=graph symbol to use for box. -#* Use whitespace " " as separator between different presets. -#* Example: "cpu:0:default,mem:0:tty,proc:1:default cpu:0:braille,proc:0:tty" -presets = "cpu:1:default,proc:0:default cpu:0:default,mem:0:default,net:0:default cpu:0:block,net:0:tty" - -#* Set to True to enable "h,j,k,l,g,G" keys for directional control in lists. -#* Conflicting keys for h:"help" and k:"kill" is accessible while holding shift. -vim_keys = True - -#* Rounded corners on boxes, is ignored if TTY mode is ON. -rounded_corners = False - -#* Default symbols to use for graph creation, "braille", "block" or "tty". -#* "braille" offers the highest resolution but might not be included in all fonts. -#* "block" has half the resolution of braille but uses more common characters. -#* "tty" uses only 3 different symbols but will work with most fonts and should work in a real TTY. -#* Note that "tty" only has half the horizontal resolution of the other two, so will show a shorter historical view. -graph_symbol = "braille" - -# Graph symbol to use for graphs in cpu box, "default", "braille", "block" or "tty". -graph_symbol_cpu = "default" - -# Graph symbol to use for graphs in gpu box, "default", "braille", "block" or "tty". -graph_symbol_gpu = "default" - -# Graph symbol to use for graphs in cpu box, "default", "braille", "block" or "tty". -graph_symbol_mem = "default" - -# Graph symbol to use for graphs in cpu box, "default", "braille", "block" or "tty". -graph_symbol_net = "default" - -# Graph symbol to use for graphs in cpu box, "default", "braille", "block" or "tty". -graph_symbol_proc = "default" - -#* Manually set which boxes to show. Available values are "cpu mem net proc" and "gpu0" through "gpu5", separate values with whitespace. -shown_boxes = "cpu mem proc" - -#* Update time in milliseconds, recommended 2000 ms or above for better sample times for graphs. -update_ms = 2000 - -#* Processes sorting, "pid" "program" "arguments" "threads" "user" "memory" "cpu lazy" "cpu direct", -#* "cpu lazy" sorts top process over time (easier to follow), "cpu direct" updates top process directly. -proc_sorting = "cpu lazy" - -#* Reverse sorting order, True or False. -proc_reversed = False - -#* Show processes as a tree. -proc_tree = False - -#* Use the cpu graph colors in the process list. -proc_colors = True - -#* Use a darkening gradient in the process list. -proc_gradient = True - -#* If process cpu usage should be of the core it's running on or usage of the total available cpu power. -proc_per_core = False - -#* Show process memory as bytes instead of percent. -proc_mem_bytes = True - -#* Show cpu graph for each process. -proc_cpu_graphs = True - -#* Use /proc/[pid]/smaps for memory information in the process info box (very slow but more accurate) -proc_info_smaps = False - -#* Show proc box on left side of screen instead of right. -proc_left = False - -#* (Linux) Filter processes tied to the Linux kernel(similar behavior to htop). -proc_filter_kernel = False - -#* In tree-view, always accumulate child process resources in the parent process. -proc_aggregate = False - -#* Sets the CPU stat shown in upper half of the CPU graph, "total" is always available. -#* Select from a list of detected attributes from the options menu. -cpu_graph_upper = "Auto" - -#* Sets the CPU stat shown in lower half of the CPU graph, "total" is always available. -#* Select from a list of detected attributes from the options menu. -cpu_graph_lower = "Auto" - -#* If gpu info should be shown in the cpu box. Available values = "Auto", "On" and "Off". -show_gpu_info = "Auto" - -#* Toggles if the lower CPU graph should be inverted. -cpu_invert_lower = True - -#* Set to True to completely disable the lower CPU graph. -cpu_single_graph = False - -#* Show cpu box at bottom of screen instead of top. -cpu_bottom = False - -#* Shows the system uptime in the CPU box. -show_uptime = True - -#* Show cpu temperature. -check_temp = True - -#* Which sensor to use for cpu temperature, use options menu to select from list of available sensors. -cpu_sensor = "Auto" - -#* Show temperatures for cpu cores also if check_temp is True and sensors has been found. -show_coretemp = True - -#* Set a custom mapping between core and coretemp, can be needed on certain cpus to get correct temperature for correct core. -#* Use lm-sensors or similar to see which cores are reporting temperatures on your machine. -#* Format "x:y" x=core with wrong temp, y=core with correct temp, use space as separator between multiple entries. -#* Example: "4:0 5:1 6:3" -cpu_core_map = "" - -#* Which temperature scale to use, available values: "celsius", "fahrenheit", "kelvin" and "rankine". -temp_scale = "celsius" - -#* Use base 10 for bits/bytes sizes, KB = 1000 instead of KiB = 1024. -base_10_sizes = False - -#* Show CPU frequency. -show_cpu_freq = True - -#* Draw a clock at top of screen, formatting according to strftime, empty string to disable. -#* Special formatting: /host = hostname | /user = username | /uptime = system uptime -clock_format = "%X" - -#* Update main ui in background when menus are showing, set this to false if the menus is flickering too much for comfort. -background_update = True - -#* Custom cpu model name, empty string to disable. -custom_cpu_name = "" - -#* Optional filter for shown disks, should be full path of a mountpoint, separate multiple values with whitespace " ". -#* Begin line with "exclude=" to change to exclude filter, otherwise defaults to "most include" filter. Example: disks_filter="exclude=/boot /home/user". -disks_filter = "" - -#* Show graphs instead of meters for memory values. -mem_graphs = True - -#* Show mem box below net box instead of above. -mem_below_net = False - -#* Count ZFS ARC in cached and available memory. -zfs_arc_cached = True - -#* If swap memory should be shown in memory box. -show_swap = True - -#* Show swap as a disk, ignores show_swap value above, inserts itself after first disk. -swap_disk = True - -#* If mem box should be split to also show disks info. -show_disks = True - -#* Filter out non physical disks. Set this to False to include network disks, RAM disks and similar. -only_physical = True - -#* Read disks list from /etc/fstab. This also disables only_physical. -use_fstab = True - -#* Setting this to True will hide all datasets, and only show ZFS pools. (IO stats will be calculated per-pool) -zfs_hide_datasets = False - -#* Set to true to show available disk space for privileged users. -disk_free_priv = False - -#* Toggles if io activity % (disk busy time) should be shown in regular disk usage view. -show_io_stat = True - -#* Toggles io mode for disks, showing big graphs for disk read/write speeds. -io_mode = False - -#* Set to True to show combined read/write io graphs in io mode. -io_graph_combined = False - -#* Set the top speed for the io graphs in MiB/s (100 by default), use format "mountpoint:speed" separate disks with whitespace " ". -#* Example: "/mnt/media:100 /:20 /boot:1". -io_graph_speeds = "" - -#* Set fixed values for network graphs in Mebibits. Is only used if net_auto is also set to False. -net_download = 100 - -net_upload = 100 - -#* Use network graphs auto rescaling mode, ignores any values set above and rescales down to 10 Kibibytes at the lowest. -net_auto = True - -#* Sync the auto scaling for download and upload to whichever currently has the highest scale. -net_sync = True - -#* Starts with the Network Interface specified here. -net_iface = "" - -#* Show battery stats in top right if battery is present. -show_battery = True - -#* Which battery to use if multiple are present. "Auto" for auto detection. -selected_battery = "Auto" - -#* Show power stats of battery next to charge indicator. -show_battery_watts = True - -#* Set loglevel for "~/.config/btop/btop.log" levels are: "ERROR" "WARNING" "INFO" "DEBUG". -#* The level set includes all lower levels, i.e. "DEBUG" will show all logging info. -log_level = "WARNING" - -#* Measure PCIe throughput on NVIDIA cards, may impact performance on certain cards. -nvml_measure_pcie_speeds = True - -#* Horizontally mirror the GPU graph. -gpu_mirror_graph = True - -#* Custom gpu0 model name, empty string to disable. -custom_gpu_name0 = "" - -#* Custom gpu1 model name, empty string to disable. -custom_gpu_name1 = "" - -#* Custom gpu2 model name, empty string to disable. -custom_gpu_name2 = "" - -#* Custom gpu3 model name, empty string to disable. -custom_gpu_name3 = "" - -#* Custom gpu4 model name, empty string to disable. -custom_gpu_name4 = "" - -#* Custom gpu5 model name, empty string to disable. -custom_gpu_name5 = "" diff --git a/code/.config/Code - OSS/User/settings.json b/code/.config/Code - OSS/User/settings.json index 4f711b4..03e0dcf 100644 --- a/code/.config/Code - OSS/User/settings.json +++ b/code/.config/Code - OSS/User/settings.json @@ -34,5 +34,10 @@ "window.restoreWindows": "one", "window.zoomLevel": 2, "workbench.iconTheme": "material-icon-theme", - "workbench.startupEditor": "none" + "workbench.startupEditor": "none", + "svelte.enable-ts-plugin": true, + "[python]": { + "editor.defaultFormatter": "ms-python.black-formatter" + }, + "workbench.colorTheme": "Tokyo Night" } \ No newline at end of file diff --git a/foot/dot-config/foot/foot.ini b/foot/dot-config/foot/foot.ini new file mode 100644 index 0000000..d70f789 --- /dev/null +++ b/foot/dot-config/foot/foot.ini @@ -0,0 +1,35 @@ +[main] +font=FiraCode Nerd Font:size=13 +box-drawings-uses-font-glyphs=yes + +[environment] +RANGER_LOAD_DEFAULT_RC="FALSE" + +[bell] +urgent=yes +notify=yes +visual=yes + +[mouse] +hide-when-typing=yes + +[colors] +foreground=a9b1d6 +background=1a1b26 +regular0=32344a +regular1=f7768e +regular2=9ece6a +regular3=e0af68 +regular4=7aa2f7 +regular5=ad8ee6 +regular6=449dab +regular7=787c99 +bright0=444b6a +bright1=ff7a93 +bright2=b9f27c +bright3=ff9e64 +bright4=7da6ff +bright5=bb9af7 +bright6=0db9d7 +bright7=acb0d0 +alpha=0.9 \ No newline at end of file diff --git a/fuzzel/.config/fuzzel/fuzzel.ini b/fuzzel/.config/fuzzel/fuzzel.ini deleted file mode 100644 index db0313e..0000000 --- a/fuzzel/.config/fuzzel/fuzzel.ini +++ /dev/null @@ -1,21 +0,0 @@ -font=Noto Sans:size=14 -prompt=":3 " -icon-theme=Adwaita -show-actions=yes -terminal=alacritty -e -horizontal-pad=8 -vertical-pad=8 -inner-pad=8 - -[colors] -background=1a1b26e6 -text=c0caf5ff -match=bb9af7ff -selection=bb9af7ff -selection-text=1a1b26e6 -selection-match=c0caf5ff -border=414868ff - -[border] -width=2 -radius=0 diff --git a/gtk/.config/gtk-3.0/settings.ini b/gtk/.config/gtk-3.0/settings.ini deleted file mode 100644 index 2189857..0000000 --- a/gtk/.config/gtk-3.0/settings.ini +++ /dev/null @@ -1,2 +0,0 @@ -[Settings] -gtk-application-prefer-dark-theme = true diff --git a/justfile b/justfile index f8992a8..147a6db 100644 --- a/justfile +++ b/justfile @@ -4,121 +4,110 @@ username := env_var('USER') default: @just --list --justfile {{justfile()}} -install-codecs: - sudo pacman -S gst-libav gst-plugin-va gst-plugins-bad gst-plugins-base gst-plugins-good gstreamer - -# Install C# dev environment -install-dev-csharp: - sudo pacman -S aspnet-runtime aspnet-targeting-pack dotnet-sdk dotnet-runtime dotnet-targeting-pack - sudo dotnet workload install wasm-tools - -install-dev-node: - sudo pacman -S nodejs npm - -install-dev-python: - sudo pacman -S python python-pip - -# Install Rust dev environment -install-dev-rust: - sudo pacman -S rustup - rustup install stable - -# Install Docker and docker-compose -install-docker: - sudo pacman -S docker docker-compose - sudo systemctl enable docker.socket - -install-essentials-cli: - sudo pacman -S base-devel btop curl eza fastfetch ffmpeg flatpak fwupd fzf hunspell hunspell-en_au hunspell-en_us man-db man-pages nvtop openssh p7zip reflector ripgrep unrar vim vulkan-tools xdg-user-dirs yt-dlp - -install-essentials-gui: - sudo pacman -S audacity blue-utils code easyeffects firefox freerdp2 gamemode gimp goverlay kate kdeconnect libva-vdpau-driver libva-utils libvdpau-va-gl lsp-plugins-lv2 mangohud mesa-vdpau mpv power-profiles-daemon steam syncthing ttf-firacode-nerd ttf-liberation wine wine-gecko wine-mono winetricks wqy-zenhei - ame install arrpc protontricks vesktop - flatpak install ca.parallel_launcher.ParallelLauncher com.heroicgameslauncher.hgl com.logseq.Logseq com.obsproject.Studio net.davidotek.pupgui2 org.prismlauncher.PrismLauncher - systemctl enable --now --user arrpc - sudo systemctl enable --now bluetooth - sudo systemctl enable --now power-profiles-daemon - systemctl enable --now --user syncthing - -# Install fish and plugin manager -install-fish: - sudo pacman -S fish pkgfile - fish -c "curl -sL https://raw.githubusercontent.com/jorgebucaran/fisher/main/functions/fisher.fish | source && fisher install jorgebucaran/fisher" - -# Setup reflector and enable timer -setup-arch-mirrors: +# Arch Linux package mirrors & timer for fetching best mirrors +arch-mirrors: sudo reflector --country 'Australia,New Zealand,' --latest 15 --protocol https --sort rate --save /etc/pacman.d/mirrorlist sudo systemctl enable --now reflector.timer -# Installs the ame AUR helper -setup-aur: +# Arch User Repository +aur: rustup install stable - rm -rf /tmp/ame - git clone https://aur.archlinux.org/ame.git /tmp/ame - cd /tmp/ame; makepkg -si - rm -rf /tmp/ame + rm -rf /tmp/paru-git + git clone https://aur.archlinux.org/paru-git.git /tmp/paru-git + cd /tmp/paru-git; makepkg -si + rm -rf /tmp/paru-git -# Installs VSCodium extensions -setup-code: - code-oss --install-extension davidanson.vscode-markdownlint - code-oss --install-extension irongeek.vscode-env - code-oss --install-extension kokakiwi.vscode-just - code-oss --install-extension ms-vscode.live-server - code-oss --install-extension naumovs.color-highlight - code-oss --install-extension pkief.material-icon-theme - code-oss --install-extension redhat.vscode-yaml - code-oss --install-extension rust-lang.rust-analyzer - code-oss --install-extension serayuzgur.crates - code-oss --install-extension spgoding.datapack-language-server - code-oss --install-extension tamasfe.even-better-toml - code-oss --install-extension usernamehw.errorlens +# Essential CLI tools & utils +cli: + sudo pacman -S base-devel btop curl eza fastfetch ffmpeg fwupd fzf man-db man-pages nvtop openssh reflector ripgrep unrar vim vulkan-tools xdg-user-dirs yt-dlp -setup-flatpak: +# ranger terminal file browser +cli-ranger: + sudo pacman -S atool ffmpegthumbnailer highlight mediainfo p7zip transmission-cli unzip w3m zip + paru -S ranger-git + pipx install no_vtf python-bidi + + stow --dotfiles -S ranger + +codecs: + sudo pacman -S gst-libav gst-plugin-va gst-plugins-bad gst-plugins-base gst-plugins-good gstreamer + +# C#/.NET dev environment & Rider editor +dev-csharp: + sudo pacman -S aspnet-runtime aspnet-targeting-pack dotnet-sdk dotnet-runtime dotnet-targeting-pack + sudo dotnet workload install wasm-tools + paru -S rider + +# Node dev environment +dev-node: + sudo pacman -S nodejs npm + +# Python dev environment & PyCharm editor +dev-python: + sudo pacman -S pycharm-community-edition python python-pip python-pipx python-venv + + fish -c "fish_add_path $HOME/.local/bin" + +# Rust dev environment +dev-rust: + sudo pacman -S rustup + rustup install stable + +# Docker container runtime +docker: + sudo pacman -S docker docker-compose + sudo systemctl enable --now docker + +# Flatpak & Flathub package repository +flatpak: + sudo pacman -S flatpak flatpak-xdg-utils flatpak remote-add --if-not-exists flathub https://dl.flathub.org/repo/flathub.flatpakrepo -# Set up git global config. Still need to manually set user.signingkey -setup-git: +# foot terminal emulator +foot: + sudo pacman -S foot foot-terminfo + + stow --dotfiles -S foot + +# Steam, Heroic, Prism Launcher, Gamescope, MangoHud & other utils +games: + sudo pacman -S gamemode gamescope goverlay mangohud steam ttf-liberation wine wine-gecko wine-mono winetricks wqy-zenhei + paru -S protontricks + flatpak install ca.parallel_launcher.ParallelLauncher com.heroicgameslauncher.hgl net.davidotek.pupgui2 org.prismlauncher.PrismLauncher + +# git global config +git: git config --global commit.gpgsign true git config --global init.defaultBranch "main" git config --global user.email "trypancakes@tutanota.com" git config --global user.name "pancakes" -# Installs mpv scripts -setup-mpv: - mkdir -p ~/.config/mpv/scripts - curl https://raw.githubusercontent.com/mpv-player/mpv/master/TOOLS/lua/autodeint.lua -o ~/.config/mpv/scripts/autodeint.lua - curl https://raw.githubusercontent.com/po5/thumbfast/master/thumbfast.lua -o ~/.config/mpv/scripts/thumbfast.lua - curl -fsSL https://raw.githubusercontent.com/tomasklaen/uosc/HEAD/installers/unix.sh | bash +# Syncthing file sync +syncthing: + sudo pacman -S syncthing + systemctl enable --now --user syncthing -# Configure fish and plugins -setup-shell: - chsh -s /usr/bin/fish - fish -c "set -U fish_greeting" - fish -c "set -U MOZ_ENABLE_WAYLAND 1" - fish -c "set -U MOZ_USE_XINPUT2 1" - fish -c "set -U VISUAL vim" - fish -c "curl -sL https://raw.githubusercontent.com/folke/tokyonight.nvim/main/extras/fish/tokyonight_night.fish | source" - fish -c "fisher install franciscolourenco/done" - fish -c "fisher install jorgebucaran/autopair.fish" - fish -c "fisher install jorgebucaran/hydro" - fish -c "fisher install meaningful-ooo/sponge" - fish -c "fisher install nickeb96/puffer-fish" - -# Enable and authenticate with Tailscale -setup-tailscale: +# Tailscale private VPN +tailscale: + sudo pacman -S tailscale sudo systemctl enable --now tailscaled sudo tailscale up --operator={{username}} --ssh=true -# Installs Waydroid with GAPPS -setup-waydroid: +# Waydroid Android emulator with Google Apps +waydroid: ame install binder_linux-dkms waydroid sudo waydroid init -s GAPPS sudo systemctl enable --now waydroid-container waydroid session start & -# Stows all dotfiles into the correct locations -stow: - stow btop - stow code - stow mangohud - stow mpv +# window manager and required programs +wm: + sudo pacman -S bluez bluez-utils cliphist easyeffects firefox fuzzel gdm gnome-keyring gtklock hunspell hunspell-en_au hunspell-en_us mako niri noto-fonts noto-fonts-cjk noto-fonts-emoji noto-fonts-extra power-profiles-daemon swayidle swww ttf-firacode-nerd ttf-font-awesome waybar wl-clipboard xdg-desktop-portal-gnome + paru -S xwayland-satellite + flatpak install it.mijorus.smile + + sudo systemctl enable --now bluetooth + sudo systemctl enable gdm + sudo systemctl enable --now power-profiles-daemon + + stow --dotfiles -S wm diff --git a/kanshi/.config/kanshi/config b/kanshi/.config/kanshi/config deleted file mode 100644 index 7e68023..0000000 --- a/kanshi/.config/kanshi/config +++ /dev/null @@ -1,33 +0,0 @@ -profile amida { - output "AOC 27G2G4 GYGL9HA232568" { - adaptive_sync on - mode 1920x1080@144Hz - } - - exec pkill swaybg; riverctl spawn "swaybg -i ~/.wallpaper -m fill" -} - -profile amida2 { - output "AOC 27G2G4 GYGL9HA232568" { - adaptive_sync on - mode 1920x1080@144Hz - position 1080,350 - } - - output "AOC 2470W GGJH9HA056165" { - adaptive_sync off - mode 1920x1080@60Hz - position 0,0 - transform 90 - } - - exec pkill swaybg; riverctl spawn "swaybg -i ~/.wallpaper -m fill" -} - -profile vlam { - output eDP-1 { - scale 1.5 - } - - exec pkill swaybg; riverctl spawn "swaybg -i ~/.wallpaper -m fill" -} diff --git a/kitty/.config/kitty/current-theme.conf b/kitty/.config/kitty/current-theme.conf deleted file mode 100644 index 7ff8ff1..0000000 --- a/kitty/.config/kitty/current-theme.conf +++ /dev/null @@ -1,45 +0,0 @@ -# vim:ft=kitty - -## name: Tokyo Night -## license: MIT -## author: Folke Lemaitre -## upstream: https://github.com/folke/tokyonight.nvim/raw/main/extras/kitty_tokyonight_night.conf - - -background #1a1b26 -foreground #c0caf5 -selection_background #33467C -selection_foreground #c0caf5 -url_color #73daca -cursor #c0caf5 - -# Tabs -active_tab_background #7aa2f7 -active_tab_foreground #1f2335 -inactive_tab_background #292e42 -inactive_tab_foreground #545c7e -#tab_bar_background #15161E - -# normal -color0 #15161E -color1 #f7768e -color2 #9ece6a -color3 #e0af68 -color4 #7aa2f7 -color5 #bb9af7 -color6 #7dcfff -color7 #a9b1d6 - -# bright -color8 #414868 -color9 #f7768e -color10 #9ece6a -color11 #e0af68 -color12 #7aa2f7 -color13 #bb9af7 -color14 #7dcfff -color15 #c0caf5 - -# extended colors -color16 #ff9e64 -color17 #db4b4b diff --git a/kitty/.config/kitty/kitty.conf b/kitty/.config/kitty/kitty.conf deleted file mode 100644 index 6964228..0000000 --- a/kitty/.config/kitty/kitty.conf +++ /dev/null @@ -1,2459 +0,0 @@ -# vim:fileencoding=utf-8:foldmethod=marker - -#: Fonts {{{ - -#: kitty has very powerful font management. You can configure -#: individual font faces and even specify special fonts for particular -#: characters. - -font_family FiraCode Nerd Font -bold_font auto -italic_font auto -bold_italic_font auto - -#: You can specify different fonts for the bold/italic/bold-italic -#: variants. To get a full list of supported fonts use the `kitty -#: +list-fonts` command. By default they are derived automatically, by -#: the OSes font system. When bold_font or bold_italic_font is set to -#: auto on macOS, the priority of bold fonts is semi-bold, bold, -#: heavy. Setting them manually is useful for font families that have -#: many weight variants like Book, Medium, Thick, etc. For example:: - -#: font_family Operator Mono Book -#: bold_font Operator Mono Medium -#: italic_font Operator Mono Book Italic -#: bold_italic_font Operator Mono Medium Italic - -font_size 14.0 - -#: Font size (in pts) - -# force_ltr no - -#: kitty does not support BIDI (bidirectional text), however, for RTL -#: scripts, words are automatically displayed in RTL. That is to say, -#: in an RTL script, the words "HELLO WORLD" display in kitty as -#: "WORLD HELLO", and if you try to select a substring of an RTL- -#: shaped string, you will get the character that would be there had -#: the string been LTR. For example, assuming the Hebrew word ירושלים, -#: selecting the character that on the screen appears to be ם actually -#: writes into the selection buffer the character י. kitty's default -#: behavior is useful in conjunction with a filter to reverse the word -#: order, however, if you wish to manipulate RTL glyphs, it can be -#: very challenging to work with, so this option is provided to turn -#: it off. Furthermore, this option can be used with the command line -#: program GNU FriBidi -#: to get BIDI support, because it will force kitty to always treat -#: the text as LTR, which FriBidi expects for terminals. - -# symbol_map - -#: E.g. symbol_map U+E0A0-U+E0A3,U+E0C0-U+E0C7 PowerlineSymbols - -#: Map the specified Unicode codepoints to a particular font. Useful -#: if you need special rendering for some symbols, such as for -#: Powerline. Avoids the need for patched fonts. Each Unicode code -#: point is specified in the form `U+`. You -#: can specify multiple code points, separated by commas and ranges -#: separated by hyphens. This option can be specified multiple times. -#: The syntax is:: - -#: symbol_map codepoints Font Family Name - -# narrow_symbols - -#: E.g. narrow_symbols U+E0A0-U+E0A3,U+E0C0-U+E0C7 1 - -#: Usually, for Private Use Unicode characters and some symbol/dingbat -#: characters, if the character is followed by one or more spaces, -#: kitty will use those extra cells to render the character larger, if -#: the character in the font has a wide aspect ratio. Using this -#: option you can force kitty to restrict the specified code points to -#: render in the specified number of cells (defaulting to one cell). -#: This option can be specified multiple times. The syntax is:: - -#: narrow_symbols codepoints [optionally the number of cells] - -# disable_ligatures never - -#: Choose how you want to handle multi-character ligatures. The -#: default is to always render them. You can tell kitty to not render -#: them when the cursor is over them by using cursor to make editing -#: easier, or have kitty never render them at all by using always, if -#: you don't like them. The ligature strategy can be set per-window -#: either using the kitty remote control facility or by defining -#: shortcuts for it in kitty.conf, for example:: - -#: map alt+1 disable_ligatures_in active always -#: map alt+2 disable_ligatures_in all never -#: map alt+3 disable_ligatures_in tab cursor - -#: Note that this refers to programming ligatures, typically -#: implemented using the calt OpenType feature. For disabling general -#: ligatures, use the font_features option. - -# font_features - -#: E.g. font_features none - -#: Choose exactly which OpenType features to enable or disable. This -#: is useful as some fonts might have features worthwhile in a -#: terminal. For example, Fira Code includes a discretionary feature, -#: zero, which in that font changes the appearance of the zero (0), to -#: make it more easily distinguishable from Ø. Fira Code also includes -#: other discretionary features known as Stylistic Sets which have the -#: tags ss01 through ss20. - -#: For the exact syntax to use for individual features, see the -#: HarfBuzz documentation . - -#: Note that this code is indexed by PostScript name, and not the font -#: family. This allows you to define very precise feature settings; -#: e.g. you can disable a feature in the italic font but not in the -#: regular font. - -#: On Linux, font features are first read from the FontConfig database -#: and then this option is applied, so they can be configured in a -#: single, central place. - -#: To get the PostScript name for a font, use `kitty +list-fonts -#: --psnames`: - -#: .. code-block:: sh - -#: $ kitty +list-fonts --psnames | grep Fira -#: Fira Code -#: Fira Code Bold (FiraCode-Bold) -#: Fira Code Light (FiraCode-Light) -#: Fira Code Medium (FiraCode-Medium) -#: Fira Code Regular (FiraCode-Regular) -#: Fira Code Retina (FiraCode-Retina) - -#: The part in brackets is the PostScript name. - -#: Enable alternate zero and oldstyle numerals:: - -#: font_features FiraCode-Retina +zero +onum - -#: Enable only alternate zero in the bold font:: - -#: font_features FiraCode-Bold +zero - -#: Disable the normal ligatures, but keep the calt feature which (in -#: this font) breaks up monotony:: - -#: font_features TT2020StyleB-Regular -liga +calt - -#: In conjunction with force_ltr, you may want to disable Arabic -#: shaping entirely, and only look at their isolated forms if they -#: show up in a document. You can do this with e.g.:: - -#: font_features UnifontMedium +isol -medi -fina -init - -# modify_font - -#: Modify font characteristics such as the position or thickness of -#: the underline and strikethrough. The modifications can have the -#: suffix px for pixels or % for percentage of original value. No -#: suffix means use pts. For example:: - -#: modify_font underline_position -2 -#: modify_font underline_thickness 150% -#: modify_font strikethrough_position 2px - -#: Additionally, you can modify the size of the cell in which each -#: font glyph is rendered and the baseline at which the glyph is -#: placed in the cell. For example:: - -#: modify_font cell_width 80% -#: modify_font cell_height -2px -#: modify_font baseline 3 - -#: Note that modifying the baseline will automatically adjust the -#: underline and strikethrough positions by the same amount. -#: Increasing the baseline raises glyphs inside the cell and -#: decreasing it lowers them. Decreasing the cell size might cause -#: rendering artifacts, so use with care. - -# box_drawing_scale 0.001, 1, 1.5, 2 - -#: The sizes of the lines used for the box drawing Unicode characters. -#: These values are in pts. They will be scaled by the monitor DPI to -#: arrive at a pixel value. There must be four values corresponding to -#: thin, normal, thick, and very thick lines. - -# undercurl_style thin-sparse - -#: The style with which undercurls are rendered. This option takes the -#: form (thin|thick)-(sparse|dense). Thin and thick control the -#: thickness of the undercurl. Sparse and dense control how often the -#: curl oscillates. With sparse the curl will peak once per character, -#: with dense twice. - -# text_composition_strategy platform - -#: Control how kitty composites text glyphs onto the background color. -#: The default value of platform tries for text rendering as close to -#: "native" for the platform kitty is running on as possible. - -#: A value of legacy uses the old (pre kitty 0.28) strategy for how -#: glyphs are composited. This will make dark text on light -#: backgrounds look thicker and light text on dark backgrounds -#: thinner. It might also make some text appear like the strokes are -#: uneven. - -#: You can fine tune the actual contrast curve used for glyph -#: composition by specifying up to two space-separated numbers for -#: this setting. - -#: The first number is the gamma adjustment, which controls the -#: thickness of dark text on light backgrounds. Increasing the value -#: will make text appear thicker. The default value for this is 1.0 on -#: Linux and 1.7 on macOS. Valid values are 0.01 and above. The result -#: is scaled based on the luminance difference between the background -#: and the foreground. Dark text on light backgrounds receives the -#: full impact of the curve while light text on dark backgrounds is -#: affected very little. - -#: The second number is an additional multiplicative contrast. It is -#: percentage ranging from 0 to 100. The default value is 0 on Linux -#: and 30 on macOS. - -#: If you wish to achieve similar looking thickness in light and dark -#: themes, a good way to experiment is start by setting the value to -#: 1.0 0 and use a dark theme. Then adjust the second parameter until -#: it looks good. Then switch to a light theme and adjust the first -#: parameter until the perceived thickness matches the dark theme. - -# text_fg_override_threshold 0 - -#: The minimum accepted difference in luminance between the foreground -#: and background color, below which kitty will override the -#: foreground color. It is percentage ranging from 0 to 100. If the -#: difference in luminance of the foreground and background is below -#: this threshold, the foreground color will be set to white if the -#: background is dark or black if the background is light. The default -#: value is 0, which means no overriding is performed. Useful when -#: working with applications that use colors that do not contrast well -#: with your preferred color scheme. - -#: WARNING: Some programs use characters (such as block characters) -#: for graphics display and may expect to be able to set the -#: foreground and background to the same color (or similar colors). -#: If you see unexpected stripes, dots, lines, incorrect color, no -#: color where you expect color, or any kind of graphic display -#: problem try setting text_fg_override_threshold to 0 to see if this -#: is the cause of the problem. - -#: }}} - -#: Cursor customization {{{ - -# cursor #cccccc - -#: Default cursor color. If set to the special value none the cursor -#: will be rendered with a "reverse video" effect. It's color will be -#: the color of the text in the cell it is over and the text will be -#: rendered with the background color of the cell. Note that if the -#: program running in the terminal sets a cursor color, this takes -#: precedence. Also, the cursor colors are modified if the cell -#: background and foreground colors have very low contrast. - -# cursor_text_color #111111 - -#: The color of text under the cursor. If you want it rendered with -#: the background color of the cell underneath instead, use the -#: special keyword: background. Note that if cursor is set to none -#: then this option is ignored. - -# cursor_shape block - -#: The cursor shape can be one of block, beam, underline. Note that -#: when reloading the config this will be changed only if the cursor -#: shape has not been set by the program running in the terminal. This -#: sets the default cursor shape, applications running in the terminal -#: can override it. In particular, shell integration -#: in kitty sets -#: the cursor shape to beam at shell prompts. You can avoid this by -#: setting shell_integration to no-cursor. - -# cursor_beam_thickness 1.5 - -#: The thickness of the beam cursor (in pts). - -# cursor_underline_thickness 2.0 - -#: The thickness of the underline cursor (in pts). - -# cursor_blink_interval -1 - -#: The interval to blink the cursor (in seconds). Set to zero to -#: disable blinking. Negative values mean use system default. Note -#: that the minimum interval will be limited to repaint_delay. - -# cursor_stop_blinking_after 15.0 - -#: Stop blinking cursor after the specified number of seconds of -#: keyboard inactivity. Set to zero to never stop blinking. - -#: }}} - -#: Scrollback {{{ - -# scrollback_lines 2000 - -#: Number of lines of history to keep in memory for scrolling back. -#: Memory is allocated on demand. Negative numbers are (effectively) -#: infinite scrollback. Note that using very large scrollback is not -#: recommended as it can slow down performance of the terminal and -#: also use large amounts of RAM. Instead, consider using -#: scrollback_pager_history_size. Note that on config reload if this -#: is changed it will only affect newly created windows, not existing -#: ones. - -# scrollback_pager less --chop-long-lines --RAW-CONTROL-CHARS +INPUT_LINE_NUMBER - -#: Program with which to view scrollback in a new window. The -#: scrollback buffer is passed as STDIN to this program. If you change -#: it, make sure the program you use can handle ANSI escape sequences -#: for colors and text formatting. INPUT_LINE_NUMBER in the command -#: line above will be replaced by an integer representing which line -#: should be at the top of the screen. Similarly CURSOR_LINE and -#: CURSOR_COLUMN will be replaced by the current cursor position or -#: set to 0 if there is no cursor, for example, when showing the last -#: command output. - -# scrollback_pager_history_size 0 - -#: Separate scrollback history size (in MB), used only for browsing -#: the scrollback buffer with pager. This separate buffer is not -#: available for interactive scrolling but will be piped to the pager -#: program when viewing scrollback buffer in a separate window. The -#: current implementation stores the data in UTF-8, so approximately -#: 10000 lines per megabyte at 100 chars per line, for pure ASCII, -#: unformatted text. A value of zero or less disables this feature. -#: The maximum allowed size is 4GB. Note that on config reload if this -#: is changed it will only affect newly created windows, not existing -#: ones. - -# scrollback_fill_enlarged_window no - -#: Fill new space with lines from the scrollback buffer after -#: enlarging a window. - -# wheel_scroll_multiplier 5.0 - -#: Multiplier for the number of lines scrolled by the mouse wheel. -#: Note that this is only used for low precision scrolling devices, -#: not for high precision scrolling devices on platforms such as macOS -#: and Wayland. Use negative numbers to change scroll direction. See -#: also wheel_scroll_min_lines. - -# wheel_scroll_min_lines 1 - -#: The minimum number of lines scrolled by the mouse wheel. The scroll -#: multiplier wheel_scroll_multiplier only takes effect after it -#: reaches this number. Note that this is only used for low precision -#: scrolling devices like wheel mice that scroll by very small amounts -#: when using the wheel. With a negative number, the minimum number of -#: lines will always be added. - -# touch_scroll_multiplier 1.0 - -#: Multiplier for the number of lines scrolled by a touchpad. Note -#: that this is only used for high precision scrolling devices on -#: platforms such as macOS and Wayland. Use negative numbers to change -#: scroll direction. - -#: }}} - -#: Mouse {{{ - -# mouse_hide_wait 3.0 - -#: Hide mouse cursor after the specified number of seconds of the -#: mouse not being used. Set to zero to disable mouse cursor hiding. -#: Set to a negative value to hide the mouse cursor immediately when -#: typing text. Disabled by default on macOS as getting it to work -#: robustly with the ever-changing sea of bugs that is Cocoa is too -#: much effort. - -# url_color #0087bd -# url_style curly - -#: The color and style for highlighting URLs on mouse-over. url_style -#: can be one of: none, straight, double, curly, dotted, dashed. - -# open_url_with default - -#: The program to open clicked URLs. The special value default with -#: first look for any URL handlers defined via the open_actions -#: facility and if non -#: are found, it will use the Operating System's default URL handler -#: (open on macOS and xdg-open on Linux). - -# url_prefixes file ftp ftps gemini git gopher http https irc ircs kitty mailto news sftp ssh - -#: The set of URL prefixes to look for when detecting a URL under the -#: mouse cursor. - -# detect_urls yes - -#: Detect URLs under the mouse. Detected URLs are highlighted with an -#: underline and the mouse cursor becomes a hand over them. Even if -#: this option is disabled, URLs are still clickable. See also the -#: underline_hyperlinks option to control how hyperlinks (as opposed -#: to plain text URLs) are displayed. - -# url_excluded_characters - -#: Additional characters to be disallowed from URLs, when detecting -#: URLs under the mouse cursor. By default, all characters that are -#: legal in URLs are allowed. Additionally, newlines are allowed (but -#: stripped). This is to accommodate programs such as mutt that add -#: hard line breaks even for continued lines. \n can be added to this -#: option to disable this behavior. Special characters can be -#: specified using backslash escapes, to specify a backslash use a -#: double backslash. - -# show_hyperlink_targets no - -#: When the mouse hovers over a terminal hyperlink, show the actual -#: URL that will be activated when the hyperlink is clicked. - -# underline_hyperlinks hover - -#: Control how hyperlinks are underlined. They can either be -#: underlined on mouse hover, always (i.e. permanently underlined) or -#: never which means that kitty will not apply any underline styling -#: to hyperlinks. Uses the url_style and url_color settings for the -#: underline style. Note that reloading the config and changing this -#: value to/from always will only affect text subsequently received by -#: kitty. - -# copy_on_select no - -#: Copy to clipboard or a private buffer on select. With this set to -#: clipboard, selecting text with the mouse will cause the text to be -#: copied to clipboard. Useful on platforms such as macOS that do not -#: have the concept of primary selection. You can instead specify a -#: name such as a1 to copy to a private kitty buffer. Map a shortcut -#: with the paste_from_buffer action to paste from this private -#: buffer. For example:: - -#: copy_on_select a1 -#: map shift+cmd+v paste_from_buffer a1 - -#: Note that copying to the clipboard is a security risk, as all -#: programs, including websites open in your browser can read the -#: contents of the system clipboard. - -# paste_actions quote-urls-at-prompt,confirm - -#: A comma separated list of actions to take when pasting text into -#: the terminal. The supported paste actions are: - -#: quote-urls-at-prompt: -#: If the text being pasted is a URL and the cursor is at a shell prompt, -#: automatically quote the URL (needs shell_integration). -#: replace-dangerous-control-codes -#: Replace dangerous control codes from pasted text, without confirmation. -#: replace-newline -#: Replace the newline character from pasted text, without confirmation. -#: confirm: -#: Confirm the paste if the text to be pasted contains any terminal control codes -#: as this can be dangerous, leading to code execution if the shell/program running -#: in the terminal does not properly handle these. -#: confirm-if-large -#: Confirm the paste if it is very large (larger than 16KB) as pasting -#: large amounts of text into shells can be very slow. -#: filter: -#: Run the filter_paste() function from the file paste-actions.py in -#: the kitty config directory on the pasted text. The text returned by the -#: function will be actually pasted. - -# strip_trailing_spaces never - -#: Remove spaces at the end of lines when copying to clipboard. A -#: value of smart will do it when using normal selections, but not -#: rectangle selections. A value of always will always do it. - -# select_by_word_characters @-./_~?&=%+# - -#: Characters considered part of a word when double clicking. In -#: addition to these characters any character that is marked as an -#: alphanumeric character in the Unicode database will be matched. - -# select_by_word_characters_forward - -#: Characters considered part of a word when extending the selection -#: forward on double clicking. In addition to these characters any -#: character that is marked as an alphanumeric character in the -#: Unicode database will be matched. - -#: If empty (default) select_by_word_characters will be used for both -#: directions. - -# click_interval -1.0 - -#: The interval between successive clicks to detect double/triple -#: clicks (in seconds). Negative numbers will use the system default -#: instead, if available, or fallback to 0.5. - -# focus_follows_mouse no - -#: Set the active window to the window under the mouse when moving the -#: mouse around. On macOS, this will also cause the OS Window under -#: the mouse to be focused automatically when the mouse enters it. - -# pointer_shape_when_grabbed arrow - -#: The shape of the mouse pointer when the program running in the -#: terminal grabs the mouse. - -# default_pointer_shape beam - -#: The default shape of the mouse pointer. - -# pointer_shape_when_dragging beam - -#: The default shape of the mouse pointer when dragging across text. - -#: Mouse actions {{{ - -#: Mouse buttons can be mapped to perform arbitrary actions. The -#: syntax is: - -#: .. code-block:: none - -#: mouse_map button-name event-type modes action - -#: Where button-name is one of left, middle, right, b1 ... b8 with -#: added keyboard modifiers. For example: ctrl+shift+left refers to -#: holding the Ctrl+Shift keys while clicking with the left mouse -#: button. The value b1 ... b8 can be used to refer to up to eight -#: buttons on a mouse. - -#: event-type is one of press, release, doublepress, triplepress, -#: click, doubleclick. modes indicates whether the action is performed -#: when the mouse is grabbed by the program running in the terminal, -#: or not. The values are grabbed or ungrabbed or a comma separated -#: combination of them. grabbed refers to when the program running in -#: the terminal has requested mouse events. Note that the click and -#: double click events have a delay of click_interval to disambiguate -#: from double and triple presses. - -#: You can run kitty with the kitty --debug-input command line option -#: to see mouse events. See the builtin actions below to get a sense -#: of what is possible. - -#: If you want to unmap an action, map it to no_op. For example, to -#: disable opening of URLs with a plain click:: - -#: mouse_map left click ungrabbed no_op - -#: See all the mappable actions including mouse actions here -#: . - -#: .. note:: -#: Once a selection is started, releasing the button that started it will -#: automatically end it and no release event will be dispatched. - -# clear_all_mouse_actions no - -#: Remove all mouse action definitions up to this point. Useful, for -#: instance, to remove the default mouse actions. - -#: Click the link under the mouse or move the cursor - -# mouse_map left click ungrabbed mouse_handle_click selection link prompt - -#:: First check for a selection and if one exists do nothing. Then -#:: check for a link under the mouse cursor and if one exists, click -#:: it. Finally check if the click happened at the current shell -#:: prompt and if so, move the cursor to the click location. Note -#:: that this requires shell integration -#:: to work. - -#: Click the link under the mouse or move the cursor even when grabbed - -# mouse_map shift+left click grabbed,ungrabbed mouse_handle_click selection link prompt - -#:: Same as above, except that the action is performed even when the -#:: mouse is grabbed by the program running in the terminal. - -#: Click the link under the mouse cursor - -# mouse_map ctrl+shift+left release grabbed,ungrabbed mouse_handle_click link - -#:: Variant with Ctrl+Shift is present because the simple click based -#:: version has an unavoidable delay of click_interval, to -#:: disambiguate clicks from double clicks. - -#: Discard press event for link click - -# mouse_map ctrl+shift+left press grabbed discard_event - -#:: Prevent this press event from being sent to the program that has -#:: grabbed the mouse, as the corresponding release event is used to -#:: open a URL. - -#: Paste from the primary selection - -# mouse_map middle release ungrabbed paste_from_selection - -#: Start selecting text - -# mouse_map left press ungrabbed mouse_selection normal - -#: Start selecting text in a rectangle - -# mouse_map ctrl+alt+left press ungrabbed mouse_selection rectangle - -#: Select a word - -# mouse_map left doublepress ungrabbed mouse_selection word - -#: Select a line - -# mouse_map left triplepress ungrabbed mouse_selection line - -#: Select line from point - -# mouse_map ctrl+alt+left triplepress ungrabbed mouse_selection line_from_point - -#:: Select from the clicked point to the end of the line. If you -#:: would like to select the word at the point and then extend to the -#:: rest of the line, change line_from_point to -#:: word_and_line_from_point. - -#: Extend the current selection - -# mouse_map right press ungrabbed mouse_selection extend - -#:: If you want only the end of the selection to be moved instead of -#:: the nearest boundary, use move-end instead of extend. - -#: Paste from the primary selection even when grabbed - -# mouse_map shift+middle release ungrabbed,grabbed paste_selection -# mouse_map shift+middle press grabbed discard_event - -#: Start selecting text even when grabbed - -# mouse_map shift+left press ungrabbed,grabbed mouse_selection normal - -#: Start selecting text in a rectangle even when grabbed - -# mouse_map ctrl+shift+alt+left press ungrabbed,grabbed mouse_selection rectangle - -#: Select a word even when grabbed - -# mouse_map shift+left doublepress ungrabbed,grabbed mouse_selection word - -#: Select a line even when grabbed - -# mouse_map shift+left triplepress ungrabbed,grabbed mouse_selection line - -#: Select line from point even when grabbed - -# mouse_map ctrl+shift+alt+left triplepress ungrabbed,grabbed mouse_selection line_from_point - -#:: Select from the clicked point to the end of the line even when -#:: grabbed. If you would like to select the word at the point and -#:: then extend to the rest of the line, change line_from_point to -#:: word_and_line_from_point. - -#: Extend the current selection even when grabbed - -# mouse_map shift+right press ungrabbed,grabbed mouse_selection extend - -#: Show clicked command output in pager - -# mouse_map ctrl+shift+right press ungrabbed mouse_show_command_output - -#:: Requires shell integration -#:: to work. - -#: }}} - -#: }}} - -#: Performance tuning {{{ - -# repaint_delay 10 - -#: Delay between screen updates (in milliseconds). Decreasing it, -#: increases frames-per-second (FPS) at the cost of more CPU usage. -#: The default value yields ~100 FPS which is more than sufficient for -#: most uses. Note that to actually achieve 100 FPS, you have to -#: either set sync_to_monitor to no or use a monitor with a high -#: refresh rate. Also, to minimize latency when there is pending input -#: to be processed, this option is ignored. - -# input_delay 3 - -#: Delay before input from the program running in the terminal is -#: processed (in milliseconds). Note that decreasing it will increase -#: responsiveness, but also increase CPU usage and might cause flicker -#: in full screen programs that redraw the entire screen on each loop, -#: because kitty is so fast that partial screen updates will be drawn. - -# sync_to_monitor yes - -#: Sync screen updates to the refresh rate of the monitor. This -#: prevents screen tearing -#: when scrolling. -#: However, it limits the rendering speed to the refresh rate of your -#: monitor. With a very high speed mouse/high keyboard repeat rate, -#: you may notice some slight input latency. If so, set this to no. - -#: }}} - -#: Terminal bell {{{ - -# enable_audio_bell yes - -#: The audio bell. Useful to disable it in environments that require -#: silence. - -# visual_bell_duration 0.0 - -#: The visual bell duration (in seconds). Flash the screen when a bell -#: occurs for the specified number of seconds. Set to zero to disable. - -# visual_bell_color none - -#: The color used by visual bell. Set to none will fall back to -#: selection background color. If you feel that the visual bell is too -#: bright, you can set it to a darker color. - -# window_alert_on_bell yes - -#: Request window attention on bell. Makes the dock icon bounce on -#: macOS or the taskbar flash on linux. - -# bell_on_tab "🔔 " - -#: Some text or a Unicode symbol to show on the tab if a window in the -#: tab that does not have focus has a bell. If you want to use leading -#: or trailing spaces, surround the text with quotes. See -#: tab_title_template for how this is rendered. - -#: For backwards compatibility, values of yes, y and true are -#: converted to the default bell symbol and no, n, false and none are -#: converted to the empty string. - -# command_on_bell none - -#: Program to run when a bell occurs. The environment variable -#: KITTY_CHILD_CMDLINE can be used to get the program running in the -#: window in which the bell occurred. - -# bell_path none - -#: Path to a sound file to play as the bell sound. If set to none, the -#: system default bell sound is used. Must be in a format supported by -#: the operating systems sound API, such as WAV or OGA on Linux -#: (libcanberra) or AIFF, MP3 or WAV on macOS (NSSound) - -# linux_bell_theme __custom - -#: The XDG Sound Theme kitty will use to play the bell sound. Defaults -#: to the custom theme name used by GNOME and Budgie, falling back to -#: the default freedesktop theme if it does not exist. This option may -#: be removed if Linux ever provides desktop-agnostic support for -#: setting system sound themes. - -#: }}} - -#: Window layout {{{ - -# remember_window_size yes -# initial_window_width 640 -# initial_window_height 400 - -#: If enabled, the OS Window size will be remembered so that new -#: instances of kitty will have the same size as the previous -#: instance. If disabled, the OS Window will initially have size -#: configured by initial_window_width/height, in pixels. You can use a -#: suffix of "c" on the width/height values to have them interpreted -#: as number of cells instead of pixels. - -# enabled_layouts * - -#: The enabled window layouts. A comma separated list of layout names. -#: The special value all means all layouts. The first listed layout -#: will be used as the startup layout. Default configuration is all -#: layouts in alphabetical order. For a list of available layouts, see -#: the layouts . - -# window_resize_step_cells 2 -# window_resize_step_lines 2 - -#: The step size (in units of cell width/cell height) to use when -#: resizing kitty windows in a layout with the shortcut -#: start_resizing_window. The cells value is used for horizontal -#: resizing, and the lines value is used for vertical resizing. - -# window_border_width 0.5pt - -#: The width of window borders. Can be either in pixels (px) or pts -#: (pt). Values in pts will be rounded to the nearest number of pixels -#: based on screen resolution. If not specified, the unit is assumed -#: to be pts. Note that borders are displayed only when more than one -#: window is visible. They are meant to separate multiple windows. - -# draw_minimal_borders yes - -#: Draw only the minimum borders needed. This means that only the -#: borders that separate the window from a neighbor are drawn. Note -#: that setting a non-zero window_margin_width overrides this and -#: causes all borders to be drawn. - -# window_margin_width 0 - -#: The window margin (in pts) (blank area outside the border). A -#: single value sets all four sides. Two values set the vertical and -#: horizontal sides. Three values set top, horizontal and bottom. Four -#: values set top, right, bottom and left. - -# single_window_margin_width -1 - -#: The window margin to use when only a single window is visible (in -#: pts). Negative values will cause the value of window_margin_width -#: to be used instead. A single value sets all four sides. Two values -#: set the vertical and horizontal sides. Three values set top, -#: horizontal and bottom. Four values set top, right, bottom and left. - -# window_padding_width 0 - -#: The window padding (in pts) (blank area between the text and the -#: window border). A single value sets all four sides. Two values set -#: the vertical and horizontal sides. Three values set top, horizontal -#: and bottom. Four values set top, right, bottom and left. - -# single_window_padding_width -1 - -#: The window padding to use when only a single window is visible (in -#: pts). Negative values will cause the value of window_padding_width -#: to be used instead. A single value sets all four sides. Two values -#: set the vertical and horizontal sides. Three values set top, -#: horizontal and bottom. Four values set top, right, bottom and left. - -# placement_strategy center - -#: When the window size is not an exact multiple of the cell size, the -#: cell area of the terminal window will have some extra padding on -#: the sides. You can control how that padding is distributed with -#: this option. Using a value of center means the cell area will be -#: placed centrally. A value of top-left means the padding will be -#: only at the bottom and right edges. - -# active_border_color #00ff00 - -#: The color for the border of the active window. Set this to none to -#: not draw borders around the active window. - -# inactive_border_color #cccccc - -#: The color for the border of inactive windows. - -# bell_border_color #ff5a00 - -#: The color for the border of inactive windows in which a bell has -#: occurred. - -# inactive_text_alpha 1.0 - -#: Fade the text in inactive windows by the specified amount (a number -#: between zero and one, with zero being fully faded). - -# hide_window_decorations no - -#: Hide the window decorations (title-bar and window borders) with -#: yes. On macOS, titlebar-only and titlebar-and-corners can be used -#: to only hide the titlebar and the rounded corners. Whether this -#: works and exactly what effect it has depends on the window -#: manager/operating system. Note that the effects of changing this -#: option when reloading config are undefined. When using titlebar- -#: only, it is useful to also set window_margin_width and -#: placement_strategy to prevent the rounded corners from clipping -#: text. Or use titlebar-and-corners. - -# window_logo_path none - -#: Path to a logo image. Must be in PNG format. Relative paths are -#: interpreted relative to the kitty config directory. The logo is -#: displayed in a corner of every kitty window. The position is -#: controlled by window_logo_position. Individual windows can be -#: configured to have different logos either using the launch action -#: or the remote control facility. - -# window_logo_position bottom-right - -#: Where to position the window logo in the window. The value can be -#: one of: top-left, top, top-right, left, center, right, bottom-left, -#: bottom, bottom-right. - -# window_logo_alpha 0.5 - -#: The amount the logo should be faded into the background. With zero -#: being fully faded and one being fully opaque. - -# resize_debounce_time 0.1 0.5 - -#: The time to wait before redrawing the screen during a live resize -#: of the OS window, when no new resize events have been received, -#: i.e. when resizing is either paused or finished. On platforms such -#: as macOS, where the operating system sends events corresponding to -#: the start and end of a live resize, the second number is used for -#: redraw-after-pause since kitty can distinguish between a pause and -#: end of resizing. On such systems the first number is ignored and -#: redraw is immediate after end of resize. On other systems the -#: first number is used so that kitty is "ready" quickly after the end -#: of resizing, while not also continuously redrawing, to save energy. - -# resize_in_steps no - -#: Resize the OS window in steps as large as the cells, instead of -#: with the usual pixel accuracy. Combined with initial_window_width -#: and initial_window_height in number of cells, this option can be -#: used to keep the margins as small as possible when resizing the OS -#: window. Note that this does not currently work on Wayland. - -# visual_window_select_characters 1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ - -#: The list of characters for visual window selection. For example, -#: for selecting a window to focus on with focus_visible_window. The -#: value should be a series of unique numbers or alphabets, case -#: insensitive, from the set 0-9A-Z\-=[];',./\\`. Specify your -#: preference as a string of characters. - -# confirm_os_window_close -1 - -#: Ask for confirmation when closing an OS window or a tab with at -#: least this number of kitty windows in it by window manager (e.g. -#: clicking the window close button or pressing the operating system -#: shortcut to close windows) or by the close_tab action. A value of -#: zero disables confirmation. This confirmation also applies to -#: requests to quit the entire application (all OS windows, via the -#: quit action). Negative values are converted to positive ones, -#: however, with shell_integration enabled, using negative values -#: means windows sitting at a shell prompt are not counted, only -#: windows where some command is currently running. Note that if you -#: want confirmation when closing individual windows, you can map the -#: close_window_with_confirmation action. - -#: }}} - -#: Tab bar {{{ - -# tab_bar_edge bottom - -#: The edge to show the tab bar on, top or bottom. - -# tab_bar_margin_width 0.0 - -#: The margin to the left and right of the tab bar (in pts). - -# tab_bar_margin_height 0.0 0.0 - -#: The margin above and below the tab bar (in pts). The first number -#: is the margin between the edge of the OS Window and the tab bar. -#: The second number is the margin between the tab bar and the -#: contents of the current tab. - -# tab_bar_style fade - -#: The tab bar style, can be one of: - -#: fade -#: Each tab's edges fade into the background color. (See also tab_fade) -#: slant -#: Tabs look like the tabs in a physical file. -#: separator -#: Tabs are separated by a configurable separator. (See also -#: tab_separator) -#: powerline -#: Tabs are shown as a continuous line with "fancy" separators. -#: (See also tab_powerline_style) -#: custom -#: A user-supplied Python function called draw_tab is loaded from the file -#: tab_bar.py in the kitty config directory. For examples of how to -#: write such a function, see the functions named draw_tab_with_* in -#: kitty's source code: kitty/tab_bar.py. See also -#: this discussion -#: for examples from kitty users. -#: hidden -#: The tab bar is hidden. If you use this, you might want to create -#: a mapping for the select_tab action which presents you with a list of -#: tabs and allows for easy switching to a tab. - -# tab_bar_align left - -#: The horizontal alignment of the tab bar, can be one of: left, -#: center, right. - -# tab_bar_min_tabs 2 - -#: The minimum number of tabs that must exist before the tab bar is -#: shown. - -# tab_switch_strategy previous - -#: The algorithm to use when switching to a tab when the current tab -#: is closed. The default of previous will switch to the last used -#: tab. A value of left will switch to the tab to the left of the -#: closed tab. A value of right will switch to the tab to the right of -#: the closed tab. A value of last will switch to the right-most tab. - -# tab_fade 0.25 0.5 0.75 1 - -#: Control how each tab fades into the background when using fade for -#: the tab_bar_style. Each number is an alpha (between zero and one) -#: that controls how much the corresponding cell fades into the -#: background, with zero being no fade and one being full fade. You -#: can change the number of cells used by adding/removing entries to -#: this list. - -# tab_separator " ┇" - -#: The separator between tabs in the tab bar when using separator as -#: the tab_bar_style. - -# tab_powerline_style angled - -#: The powerline separator style between tabs in the tab bar when -#: using powerline as the tab_bar_style, can be one of: angled, -#: slanted, round. - -# tab_activity_symbol none - -#: Some text or a Unicode symbol to show on the tab if a window in the -#: tab that does not have focus has some activity. If you want to use -#: leading or trailing spaces, surround the text with quotes. See -#: tab_title_template for how this is rendered. - -# tab_title_max_length 0 - -#: The maximum number of cells that can be used to render the text in -#: a tab. A value of zero means that no limit is applied. - -# tab_title_template "{fmt.fg.red}{bell_symbol}{activity_symbol}{fmt.fg.tab}{title}" - -#: A template to render the tab title. The default just renders the -#: title with optional symbols for bell and activity. If you wish to -#: include the tab-index as well, use something like: {index}:{title}. -#: Useful if you have shortcuts mapped for goto_tab N. If you prefer -#: to see the index as a superscript, use {sup.index}. All data -#: available is: - -#: title -#: The current tab title. -#: index -#: The tab index usable with goto_tab N goto_tab shortcuts. -#: layout_name -#: The current layout name. -#: num_windows -#: The number of windows in the tab. -#: num_window_groups -#: The number of window groups (a window group is a window and all of its overlay windows) in the tab. -#: tab.active_wd -#: The working directory of the currently active window in the tab -#: (expensive, requires syscall). Use active_oldest_wd to get -#: the directory of the oldest foreground process rather than the newest. -#: tab.active_exe -#: The name of the executable running in the foreground of the currently -#: active window in the tab (expensive, requires syscall). Use -#: active_oldest_exe for the oldest foreground process. -#: max_title_length -#: The maximum title length available. - -#: Note that formatting is done by Python's string formatting -#: machinery, so you can use, for instance, {layout_name[:2].upper()} -#: to show only the first two letters of the layout name, upper-cased. -#: If you want to style the text, you can use styling directives, for -#: example: -#: `{fmt.fg.red}red{fmt.fg.tab}normal{fmt.bg._00FF00}greenbg{fmt.bg.tab}`. -#: Similarly, for bold and italic: -#: `{fmt.bold}bold{fmt.nobold}normal{fmt.italic}italic{fmt.noitalic}`. -#: Note that for backward compatibility, if {bell_symbol} or -#: {activity_symbol} are not present in the template, they are -#: prepended to it. - -# active_tab_title_template none - -#: Template to use for active tabs. If not specified falls back to -#: tab_title_template. - -# active_tab_foreground #000 -# active_tab_background #eee -# active_tab_font_style bold-italic -# inactive_tab_foreground #444 -# inactive_tab_background #999 -# inactive_tab_font_style normal - -#: Tab bar colors and styles. - -# tab_bar_background none - -#: Background color for the tab bar. Defaults to using the terminal -#: background color. - -# tab_bar_margin_color none - -#: Color for the tab bar margin area. Defaults to using the terminal -#: background color for margins above and below the tab bar. For side -#: margins the default color is chosen to match the background color -#: of the neighboring tab. - -#: }}} - -#: Color scheme {{{ - -# foreground #dddddd -# background #000000 - -#: The foreground and background colors. - -background_opacity 0.9 - -#: The opacity of the background. A number between zero and one, where -#: one is opaque and zero is fully transparent. This will only work if -#: supported by the OS (for instance, when using a compositor under -#: X11). Note that it only sets the background color's opacity in -#: cells that have the same background color as the default terminal -#: background, so that things like the status bar in vim, powerline -#: prompts, etc. still look good. But it means that if you use a color -#: theme with a background color in your editor, it will not be -#: rendered as transparent. Instead you should change the default -#: background color in your kitty config and not use a background -#: color in the editor color scheme. Or use the escape codes to set -#: the terminals default colors in a shell script to launch your -#: editor. Be aware that using a value less than 1.0 is a (possibly -#: significant) performance hit. When using a low value for this -#: setting, it is desirable that you set the background color to a -#: color the matches the general color of the desktop background, for -#: best text rendering. If you want to dynamically change -#: transparency of windows, set dynamic_background_opacity to yes -#: (this is off by default as it has a performance cost). Changing -#: this option when reloading the config will only work if -#: dynamic_background_opacity was enabled in the original config. - -# background_blur 0 - -#: Set to a positive value to enable background blur (blurring of the -#: visuals behind a transparent window) on platforms that support it. -#: Only takes effect when background_opacity is less than one. On -#: macOS, this will also control the blur radius (amount of blurring). -#: Setting it to too high a value will cause severe performance issues -#: and/or rendering artifacts. Usually, values up to 64 work well. -#: Note that this might cause performance issues, depending on how the -#: platform implements it, so use with care. Currently supported on -#: macOS and KDE under X11. - -# background_image none - -#: Path to a background image. Must be in PNG format. - -# background_image_layout tiled - -#: Whether to tile, scale or clamp the background image. The value can -#: be one of tiled, mirror-tiled, scaled, clamped, centered or -#: cscaled. The scaled and cscaled values scale the image to the -#: window size, with cscaled preserving the image aspect ratio. - -# background_image_linear no - -#: When background image is scaled, whether linear interpolation -#: should be used. - -# dynamic_background_opacity no - -#: Allow changing of the background_opacity dynamically, using either -#: keyboard shortcuts (increase_background_opacity and -#: decrease_background_opacity) or the remote control facility. -#: Changing this option by reloading the config is not supported. - -# background_tint 0.0 - -#: How much to tint the background image by the background color. This -#: option makes it easier to read the text. Tinting is done using the -#: current background color for each window. This option applies only -#: if background_opacity is set and transparent windows are supported -#: or background_image is set. - -# background_tint_gaps 1.0 - -#: How much to tint the background image at the window gaps by the -#: background color, after applying background_tint. Since this is -#: multiplicative with background_tint, it can be used to lighten the -#: tint over the window gaps for a *separated* look. - -# dim_opacity 0.4 - -#: How much to dim text that has the DIM/FAINT attribute set. One -#: means no dimming and zero means fully dimmed (i.e. invisible). - -# selection_foreground #000000 -# selection_background #fffacd - -#: The foreground and background colors for text selected with the -#: mouse. Setting both of these to none will cause a "reverse video" -#: effect for selections, where the selection will be the cell text -#: color and the text will become the cell background color. Setting -#: only selection_foreground to none will cause the foreground color -#: to be used unchanged. Note that these colors can be overridden by -#: the program running in the terminal. - -#: The color table {{{ - -#: The 256 terminal colors. There are 8 basic colors, each color has a -#: dull and bright version, for the first 16 colors. You can set the -#: remaining 240 colors as color16 to color255. - -# color0 #000000 -# color8 #767676 - -#: black - -# color1 #cc0403 -# color9 #f2201f - -#: red - -# color2 #19cb00 -# color10 #23fd00 - -#: green - -# color3 #cecb00 -# color11 #fffd00 - -#: yellow - -# color4 #0d73cc -# color12 #1a8fff - -#: blue - -# color5 #cb1ed1 -# color13 #fd28ff - -#: magenta - -# color6 #0dcdcd -# color14 #14ffff - -#: cyan - -# color7 #dddddd -# color15 #ffffff - -#: white - -# mark1_foreground black - -#: Color for marks of type 1 - -# mark1_background #98d3cb - -#: Color for marks of type 1 (light steel blue) - -# mark2_foreground black - -#: Color for marks of type 2 - -# mark2_background #f2dcd3 - -#: Color for marks of type 1 (beige) - -# mark3_foreground black - -#: Color for marks of type 3 - -# mark3_background #f274bc - -#: Color for marks of type 3 (violet) - -#: }}} - -#: }}} - -#: Advanced {{{ - -# shell . - -#: The shell program to execute. The default value of . means to use -#: whatever shell is set as the default shell for the current user. -#: Note that on macOS if you change this, you might need to add -#: --login and --interactive to ensure that the shell starts in -#: interactive mode and reads its startup rc files. Environment -#: variables are expanded in this setting. - -# editor . - -#: The terminal based text editor (such as vim or nano) to use when -#: editing the kitty config file or similar tasks. - -#: The default value of . means to use the environment variables -#: VISUAL and EDITOR in that order. If these variables aren't set, -#: kitty will run your shell ($SHELL -l -i -c env) to see if your -#: shell startup rc files set VISUAL or EDITOR. If that doesn't work, -#: kitty will cycle through various known editors (vim, emacs, etc.) -#: and take the first one that exists on your system. - -# close_on_child_death no - -#: Close the window when the child process (shell) exits. With the -#: default value no, the terminal will remain open when the child -#: exits as long as there are still processes outputting to the -#: terminal (for example disowned or backgrounded processes). When -#: enabled with yes, the window will close as soon as the child -#: process exits. Note that setting it to yes means that any -#: background processes still using the terminal can fail silently -#: because their stdout/stderr/stdin no longer work. - -# remote_control_password - -#: Allow other programs to control kitty using passwords. This option -#: can be specified multiple times to add multiple passwords. If no -#: passwords are present kitty will ask the user for permission if a -#: program tries to use remote control with a password. A password can -#: also *optionally* be associated with a set of allowed remote -#: control actions. For example:: - -#: remote_control_password "my passphrase" get-colors set-colors focus-window focus-tab - -#: Only the specified actions will be allowed when using this -#: password. Glob patterns can be used too, for example:: - -#: remote_control_password "my passphrase" set-tab-* resize-* - -#: To get a list of available actions, run:: - -#: kitten @ --help - -#: A set of actions to be allowed when no password is sent can be -#: specified by using an empty password. For example:: - -#: remote_control_password "" *-colors - -#: Finally, the path to a python module can be specified that provides -#: a function is_cmd_allowed that is used to check every remote -#: control command. For example:: - -#: remote_control_password "my passphrase" my_rc_command_checker.py - -#: Relative paths are resolved from the kitty configuration directory. -#: See rc_custom_auth for details. - -# allow_remote_control no - -#: Allow other programs to control kitty. If you turn this on, other -#: programs can control all aspects of kitty, including sending text -#: to kitty windows, opening new windows, closing windows, reading the -#: content of windows, etc. Note that this even works over SSH -#: connections. The default setting of no prevents any form of remote -#: control. The meaning of the various values are: - -#: password -#: Remote control requests received over both the TTY device and the socket -#: are confirmed based on passwords, see remote_control_password. - -#: socket-only -#: Remote control requests received over a socket are accepted -#: unconditionally. Requests received over the TTY are denied. -#: See listen_on. - -#: socket -#: Remote control requests received over a socket are accepted -#: unconditionally. Requests received over the TTY are confirmed based on -#: password. - -#: no -#: Remote control is completely disabled. - -#: yes -#: Remote control requests are always accepted. - -# listen_on none - -#: Listen to the specified socket for remote control connections. Note -#: that this will apply to all kitty instances. It can be overridden -#: by the kitty --listen-on command line option. For UNIX sockets, -#: such as unix:${TEMP}/mykitty or unix:@mykitty (on Linux). -#: Environment variables are expanded and relative paths are resolved -#: with respect to the temporary directory. If {kitty_pid} is present, -#: then it is replaced by the PID of the kitty process, otherwise the -#: PID of the kitty process is appended to the value, with a hyphen. -#: For TCP sockets such as tcp:localhost:0 a random port is always -#: used even if a non-zero port number is specified. See the help for -#: kitty --listen-on for more details. Note that this will be ignored -#: unless allow_remote_control is set to either: yes, socket or -#: socket-only. Changing this option by reloading the config is not -#: supported. - -# env - -#: Specify the environment variables to be set in all child processes. -#: Using the name with an equal sign (e.g. env VAR=) will set it to -#: the empty string. Specifying only the name (e.g. env VAR) will -#: remove the variable from the child process' environment. Note that -#: environment variables are expanded recursively, for example:: - -#: env VAR1=a -#: env VAR2=${HOME}/${VAR1}/b - -#: The value of VAR2 will be /a/b. - -# watcher - -#: Path to python file which will be loaded for watchers -#: . Can be -#: specified more than once to load multiple watchers. The watchers -#: will be added to every kitty window. Relative paths are resolved -#: relative to the kitty config directory. Note that reloading the -#: config will only affect windows created after the reload. - -# exe_search_path - -#: Control where kitty finds the programs to run. The default search -#: order is: First search the system wide PATH, then ~/.local/bin and -#: ~/bin. If still not found, the PATH defined in the login shell -#: after sourcing all its startup files is tried. Finally, if present, -#: the PATH specified by the env option is tried. - -#: This option allows you to prepend, append, or remove paths from -#: this search order. It can be specified multiple times for multiple -#: paths. A simple path will be prepended to the search order. A path -#: that starts with the + sign will be append to the search order, -#: after ~/bin above. A path that starts with the - sign will be -#: removed from the entire search order. For example:: - -#: exe_search_path /some/prepended/path -#: exe_search_path +/some/appended/path -#: exe_search_path -/some/excluded/path - -# update_check_interval 24 - -#: The interval to periodically check if an update to kitty is -#: available (in hours). If an update is found, a system notification -#: is displayed informing you of the available update. The default is -#: to check every 24 hours, set to zero to disable. Update checking is -#: only done by the official binary builds. Distro packages or source -#: builds do not do update checking. Changing this option by reloading -#: the config is not supported. - -# startup_session none - -#: Path to a session file to use for all kitty instances. Can be -#: overridden by using the kitty --session =none command line option -#: for individual instances. See sessions -#: in the kitty -#: documentation for details. Note that relative paths are interpreted -#: with respect to the kitty config directory. Environment variables -#: in the path are expanded. Changing this option by reloading the -#: config is not supported. - -# clipboard_control write-clipboard write-primary read-clipboard-ask read-primary-ask - -#: Allow programs running in kitty to read and write from the -#: clipboard. You can control exactly which actions are allowed. The -#: possible actions are: write-clipboard, read-clipboard, write- -#: primary, read-primary, read-clipboard-ask, read-primary-ask. The -#: default is to allow writing to the clipboard and primary selection -#: and to ask for permission when a program tries to read from the -#: clipboard. Note that disabling the read confirmation is a security -#: risk as it means that any program, even the ones running on a -#: remote server via SSH can read your clipboard. See also -#: clipboard_max_size. - -# clipboard_max_size 512 - -#: The maximum size (in MB) of data from programs running in kitty -#: that will be stored for writing to the system clipboard. A value of -#: zero means no size limit is applied. See also clipboard_control. - -# file_transfer_confirmation_bypass - -#: The password that can be supplied to the file transfer kitten -#: to skip the -#: transfer confirmation prompt. This should only be used when -#: initiating transfers from trusted computers, over trusted networks -#: or encrypted transports, as it allows any programs running on the -#: remote machine to read/write to the local filesystem, without -#: permission. - -# allow_hyperlinks yes - -#: Process hyperlink escape sequences (OSC 8). If disabled OSC 8 -#: escape sequences are ignored. Otherwise they become clickable -#: links, that you can click with the mouse or by using the hints -#: kitten . The -#: special value of ask means that kitty will ask before opening the -#: link when clicked. - -# shell_integration enabled - -#: Enable shell integration on supported shells. This enables features -#: such as jumping to previous prompts, browsing the output of the -#: previous command in a pager, etc. on supported shells. Set to -#: disabled to turn off shell integration, completely. It is also -#: possible to disable individual features, set to a space separated -#: list of these values: no-rc, no-cursor, no-title, no-cwd, no- -#: prompt-mark, no-complete, no-sudo. See Shell integration -#: for details. - -# allow_cloning ask - -#: Control whether programs running in the terminal can request new -#: windows to be created. The canonical example is clone-in-kitty -#: . -#: By default, kitty will ask for permission for each clone request. -#: Allowing cloning unconditionally gives programs running in the -#: terminal (including over SSH) permission to execute arbitrary code, -#: as the user who is running the terminal, on the computer that the -#: terminal is running on. - -# clone_source_strategies venv,conda,env_var,path - -#: Control what shell code is sourced when running clone-in-kitty in -#: the newly cloned window. The supported strategies are: - -#: venv -#: Source the file $VIRTUAL_ENV/bin/activate. This is used by the -#: Python stdlib venv module and allows cloning venvs automatically. -#: conda -#: Run conda activate $CONDA_DEFAULT_ENV. This supports the virtual -#: environments created by conda. -#: env_var -#: Execute the contents of the environment variable -#: KITTY_CLONE_SOURCE_CODE with eval. -#: path -#: Source the file pointed to by the environment variable -#: KITTY_CLONE_SOURCE_PATH. - -#: This option must be a comma separated list of the above values. -#: Only the first valid match, in the order specified, is sourced. - -# term xterm-kitty - -#: The value of the TERM environment variable to set. Changing this -#: can break many terminal programs, only change it if you know what -#: you are doing, not because you read some advice on "Stack Overflow" -#: to change it. The TERM variable is used by various programs to get -#: information about the capabilities and behavior of the terminal. If -#: you change it, depending on what programs you run, and how -#: different the terminal you are changing it to is, various things -#: from key-presses, to colors, to various advanced features may not -#: work. Changing this option by reloading the config will only affect -#: newly created windows. - -# forward_stdio no - -#: Forward STDOUT and STDERR of the kitty process to child processes -#: as file descriptors 3 and 4. This is useful for debugging as it -#: allows child processes to print to kitty's STDOUT directly. For -#: example, echo hello world >&3 in a shell will print to the parent -#: kitty's STDOUT. When enabled, this also sets the -#: KITTY_STDIO_FORWARDED=3 environment variable so child processes -#: know about the forwarding. - -# menu_map - -#: Specify entries for various menus in kitty. Currently only the -#: global menubar on macOS is supported. For example:: - -#: menu_map global "Actions::Launch something special" launch --hold --type=os-window sh -c "echo hello world" - -#: This will create a menu entry named "Launch something special" in -#: an "Actions" menu in the macOS global menubar. Sub-menus can be -#: created by adding more levels separated by ::. - -#: }}} - -#: OS specific tweaks {{{ - -# wayland_titlebar_color system - -#: The color of the kitty window's titlebar on Wayland systems with -#: client side window decorations such as GNOME. A value of system -#: means to use the default system color, a value of background means -#: to use the background color of the currently active window and -#: finally you can use an arbitrary color, such as #12af59 or red. - -# macos_titlebar_color system - -#: The color of the kitty window's titlebar on macOS. A value of -#: system means to use the default system color, light or dark can -#: also be used to set it explicitly. A value of background means to -#: use the background color of the currently active window and finally -#: you can use an arbitrary color, such as #12af59 or red. WARNING: -#: This option works by using a hack when arbitrary color (or -#: background) is configured, as there is no proper Cocoa API for it. -#: It sets the background color of the entire window and makes the -#: titlebar transparent. As such it is incompatible with -#: background_opacity. If you want to use both, you are probably -#: better off just hiding the titlebar with hide_window_decorations. - -# macos_option_as_alt no - -#: Use the Option key as an Alt key on macOS. With this set to no, -#: kitty will use the macOS native Option+Key to enter Unicode -#: character behavior. This will break any Alt+Key keyboard shortcuts -#: in your terminal programs, but you can use the macOS Unicode input -#: technique. You can use the values: left, right or both to use only -#: the left, right or both Option keys as Alt, instead. Note that -#: kitty itself always treats Option the same as Alt. This means you -#: cannot use this option to configure different kitty shortcuts for -#: Option+Key vs. Alt+Key. Also, any kitty shortcuts using -#: Option/Alt+Key will take priority, so that any such key presses -#: will not be passed to terminal programs running inside kitty. -#: Changing this option by reloading the config is not supported. - -# macos_hide_from_tasks no - -#: Hide the kitty window from running tasks on macOS (⌘+Tab and the -#: Dock). Changing this option by reloading the config is not -#: supported. - -# macos_quit_when_last_window_closed no - -#: Have kitty quit when all the top-level windows are closed on macOS. -#: By default, kitty will stay running, even with no open windows, as -#: is the expected behavior on macOS. - -# macos_window_resizable yes - -#: Disable this if you want kitty top-level OS windows to not be -#: resizable on macOS. - -# macos_thicken_font 0 - -#: Draw an extra border around the font with the given width, to -#: increase legibility at small font sizes on macOS. For example, a -#: value of 0.75 will result in rendering that looks similar to sub- -#: pixel antialiasing at common font sizes. Note that in modern kitty, -#: this option is obsolete (although still supported). Consider using -#: text_composition_strategy instead. - -# macos_traditional_fullscreen no - -#: Use the macOS traditional full-screen transition, that is faster, -#: but less pretty. - -# macos_show_window_title_in all - -#: Control where the window title is displayed on macOS. A value of -#: window will show the title of the currently active window at the -#: top of the macOS window. A value of menubar will show the title of -#: the currently active window in the macOS global menu bar, making -#: use of otherwise wasted space. A value of all will show the title -#: in both places, and none hides the title. See -#: macos_menubar_title_max_length for how to control the length of the -#: title in the menu bar. - -# macos_menubar_title_max_length 0 - -#: The maximum number of characters from the window title to show in -#: the macOS global menu bar. Values less than one means that there is -#: no maximum limit. - -# macos_custom_beam_cursor no - -#: Use a custom mouse cursor for macOS that is easier to see on both -#: light and dark backgrounds. Nowadays, the default macOS cursor -#: already comes with a white border. WARNING: this might make your -#: mouse cursor invisible on dual GPU machines. Changing this option -#: by reloading the config is not supported. - -# macos_colorspace srgb - -#: The colorspace in which to interpret terminal colors. The default -#: of srgb will cause colors to match those seen in web browsers. The -#: value of default will use whatever the native colorspace of the -#: display is. The value of displayp3 will use Apple's special -#: snowflake display P3 color space, which will result in over -#: saturated (brighter) colors with some color shift. Reloading -#: configuration will change this value only for newly created OS -#: windows. - -# linux_display_server auto - -#: Choose between Wayland and X11 backends. By default, an appropriate -#: backend based on the system state is chosen automatically. Set it -#: to x11 or wayland to force the choice. Changing this option by -#: reloading the config is not supported. - -#: }}} - -#: Keyboard shortcuts {{{ - -#: Keys are identified simply by their lowercase Unicode characters. -#: For example: a for the A key, [ for the left square bracket key, -#: etc. For functional keys, such as Enter or Escape, the names are -#: present at Functional key definitions -#: . -#: For modifier keys, the names are ctrl (control, ⌃), shift (⇧), alt -#: (opt, option, ⌥), super (cmd, command, ⌘). See also: GLFW mods -#: - -#: On Linux you can also use XKB key names to bind keys that are not -#: supported by GLFW. See XKB keys -#: for a list of key names. The name to use is the part -#: after the XKB_KEY_ prefix. Note that you can only use an XKB key -#: name for keys that are not known as GLFW keys. - -#: Finally, you can use raw system key codes to map keys, again only -#: for keys that are not known as GLFW keys. To see the system key -#: code for a key, start kitty with the kitty --debug-input option, -#: kitty will output some debug text for every key event. In that text -#: look for native_code, the value of that becomes the key name in the -#: shortcut. For example: - -#: .. code-block:: none - -#: on_key_input: glfw key: 0x61 native_code: 0x61 action: PRESS mods: none text: 'a' - -#: Here, the key name for the A key is 0x61 and you can use it with:: - -#: map ctrl+0x61 something - -#: to map Ctrl+A to something. - -#: You can use the special action no_op to unmap a keyboard shortcut -#: that is assigned in the default configuration:: - -#: map kitty_mod+space no_op - -#: If you would like kitty to completely ignore a key event, not even -#: sending it to the program running in the terminal, map it to -#: discard_event:: - -#: map kitty_mod+f1 discard_event - -#: You can combine multiple actions to be triggered by a single -#: shortcut with combine action, using the syntax below:: - -#: map key combine action1 action2 action3 ... - -#: For example:: - -#: map kitty_mod+e combine : new_window : next_layout - -#: This will create a new window and switch to the next available -#: layout. - -#: You can use multi-key shortcuts with the syntax shown below:: - -#: map key1>key2>key3 action - -#: For example:: - -#: map ctrl+f>2 set_font_size 20 - -#: The full list of actions that can be mapped to key presses is -#: available here . - -# kitty_mod ctrl+shift - -#: Special modifier key alias for default shortcuts. You can change -#: the value of this option to alter all default shortcuts that use -#: kitty_mod. - -# clear_all_shortcuts no - -#: Remove all shortcut definitions up to this point. Useful, for -#: instance, to remove the default shortcuts. - -# action_alias - -#: E.g. action_alias launch_tab launch --type=tab --cwd=current - -#: Define action aliases to avoid repeating the same options in -#: multiple mappings. Aliases can be defined for any action and will -#: be expanded recursively. For example, the above alias allows you to -#: create mappings to launch a new tab in the current working -#: directory without duplication:: - -#: map f1 launch_tab vim -#: map f2 launch_tab emacs - -#: Similarly, to alias kitten invocation:: - -#: action_alias hints kitten hints --hints-offset=0 - -# kitten_alias - -#: E.g. kitten_alias hints hints --hints-offset=0 - -#: Like action_alias above, but specifically for kittens. Generally, -#: prefer to use action_alias. This option is a legacy version, -#: present for backwards compatibility. It causes all invocations of -#: the aliased kitten to be substituted. So the example above will -#: cause all invocations of the hints kitten to have the --hints- -#: offset=0 option applied. - -#: Clipboard {{{ - -#: Copy to clipboard - -# map kitty_mod+c copy_to_clipboard -# map cmd+c copy_to_clipboard - -#:: There is also a copy_or_interrupt action that can be optionally -#:: mapped to Ctrl+C. It will copy only if there is a selection and -#:: send an interrupt otherwise. Similarly, -#:: copy_and_clear_or_interrupt will copy and clear the selection or -#:: send an interrupt if there is no selection. - -#: Paste from clipboard - -# map kitty_mod+v paste_from_clipboard -# map cmd+v paste_from_clipboard - -#: Paste from selection - -# map kitty_mod+s paste_from_selection -# map shift+insert paste_from_selection - -#: Pass selection to program - -# map kitty_mod+o pass_selection_to_program - -#:: You can also pass the contents of the current selection to any -#:: program with pass_selection_to_program. By default, the system's -#:: open program is used, but you can specify your own, the selection -#:: will be passed as a command line argument to the program. For -#:: example:: - -#:: map kitty_mod+o pass_selection_to_program firefox - -#:: You can pass the current selection to a terminal program running -#:: in a new kitty window, by using the @selection placeholder:: - -#:: map kitty_mod+y new_window less @selection - -#: }}} - -#: Scrolling {{{ - -#: Scroll line up - -# map kitty_mod+up scroll_line_up -# map kitty_mod+k scroll_line_up -# map opt+cmd+page_up scroll_line_up -# map cmd+up scroll_line_up - -#: Scroll line down - -# map kitty_mod+down scroll_line_down -# map kitty_mod+j scroll_line_down -# map opt+cmd+page_down scroll_line_down -# map cmd+down scroll_line_down - -#: Scroll page up - -# map kitty_mod+page_up scroll_page_up -# map cmd+page_up scroll_page_up - -#: Scroll page down - -# map kitty_mod+page_down scroll_page_down -# map cmd+page_down scroll_page_down - -#: Scroll to top - -# map kitty_mod+home scroll_home -# map cmd+home scroll_home - -#: Scroll to bottom - -# map kitty_mod+end scroll_end -# map cmd+end scroll_end - -#: Scroll to previous shell prompt - -# map kitty_mod+z scroll_to_prompt -1 - -#:: Use a parameter of 0 for scroll_to_prompt to scroll to the last -#:: jumped to or the last clicked position. Requires shell -#:: integration -#:: to work. - -#: Scroll to next shell prompt - -# map kitty_mod+x scroll_to_prompt 1 - -#: Browse scrollback buffer in pager - -# map kitty_mod+h show_scrollback - -#:: You can pipe the contents of the current screen and history -#:: buffer as STDIN to an arbitrary program using launch --stdin- -#:: source. For example, the following opens the scrollback buffer in -#:: less in an overlay window:: - -#:: map f1 launch --stdin-source=@screen_scrollback --stdin-add-formatting --type=overlay less +G -R - -#:: For more details on piping screen and buffer contents to external -#:: programs, see launch . - -#: Browse output of the last shell command in pager - -# map kitty_mod+g show_last_command_output - -#:: You can also define additional shortcuts to get the command -#:: output. For example, to get the first command output on screen:: - -#:: map f1 show_first_command_output_on_screen - -#:: To get the command output that was last accessed by a keyboard -#:: action or mouse action:: - -#:: map f1 show_last_visited_command_output - -#:: You can pipe the output of the last command run in the shell -#:: using the launch action. For example, the following opens the -#:: output in less in an overlay window:: - -#:: map f1 launch --stdin-source=@last_cmd_output --stdin-add-formatting --type=overlay less +G -R - -#:: To get the output of the first command on the screen, use -#:: @first_cmd_output_on_screen. To get the output of the last jumped -#:: to command, use @last_visited_cmd_output. - -#:: Requires shell integration -#:: to work. - -#: }}} - -#: Window management {{{ - -#: New window - -# map kitty_mod+enter new_window -# map cmd+enter new_window - -#:: You can open a new kitty window running an arbitrary program, for -#:: example:: - -#:: map kitty_mod+y launch mutt - -#:: You can open a new window with the current working directory set -#:: to the working directory of the current window using:: - -#:: map ctrl+alt+enter launch --cwd=current - -#:: You can open a new window that is allowed to control kitty via -#:: the kitty remote control facility with launch --allow-remote- -#:: control. Any programs running in that window will be allowed to -#:: control kitty. For example:: - -#:: map ctrl+enter launch --allow-remote-control some_program - -#:: You can open a new window next to the currently active window or -#:: as the first window, with:: - -#:: map ctrl+n launch --location=neighbor -#:: map ctrl+f launch --location=first - -#:: For more details, see launch -#:: . - -#: New OS window - -# map kitty_mod+n new_os_window -# map cmd+n new_os_window - -#:: Works like new_window above, except that it opens a top-level OS -#:: window. In particular you can use new_os_window_with_cwd to open -#:: a window with the current working directory. - -#: Close window - -# map kitty_mod+w close_window -# map shift+cmd+d close_window - -#: Next window - -# map kitty_mod+] next_window - -#: Previous window - -# map kitty_mod+[ previous_window - -#: Move window forward - -# map kitty_mod+f move_window_forward - -#: Move window backward - -# map kitty_mod+b move_window_backward - -#: Move window to top - -# map kitty_mod+` move_window_to_top - -#: Start resizing window - -# map kitty_mod+r start_resizing_window -# map cmd+r start_resizing_window - -#: First window - -# map kitty_mod+1 first_window -# map cmd+1 first_window - -#: Second window - -# map kitty_mod+2 second_window -# map cmd+2 second_window - -#: Third window - -# map kitty_mod+3 third_window -# map cmd+3 third_window - -#: Fourth window - -# map kitty_mod+4 fourth_window -# map cmd+4 fourth_window - -#: Fifth window - -# map kitty_mod+5 fifth_window -# map cmd+5 fifth_window - -#: Sixth window - -# map kitty_mod+6 sixth_window -# map cmd+6 sixth_window - -#: Seventh window - -# map kitty_mod+7 seventh_window -# map cmd+7 seventh_window - -#: Eighth window - -# map kitty_mod+8 eighth_window -# map cmd+8 eighth_window - -#: Ninth window - -# map kitty_mod+9 ninth_window -# map cmd+9 ninth_window - -#: Tenth window - -# map kitty_mod+0 tenth_window - -#: Visually select and focus window - -# map kitty_mod+f7 focus_visible_window - -#:: Display overlay numbers and alphabets on the window, and switch -#:: the focus to the window when you press the key. When there are -#:: only two windows, the focus will be switched directly without -#:: displaying the overlay. You can change the overlay characters and -#:: their order with option visual_window_select_characters. - -#: Visually swap window with another - -# map kitty_mod+f8 swap_with_window - -#:: Works like focus_visible_window above, but swaps the window. - -#: }}} - -#: Tab management {{{ - -#: Next tab - -# map kitty_mod+right next_tab -# map shift+cmd+] next_tab -# map ctrl+tab next_tab - -#: Previous tab - -# map kitty_mod+left previous_tab -# map shift+cmd+[ previous_tab -# map ctrl+shift+tab previous_tab - -#: New tab - -# map kitty_mod+t new_tab -# map cmd+t new_tab - -#: Close tab - -# map kitty_mod+q close_tab -# map cmd+w close_tab - -#: Close OS window - -# map shift+cmd+w close_os_window - -#: Move tab forward - -# map kitty_mod+. move_tab_forward - -#: Move tab backward - -# map kitty_mod+, move_tab_backward - -#: Set tab title - -# map kitty_mod+alt+t set_tab_title -# map shift+cmd+i set_tab_title - - -#: You can also create shortcuts to go to specific tabs, with 1 being -#: the first tab, 2 the second tab and -1 being the previously active -#: tab, and any number larger than the last tab being the last tab:: - -#: map ctrl+alt+1 goto_tab 1 -#: map ctrl+alt+2 goto_tab 2 - -#: Just as with new_window above, you can also pass the name of -#: arbitrary commands to run when using new_tab and new_tab_with_cwd. -#: Finally, if you want the new tab to open next to the current tab -#: rather than at the end of the tabs list, use:: - -#: map ctrl+t new_tab !neighbor [optional cmd to run] -#: }}} - -#: Layout management {{{ - -#: Next layout - -# map kitty_mod+l next_layout - - -#: You can also create shortcuts to switch to specific layouts:: - -#: map ctrl+alt+t goto_layout tall -#: map ctrl+alt+s goto_layout stack - -#: Similarly, to switch back to the previous layout:: - -#: map ctrl+alt+p last_used_layout - -#: There is also a toggle_layout action that switches to the named -#: layout or back to the previous layout if in the named layout. -#: Useful to temporarily "zoom" the active window by switching to the -#: stack layout:: - -#: map ctrl+alt+z toggle_layout stack -#: }}} - -#: Font sizes {{{ - -#: You can change the font size for all top-level kitty OS windows at -#: a time or only the current one. - -#: Increase font size - -# map kitty_mod+equal change_font_size all +2.0 -# map kitty_mod+plus change_font_size all +2.0 -# map kitty_mod+kp_add change_font_size all +2.0 -# map cmd+plus change_font_size all +2.0 -# map cmd+equal change_font_size all +2.0 -# map shift+cmd+equal change_font_size all +2.0 - -#: Decrease font size - -# map kitty_mod+minus change_font_size all -2.0 -# map kitty_mod+kp_subtract change_font_size all -2.0 -# map cmd+minus change_font_size all -2.0 -# map shift+cmd+minus change_font_size all -2.0 - -#: Reset font size - -# map kitty_mod+backspace change_font_size all 0 -# map cmd+0 change_font_size all 0 - - -#: To setup shortcuts for specific font sizes:: - -#: map kitty_mod+f6 change_font_size all 10.0 - -#: To setup shortcuts to change only the current OS window's font -#: size:: - -#: map kitty_mod+f6 change_font_size current 10.0 -#: }}} - -#: Select and act on visible text {{{ - -#: Use the hints kitten to select text and either pass it to an -#: external program or insert it into the terminal or copy it to the -#: clipboard. - -#: Open URL - -# map kitty_mod+e open_url_with_hints - -#:: Open a currently visible URL using the keyboard. The program used -#:: to open the URL is specified in open_url_with. - -#: Insert selected path - -# map kitty_mod+p>f kitten hints --type path --program - - -#:: Select a path/filename and insert it into the terminal. Useful, -#:: for instance to run git commands on a filename output from a -#:: previous git command. - -#: Open selected path - -# map kitty_mod+p>shift+f kitten hints --type path - -#:: Select a path/filename and open it with the default open program. - -#: Insert selected line - -# map kitty_mod+p>l kitten hints --type line --program - - -#:: Select a line of text and insert it into the terminal. Useful for -#:: the output of things like: `ls -1`. - -#: Insert selected word - -# map kitty_mod+p>w kitten hints --type word --program - - -#:: Select words and insert into terminal. - -#: Insert selected hash - -# map kitty_mod+p>h kitten hints --type hash --program - - -#:: Select something that looks like a hash and insert it into the -#:: terminal. Useful with git, which uses SHA1 hashes to identify -#:: commits. - -#: Open the selected file at the selected line - -# map kitty_mod+p>n kitten hints --type linenum - -#:: Select something that looks like filename:linenum and open it in -#:: vim at the specified line number. - -#: Open the selected hyperlink - -# map kitty_mod+p>y kitten hints --type hyperlink - -#:: Select a hyperlink (i.e. a URL that has been marked as such by -#:: the terminal program, for example, by `ls --hyperlink=auto`). - - -#: The hints kitten has many more modes of operation that you can map -#: to different shortcuts. For a full description see hints kitten -#: . -#: }}} - -#: Miscellaneous {{{ - -#: Show documentation - -# map kitty_mod+f1 show_kitty_doc overview - -#: Toggle fullscreen - -# map kitty_mod+f11 toggle_fullscreen -# map ctrl+cmd+f toggle_fullscreen - -#: Toggle maximized - -# map kitty_mod+f10 toggle_maximized - -#: Toggle macOS secure keyboard entry - -# map opt+cmd+s toggle_macos_secure_keyboard_entry - -#: Unicode input - -# map kitty_mod+u kitten unicode_input -# map ctrl+cmd+space kitten unicode_input - -#: Edit config file - -# map kitty_mod+f2 edit_config_file -# map cmd+, edit_config_file - -#: Open the kitty command shell - -# map kitty_mod+escape kitty_shell window - -#:: Open the kitty shell in a new window / tab / overlay / os_window -#:: to control kitty using commands. - -#: Increase background opacity - -# map kitty_mod+a>m set_background_opacity +0.1 - -#: Decrease background opacity - -# map kitty_mod+a>l set_background_opacity -0.1 - -#: Make background fully opaque - -# map kitty_mod+a>1 set_background_opacity 1 - -#: Reset background opacity - -# map kitty_mod+a>d set_background_opacity default - -#: Reset the terminal - -# map kitty_mod+delete clear_terminal reset active -# map opt+cmd+r clear_terminal reset active - -#:: You can create shortcuts to clear/reset the terminal. For -#:: example:: - -#:: # Reset the terminal -#:: map f1 clear_terminal reset active -#:: # Clear the terminal screen by erasing all contents -#:: map f1 clear_terminal clear active -#:: # Clear the terminal scrollback by erasing it -#:: map f1 clear_terminal scrollback active -#:: # Scroll the contents of the screen into the scrollback -#:: map f1 clear_terminal scroll active -#:: # Clear everything up to the line with the cursor -#:: map f1 clear_terminal to_cursor active - -#:: If you want to operate on all kitty windows instead of just the -#:: current one, use all instead of active. - -#:: Some useful functions that can be defined in the shell rc files -#:: to perform various kinds of clearing of the current window: - -#:: .. code-block:: sh - -#:: clear-only-screen() { -#:: printf "\e[H\e[2J" -#:: } - -#:: clear-screen-and-scrollback() { -#:: printf "\e[H\e[3J" -#:: } - -#:: clear-screen-saving-contents-in-scrollback() { -#:: printf "\e[H\e[22J" -#:: } - -#:: For instance, using these escape codes, it is possible to remap -#:: Ctrl+L to both scroll the current screen contents into the -#:: scrollback buffer and clear the screen, instead of just clearing -#:: the screen. For ZSH, in ~/.zshrc, add: - -#:: .. code-block:: zsh - -#:: ctrl_l() { -#:: builtin print -rn -- $'\r\e[0J\e[H\e[22J' >"$TTY" -#:: builtin zle .reset-prompt -#:: builtin zle -R -#:: } -#:: zle -N ctrl_l -#:: bindkey '^l' ctrl_l - -#: Clear up to cursor line - -# map cmd+k clear_terminal to_cursor active - -#: Reload kitty.conf - -# map kitty_mod+f5 load_config_file -# map ctrl+cmd+, load_config_file - -#:: Reload kitty.conf, applying any changes since the last time it -#:: was loaded. Note that a handful of options cannot be dynamically -#:: changed and require a full restart of kitty. Particularly, when -#:: changing shortcuts for actions located on the macOS global menu -#:: bar, a full restart is needed. You can also map a keybinding to -#:: load a different config file, for example:: - -#:: map f5 load_config /path/to/alternative/kitty.conf - -#:: Note that all options from the original kitty.conf are discarded, -#:: in other words the new configuration *replace* the old ones. - -#: Debug kitty configuration - -# map kitty_mod+f6 debug_config -# map opt+cmd+, debug_config - -#:: Show details about exactly what configuration kitty is running -#:: with and its host environment. Useful for debugging issues. - -#: Send arbitrary text on key presses - -#:: E.g. map ctrl+shift+alt+h send_text all Hello World - -#:: You can tell kitty to send arbitrary (UTF-8) encoded text to the -#:: client program when pressing specified shortcut keys. For -#:: example:: - -#:: map ctrl+alt+a send_text all Special text - -#:: This will send "Special text" when you press the Ctrl+Alt+A key -#:: combination. The text to be sent decodes ANSI C escapes -#:: so you can use escapes like \e to send control -#:: codes or \u21fb to send Unicode characters (or you can just input -#:: the Unicode characters directly as UTF-8 text). You can use -#:: `kitten show_key` to get the key escape codes you want to -#:: emulate. - -#:: The first argument to send_text is the keyboard modes in which to -#:: activate the shortcut. The possible values are normal, -#:: application, kitty or a comma separated combination of them. The -#:: modes normal and application refer to the DECCKM cursor key mode -#:: for terminals, and kitty refers to the kitty extended keyboard -#:: protocol. The special value all means all of them. - -#:: Some more examples:: - -#:: # Output a word and move the cursor to the start of the line (like typing and pressing Home) -#:: map ctrl+alt+a send_text normal Word\e[H -#:: map ctrl+alt+a send_text application Word\eOH -#:: # Run a command at a shell prompt (like typing the command and pressing Enter) -#:: map ctrl+alt+a send_text normal,application some command with arguments\r - -#: Open kitty Website - -# map shift+cmd+/ open_url https://sw.kovidgoyal.net/kitty/ - -#: Hide macOS kitty application - -# map cmd+h hide_macos_app - -#: Hide macOS other applications - -# map opt+cmd+h hide_macos_other_apps - -#: Minimize macOS window - -# map cmd+m minimize_macos_window - -#: Quit kitty - -# map cmd+q quit - -#: }}} - -#: }}} - - -# BEGIN_KITTY_THEME -# Tokyo Night -include current-theme.conf -# END_KITTY_THEME \ No newline at end of file diff --git a/lf/.config/lf/lfrc b/lf/.config/lf/lfrc deleted file mode 100644 index a68582e..0000000 --- a/lf/.config/lf/lfrc +++ /dev/null @@ -1,219 +0,0 @@ -# interpreter for shell commands -set shell sh - -# set '-eu' options for shell commands -# These options are used to have safer shell commands. Option '-e' is used to -# exit on error and option '-u' is used to give error for unset variables. -# Option '-f' disables pathname expansion which can be useful when $f, $fs, and -# $fx variables contain names with '*' or '?' characters. However, this option -# is used selectively within individual commands as it can be limiting at -# times. -set shellopts '-eu' - -# set internal field separator (IFS) to "\n" for shell commands -# This is useful to automatically split file names in $fs and $fx properly -# since default file separator used in these variables (i.e. 'filesep' option) -# is newline. You need to consider the values of these options and create your -# commands accordingly. -set ifs "\n" - -# leave some space at the top and the bottom of the screen -set scrolloff 10 - -# Use the `dim` attribute instead of underline for the cursor in the preview pane -set cursorpreviewfmt "\033[7;2m" - -# Image previews -set cleaner ~/.config/lf/scripts/lf_kitty_clean -set previewer ~/.config/lf/scripts/lf_kitty_preview - -# automatic refresh -set period 1 - -# file and dir size -set info size -set dircounts - -# remap goto top and bottom -map J bottom -map gg -map K top - -# cool dirs and shit -map gc cd ~/Projects -map gC cd ~/config -map gd cd ~/Documents -map gD cd ~/Downloads -# games -map gge cd ~/Emulation -map ggm cd ~/.var/app/org.prismlauncher.PrismLauncher/data/PrismLauncher/instances -map ggs cd ~/.local/share/Steam/steamapps/common -# music -map gm cd ~/Music -# pictures -map gps cd ~/Pictures/Screenshots -map gpp cd ~/Pictures -map gpw cd ~/Pictures/Wallpapers -# videos -map gvr cd ~/Videos/Recording -map gvv cd ~/Videos - -# use enter for shell commands -map shell - -# show the result of execution of previous commands -map ` !true - -# execute current file (must be executable) -map x $$f -map X !$f - -# dedicated keys for file opener actions -map o &mimeopen $f -map O $mimeopen --ask $f - -# define a custom 'open' command -# This command is called when current file is not a directory. You may want to -# use either file extensions and/or mime types here. Below uses an editor for -# text files and a file opener for the rest. -cmd open &{{ - case $(file --mime-type -Lb $f) in - text/*) lf -remote "send $id \$$EDITOR \$fx";; - *) for f in $fx; do $OPENER $f > /dev/null 2> /dev/null & done;; - esac -}} - -# mkdir command. See wiki if you want it to select created dir -map a :push %mkdir - -# define a custom 'rename' command without prompt for overwrite -# cmd rename %[ -e $1 ] && printf "file exists" || mv $f $1 -# map r push :rename - -# make sure trash folder exists -# %mkdir -p ~/.trash - -# move current file or selected files to trash folder -cmd trash %trash-put $fx - -# use '' key for either 'trash' or 'delete' command -map trash -map D trash -# map delete - -# extract the current file with the right command -# (xkcd link: https://xkcd.com/1168/) -cmd extract ${{ - set -f - case $f in - *.tar.bz|*.tar.bz2|*.tbz|*.tbz2) tar xjvf $f;; - *.tar.gz|*.tgz) tar xzvf $f;; - *.tar.xz|*.txz) tar xJvf $f;; - *.zip) unzip $f;; - *.rar) unrar x $f;; - *.7z) 7z x $f;; - esac -}} - -# compress current file or selected files with tar and gunzip -cmd tar ${{ - set -f - mkdir $1 - cp -r $fx $1 - tar czf $1.tar.gz $1 - rm -rf $1 -}} - -# compress current file or selected files with zip -cmd zip ${{ - set -f - mkdir $1 - cp -r $fx $1 - zip -r $1.zip $1 - rm -rf $1 -}} - -# use eza instead of ls for file info -cmd on-select &{{ - lf -remote "send $id set statfmt \"$(eza -ld --color=always "$f")\"" -}} - -cmd on-cd &{{ - # display repository status in your prompt - if [ -d .git ] || [ -f .git ]; then - branch=$(git branch --show-current 2>/dev/null) || true - remote=$(git config --get branch.$branch.remote 2>/dev/null) || true - url=$(git remote get-url $remote 2>/dev/null) || true - fmt="\033[32;1m%u@%h\033[0m:\033[34;1m%w\033[0m\033[33;1m [GIT BRANCH:> $branch >> $url]\033[0m" - elif [ -d .hg ]; then - hg=$(hg branch 2>/dev/null) || true - fmt="\033[32;1m%u@%h\033[0m:\033[34;1m%w\033[0m\033[33;1m [HG BRANCH:> $hg]\033[0m" - elif [ -d .svn ]; then - svn=$(svn info 2>/dev/null | awk '/^URL: /{print $2}') || true - fmt="\033[32;1m%u@%h\033[0m:\033[34;1m%w\033[0m\033[33;1m [SVN URL:> $svn]\033[0m" - else - fmt="\033[32;1m%u@%h\033[0m:\033[34;1m%d\033[0m\033[1m%f\033[0m" - fi - lf -remote "send $id set promptfmt \"$fmt\"" - - # update terminal name - printf "\033]0; ${PWD/#$HOME/\~}\007" > /dev/tty -}} - -on-cd - -# search all files for text -cmd fzf_search ${{ - RG_PREFIX="rg --column --line-number --no-heading --color=always --smart-case " - res="$( - FZF_DEFAULT_COMMAND="$RG_PREFIX ''" \ - fzf --bind "change:reload:$RG_PREFIX {q} || true" \ - --ansi --layout=reverse --header 'Search in files' \ - | cut -d':' -f1 | sed 's/\\/\\\\/g;s/"/\\"/g' - )" - [ -n "$res" ] && lf -remote "send $id select \"$res\"" -}} - -map ? :fzf_search - -# Use rsync for paste -cmd paste &{{ - set -- $(cat ~/.local/share/lf/files) - mode="$1" - shift - case "$mode" in - copy) - rsync -av --ignore-existing --progress -- "$@" . | - stdbuf -i0 -o0 -e0 tr '\r' '\n' | - while IFS= read -r line; do - lf -remote "send $id echo $line" - done - ;; - move) mv -n -- "$@" .;; - esac - rm ~/.local/share/lf/files - lf -remote "send clear" -}} - -# follow symlinks -cmd follow_link %{{ - lf -remote "send ${id} select '$(readlink $f)'" -}} - -map gL follow_link - -# move selected files to new folder -cmd newfold ${{ - set -f - printf "Directory name: " - read newd - mkdir -- "$newd" - mv -- $fx "$newd" -}} - -map newfold - -cmd open-with-gui &$@ $fx ## opens with a gui application outside lf client -cmd open-with-cli $$@ $fx ## opens with a cli application inside lf client -map O push :open-with-gui ## input application -map o push :open-with-cli ## input application diff --git a/lf/.config/lf/scripts/lf_kitty_clean b/lf/.config/lf/scripts/lf_kitty_clean deleted file mode 100755 index 4bffb33..0000000 --- a/lf/.config/lf/scripts/lf_kitty_clean +++ /dev/null @@ -1,5 +0,0 @@ -#!/usr/bin/env bash - -# From https://github.com/gokcehan/lf/wiki/Previews#with-kitty-and-pistol - -kitty +kitten icat --clear --stdin no --silent --transfer-mode file < /dev/null > /dev/tty diff --git a/lf/.config/lf/scripts/lf_kitty_preview b/lf/.config/lf/scripts/lf_kitty_preview deleted file mode 100755 index 3d2ad6e..0000000 --- a/lf/.config/lf/scripts/lf_kitty_preview +++ /dev/null @@ -1,20 +0,0 @@ -#!/usr/bin/env bash - -# From https://github.com/gokcehan/lf/wiki/Previews#with-kitty-and-pistol -# Includes fallback for non-images - -file=$1 -w=$2 -h=$3 -x=$4 -y=$5 - -case "$(file -Lb --mime-type -- "$1")" in - image/*) - kitty +kitten icat --silent --stdin no --transfer-mode file --place "${w}x${h}@${x}x${y}" "$file" < /dev/null > /dev/tty - exit 1 - ;; - *) - cat "$1" - ;; -esac diff --git a/mako/.config/mako/config b/mako/.config/mako/config deleted file mode 100644 index 89024d8..0000000 --- a/mako/.config/mako/config +++ /dev/null @@ -1,8 +0,0 @@ -font=Noto Sans 16 -background-color=#1a1b26e6 -text-color=#c0caf5 -width=500 -height=400 -padding=8 -border-color=#414868 -default-timeout=15000 diff --git a/mpv/.config/mpv/mpv.conf b/mpv/.config/mpv/mpv.conf deleted file mode 100644 index f42be63..0000000 --- a/mpv/.config/mpv/mpv.conf +++ /dev/null @@ -1,6 +0,0 @@ -hwdec=auto-safe,no -osd-bar=no -profile=gpu-hq -video-sync=display-resample -vo=dmabuf-wayland,gpu,sdl -ytdl-raw-options="format-sort=res:1080" diff --git a/mpv/.config/mpv/script-opts/uosc.conf b/mpv/.config/mpv/script-opts/uosc.conf deleted file mode 100644 index 32cb589..0000000 --- a/mpv/.config/mpv/script-opts/uosc.conf +++ /dev/null @@ -1,233 +0,0 @@ -# Display style of current position. available: line, bar -timeline_style=line -# Line display style config -timeline_line_width=2 -# Timeline size when fully expanded, in pixels, 0 to disable -timeline_size=40 -# Comma separated states when element should always be fully visible. -# Available: paused, audio, image, video, idle, windowed, fullscreen -timeline_persistency= -# Top border of background color to help visually separate timeline from video -timeline_border=1 -# When scrolling above timeline, wheel will seek by this amount of seconds -timeline_step=5 -# Render cache indicators for streaming content -timeline_cache=yes - -# When to display an always visible progress bar (minimized timeline). Can be: windowed, fullscreen, always, never -# Can also be toggled on demand with `toggle-progress` command. -progress=windowed -progress_size=2 -progress_line_width=20 - -# A comma delimited list of controls above the timeline. Set to `never` to disable. -# Parameter spec: enclosed in `{}` means value, enclosed in `[]` means optional -# Full item syntax: `[<[!]{disposition1}[,[!]{dispositionN}]>]{element}[:{paramN}][#{badge}[>{limit}]][?{tooltip}]` -# Common properties: -# `{icon}` - parameter used to specify an icon name (example: `face`) -# - pick here: https://fonts.google.com/icons?icon.platform=web&icon.set=Material+Icons&icon.style=Rounded -# `{element}`s and their parameters: -# `{shorthand}` - preconfigured shorthands: -# `play-pause`, `menu`, `subtitles`, `audio`, `video`, `playlist`, -# `chapters`, `editions`, `stream-quality`, `open-file`, `items`, -# `next`, `prev`, `first`, `last`, `audio-device`, `fullscreen`, -# `loop-playlist`, `loop-file`, `shuffle` -# `speed[:{scale}]` - display speed slider, [{scale}] - factor of controls_size, default: 1.3 -# `command:{icon}:{command}` - button that executes a {command} when pressed -# `toggle:{icon}:{prop}[@{owner}]` - button that toggles mpv property -# `cycle:{default_icon}:{prop}[@{owner}]:{value1}[={icon1}][!]/{valueN}[={iconN}][!]` -# - button that cycles mpv property between values, each optionally having different icon and active flag -# - presence of `!` at the end will style the button as active -# - `{owner}` is the name of a script that manages this property if any -# `gap[:{scale}]` - display an empty gap -# {scale} - factor of controls_size, default: 0.3 -# `space` - fills all available space between previous and next item, useful to align items to the right -# - multiple spaces divide the available space among themselves, which can be used for centering -# Item visibility control: -# `<[!]{disposition1}[,[!]{dispositionN}]>` - optional prefix to control element's visibility -# - `{disposition}` can be one of: -# - `idle` - true if mpv is in idle mode (no file loaded) -# - `image` - true if current file is a single image -# - `audio` - true for audio only files -# - `video` - true for files with a video track -# - `has_many_video` - true for files with more than one video track -# - `has_image` - true for files with a cover or other image track -# - `has_audio` - true for files with an audio track -# - `has_many_audio` - true for files with more than one audio track -# - `has_sub` - true for files with an subtitle track -# - `has_many_sub` - true for files with more than one subtitle track -# - `has_many_edition` - true for files with more than one edition -# - `has_chapter` - true for files with chapter list -# - `stream` - true if current file is read from a stream -# - `has_playlist` - true if current playlist has 2 or more items in it -# - prefix with `!` to negate the required disposition -# Examples: -# - `stream-quality` - show stream quality button only for streams -# - `audio` - show audio tracks button for all files that have -# an audio track, but are not exclusively audio only files -# Place `#{badge}[>{limit}]` after the element params to give it a badge. Available badges: -# `sub`, `audio`, `video` - track type counters -# `{mpv_prop}` - any mpv prop that makes sense to you: https://mpv.io/manual/master/#property-list -# - if prop value is an array it'll display its size -# `>{limit}` will display the badge only if it's numerical value is above this threshold. -# Example: `#audio>1` -# Place `?{tooltip}` after the element config to give it a tooltip. -# Example implementations: -# menu = command:menu:script-binding uosc/menu-blurred?Menu -# subtitles = command:subtitles:script-binding uosc/subtitles#sub?Subtitles -# fullscreen = cycle:crop_free:fullscreen:no/yes=fullscreen_exit!?Fullscreen -# loop-playlist = cycle:repeat:loop-playlist:no/inf!?Loop playlist -# toggle:{icon}:{prop} = cycle:{icon}:{prop}:no/yes! -controls=menu,gap,subtitles,audio,video,editions,stream-quality,gap,space,speed,space,shuffle,loop-playlist,loop-file,gap,prev,items,next,gap,fullscreen -controls_size=32 -controls_margin=8 -controls_spacing=2 -controls_persistency= - -# Where to display volume controls: none, left, right -volume=right -volume_size=40 -volume_border=1 -volume_step=1 -volume_persistency= - -# Playback speed widget: mouse drag or wheel to change, click to reset -speed_step=0.1 -speed_step_is_factor=no -speed_persistency= - -# Controls all menus, such as context menu, subtitle loader/selector, etc -menu_item_height=36 -menu_min_width=260 -menu_padding=4 -# Determines if `/` or `ctrl+f` is required to activate the search, or if typing -# any text is sufficient. -# When enabled, you can no longer toggle a menu off with the same key that opened it, if the key is a unicode character. -menu_type_to_search=yes - -# Top bar with window controls and media title -# Can be: never, no-border, always -top_bar=no-border -top_bar_size=40 -top_bar_controls=yes -# Can be: `no` (hide), `yes` (inherit title from mpv.conf), or a custom template string -top_bar_title=yes -# Template string to enable alternative top bar title. If alt title matches main title, -# it'll be hidden. Tip: use `${media-title}` for main, and `${filename}` for alt title. -top_bar_alt_title= -# Can be: -# `below` => display alt title below the main one -# `toggle` => toggle the top bar title text between main and alt by clicking -# the top bar, or calling `toggle-title` binding -top_bar_alt_title_place=below -# Flash top bar when any of these file types is loaded. Available: audio,image,video -top_bar_flash_on=video,audio -top_bar_persistency= - -# Window border drawn in no-border mode -window_border_size=1 - -# If there's no playlist and file ends, load next file in the directory -# Requires `keep-open=yes` in `mpv.conf`. -autoload=no -# What types to accept as next item when autoloading or requesting to play next file -# Can be: video, audio, image, subtitle -autoload_types=video,audio,image -# Enable uosc's playlist/directory shuffle mode -# This simply makes the next selected playlist or directory item be random, just -# like any other player in the world. It also has an easily togglable control button. -shuffle=no - -# Scale the interface by this factor -scale=1 -# Scale in fullscreen -scale_fullscreen=1.3 -# Adjust the text scaling to fit your font -font_scale=1 -# Border of text and icons when drawn directly on top of video -text_border=1.2 -# Border radius of buttons, menus, and all other rectangles -border_radius=4 -# A comma delimited list of color overrides in RGB HEX format. Defaults: -# foreground=ffffff,foreground_text=000000,background=000000,background_text=ffffff,curtain=111111,success=a5e075,error=ff616e -color= -# A comma delimited list of opacity overrides for various UI element backgrounds and shapes. -# This does not affect any text, which is always rendered fully opaque. Defaults: -# timeline=0.9,position=1,chapters=0.8,slider=0.9,slider_gauge=1,controls=0,speed=0.6,menu=1,submenu=0.4,border=1,title=1,tooltip=1,thumbnail=1,curtain=0.8,idle_indicator=0.8,audio_indicator=0.5,buffering_indicator=0.3,playlist_position=0.8 -opacity= -# A comma delimited list of features to refine at a cost of some performance impact. -# text_width - Use a more accurate text width measurement that measures each text string individually -# instead of just measuring the width of known letters once and adding them up. -# sorting - Use filename sorting that handles non-english languages better, especially asian ones. -# At the moment, this is only available on windows, and has no effect on other platforms. -refine= -# Duration of animations in milliseconds -animation_duration=100 -# Execute command for background clicks shorter than this number of milliseconds, 0 to disable -# Execution always waits for `input-doubleclick-time` to filter out double-clicks -click_threshold=0 -click_command=cycle pause; script-binding uosc/flash-pause-indicator -# Flash duration in milliseconds used by `flash-{element}` commands -flash_duration=1000 -# Distances in pixels below which elements are fully faded in/out -proximity_in=40 -proximity_out=120 -# Use only bold font weight throughout the whole UI -font_bold=no -# One of `total`, `playtime-remaining` (scaled by the current speed), `time-remaining` (remaining length of file) -destination_time=playtime-remaining -# Display sub second fraction in timestamps up to this precision -time_precision=0 -# Display stream's buffered time in timeline if it's lower than this amount of seconds, 0 to disable -buffered_time_threshold=60 -# Hide UI when mpv autohides the cursor. Timing is controlled by `cursor-autohide` in `mpv.conf` (in milliseconds). -autohide=no -# Can be: flash, static, manual (controlled by flash-pause-indicator and decide-pause-indicator commands) -pause_indicator=flash -# Sizes to list in stream quality menu -stream_quality_options=4320,2160,1440,1080,720,480,360,240,144 -# Types to identify media files -video_types=3g2,3gp,asf,avi,f4v,flv,h264,h265,m2ts,m4v,mkv,mov,mp4,mp4v,mpeg,mpg,ogm,ogv,rm,rmvb,ts,vob,webm,wmv,y4m -audio_types=aac,ac3,aiff,ape,au,cue,dsf,dts,flac,m4a,mid,midi,mka,mp3,mp4a,oga,ogg,opus,spx,tak,tta,wav,weba,wma,wv -image_types=apng,avif,bmp,gif,j2k,jp2,jfif,jpeg,jpg,jxl,mj2,png,svg,tga,tif,tiff,webp -subtitle_types=aqt,ass,gsub,idx,jss,lrc,mks,pgs,pjs,psb,rt,sbv,slt,smi,sub,sup,srt,ssa,ssf,ttxt,txt,usf,vt,vtt -# Default open-file menu directory -default_directory=~/ -# List hidden files when reading directories. Due to environment limitations, this currently only hides -# files starting with a dot. Doesn't hide hidden files on windows (we have no way to tell they're hidden). -show_hidden_files=no -# Move files to trash (recycle bin) when deleting files. Dependencies: -# - Linux: `sudo apt install trash-cli` -# - MacOS: `brew install trash` -use_trash=no -# Adjusted osd margins based on the visibility of UI elements -adjust_osd_margins=yes - -# Adds chapter range indicators to some common chapter types. -# Additionally to displaying the start of the chapter as a diamond icon on top of the timeline, -# the portion of the timeline of that chapter range is also colored based on the config below. -# -# The syntax is a comma-delimited list of `{type}:{color}` pairs, where: -# `{type}` => range type. Currently supported ones are: -# - `openings`, `endings` => anime openings/endings -# - `intros`, `outros` => video intros/outros -# - `ads` => segments created by sponsor-block software like https://github.com/po5/mpv_sponsorblock -# `{color}` => an RGB(A) HEX color code (`rrggbb`, or `rrggbbaa`) -# -# To exclude marking any of the range types, simply remove them from the list. -chapter_ranges=openings:30abf964,endings:30abf964,ads:c54e4e80 -# Add alternative lua patterns to identify beginnings of simple chapter ranges (except for `ads`) -# Syntax: `{type}:{pattern}[,{patternN}][;{type}:{pattern}[,{patternN}]]` -chapter_range_patterns=openings:オープニング;endings:エンディング - -# Localization language priority from highest to lowest. -# Also controls what languages are fetched by `download-subtitles` menu. -# Built in languages can be found in `uosc/intl`. -# `slang` is a keyword to inherit values from `--slang` mpv config. -# Supports paths to custom json files: `languages=~~/custom.json,slang,en` -languages=slang,en - -# A comma separated list of element IDs to disable. Available IDs: -# window_border, top_bar, timeline, controls, volume, -# idle_indicator, audio_indicator, buffering_indicator, pause_indicator -disable_elements= diff --git a/ranger/.config/ranger/rc.conf b/ranger/dot-config/ranger/rc.conf similarity index 96% rename from ranger/.config/ranger/rc.conf rename to ranger/dot-config/ranger/rc.conf index 87bf442..9ea8e37 100644 --- a/ranger/.config/ranger/rc.conf +++ b/ranger/dot-config/ranger/rc.conf @@ -39,7 +39,7 @@ set show_hidden false # Ask for a confirmation when running the "delete" command? # Valid values are "always", "never", "multiple" (default) # With "multiple", ranger will ask only if you delete multiple files at once. -set confirm_on_delete multiple +set confirm_on_delete always # Use non-default path for file preview script? # ranger ships with scope.sh, a script that calls external programs (see @@ -57,7 +57,7 @@ set automatically_count_files true set open_all_images true # Be aware of version control systems and display information. -set vcs_aware true +set vcs_aware false # State of the four backends git, hg, bzr, svn. The possible states are # disabled, local (only show local info), enabled (show local and remote @@ -114,7 +114,7 @@ set preview_images true # Preview images in full color with the external command "ueberzug". # Images are shown by using a child window. # Only for users who run X11 in GNU/Linux. -set preview_images_method kitty +set preview_images_method sixel # Delay in seconds before displaying an image with the w3m method. # Increase it in case of experiencing display corruption. @@ -128,11 +128,11 @@ set iterm2_font_width 8 set iterm2_font_height 11 # Use a unicode "..." character to mark cut-off filenames? -set unicode_ellipsis false +set unicode_ellipsis true # BIDI support - try to properly display file names in RTL languages (Hebrew, Arabic). # Requires the python-bidi pip package -set bidi_support false +set bidi_support true # Show dotfiles in the bookmark preview box? set show_hidden_bookmarks true @@ -148,7 +148,7 @@ set preview_directories true set collapse_preview true # Wrap long lines in plain text previews? -set wrap_plaintext_previews false +set wrap_plaintext_previews true # Save the console history on exit? set save_console_history true @@ -164,7 +164,7 @@ set draw_progress_bar_in_status_bar true # Separators are vertical lines between columns. # Outline draws a box around all the columns. # Both combines the two. -set draw_borders none +set draw_borders separators # Display the directory name in tabs? set dirname_in_tabs true @@ -447,30 +447,21 @@ map } traverse map { traverse_backwards map ) jump_non -map gh cd ~ -map ge cd /etc -map gm cd /media +map ghh cd ~ +map ghc cd ~/config +map ghC cd ~/.config +map ghd cd ~/Documents +map ghD cd ~/Downloads +map ghgm cd ~/.var/app/org.prismlauncher.PrismLauncher/data/PrismLauncher +map ghgs cd ~/.local/share/Steam/steamapps/common +map ghm cd ~/Music +map ghp cd ~/Pictures +map ghP cd ~/Projects +map ghv cd ~/Videos +map gl cd -r . +map gL cd -r %f map gi eval fm.cd('/run/media/' + os.getenv('USER')) -map gM cd /mnt -map gr cd / -map gR eval fm.cd(ranger.RANGERDIR) map g/ cd / -map g? cd /usr/share/doc/ranger - -map gd cd ~/Documents -map gD cd ~/Downloads -map gm cd ~/Music -map gpp cd ~/Pictures -map gps cd ~/Pictures/Screenshots -map gpw cd ~/Pictures/Wallpapers -map gvv cd ~/Videos -map gvr cd ~/Videos/Recording -map ggd cd ~/.var/app/org.zdoom.GZDoom/.config/gzdoom -map ggh cd ~/Games/Heroic -map ggl cd ~/Games/Lutris -map ggm cd ~/.var/app/org.prismlauncher.PrismLauncher/data/PrismLauncher/instances -map ggs cd ~/.local/share/Steam/steamapps/common -map gr cd /run/media/ollie # External Programs map E edit @@ -480,7 +471,6 @@ map yp yank path map yd yank dir map yn yank name map y. yank name_without_extension -map F open_with nautilus f # Filesystem Operations map = chmod @@ -765,4 +755,3 @@ tmap eval -q fm.ui.taskview.task_remove() tmap redraw_window tmap taskview_close copytmap q Q w - diff --git a/ranger/dot-config/ranger/scope.sh b/ranger/dot-config/ranger/scope.sh new file mode 100755 index 0000000..e21ebfc --- /dev/null +++ b/ranger/dot-config/ranger/scope.sh @@ -0,0 +1,356 @@ +#!/usr/bin/env bash + +set -o noclobber -o noglob -o nounset -o pipefail +IFS=$'\n' + +## If the option `use_preview_script` is set to `true`, +## then this script will be called and its output will be displayed in ranger. +## ANSI color codes are supported. +## STDIN is disabled, so interactive scripts won't work properly + +## This script is considered a configuration file and must be updated manually. +## It will be left untouched if you upgrade ranger. + +## Because of some automated testing we do on the script #'s for comments need +## to be doubled up. Code that is commented out, because it's an alternative for +## example, gets only one #. + +## Meanings of exit codes: +## code | meaning | action of ranger +## -----+------------+------------------------------------------- +## 0 | success | Display stdout as preview +## 1 | no preview | Display no preview at all +## 2 | plain text | Display the plain content of the file +## 3 | fix width | Don't reload when width changes +## 4 | fix height | Don't reload when height changes +## 5 | fix both | Don't ever reload +## 6 | image | Display the image `$IMAGE_CACHE_PATH` points to as an image preview +## 7 | image | Display the file directly as an image + +## Script arguments +FILE_PATH="${1}" # Full path of the highlighted file +PV_WIDTH="${2}" # Width of the preview pane (number of fitting characters) +## shellcheck disable=SC2034 # PV_HEIGHT is provided for convenience and unused +PV_HEIGHT="${3}" # Height of the preview pane (number of fitting characters) +IMAGE_CACHE_PATH="${4}" # Full path that should be used to cache image preview +PV_IMAGE_ENABLED="${5}" # 'True' if image previews are enabled, 'False' otherwise. + +FILE_EXTENSION="${FILE_PATH##*.}" +FILE_EXTENSION_LOWER="$(printf "%s" "${FILE_EXTENSION}" | tr '[:upper:]' '[:lower:]')" + +## Settings +HIGHLIGHT_SIZE_MAX=262143 # 256KiB +HIGHLIGHT_TABWIDTH=${HIGHLIGHT_TABWIDTH:-8} +HIGHLIGHT_STYLE=${HIGHLIGHT_STYLE:-pablo} +HIGHLIGHT_OPTIONS="--replace-tabs=${HIGHLIGHT_TABWIDTH} --style=${HIGHLIGHT_STYLE} ${HIGHLIGHT_OPTIONS:-}" +PYGMENTIZE_STYLE=${PYGMENTIZE_STYLE:-autumn} +OPENSCAD_IMGSIZE=${RNGR_OPENSCAD_IMGSIZE:-1000,1000} +OPENSCAD_COLORSCHEME=${RNGR_OPENSCAD_COLORSCHEME:-Tomorrow Night} + +handle_extension() { + case "${FILE_EXTENSION_LOWER}" in + ## Archive + a|ace|alz|arc|arj|bz|bz2|cab|cpio|deb|gz|jar|lha|lz|lzh|lzma|lzo|\ + rpm|rz|t7z|tar|tbz|tbz2|tgz|tlz|txz|tZ|tzo|war|xpi|xz|Z|zip) + atool --list -- "${FILE_PATH}" && exit 5 + bsdtar --list --file "${FILE_PATH}" && exit 5 + exit 1;; + rar) + ## Avoid password prompt by providing empty password + unrar lt -p- -- "${FILE_PATH}" && exit 5 + exit 1;; + 7z) + ## Avoid password prompt by providing empty password + 7z l -p -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## PDF + pdf) + ## Preview as text conversion + pdftotext -l 10 -nopgbrk -q -- "${FILE_PATH}" - | \ + fmt -w "${PV_WIDTH}" && exit 5 + mutool draw -F txt -i -- "${FILE_PATH}" 1-10 | \ + fmt -w "${PV_WIDTH}" && exit 5 + exiftool "${FILE_PATH}" && exit 5 + exit 1;; + + ## BitTorrent + torrent) + transmission-show -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## OpenDocument + odt|ods|odp|sxw) + ## Preview as text conversion + odt2txt "${FILE_PATH}" && exit 5 + ## Preview as markdown conversion + pandoc -s -t markdown -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## XLSX + xlsx) + ## Preview as csv conversion + ## Uses: https://github.com/dilshod/xlsx2csv + xlsx2csv -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## HTML + htm|html|xhtml) + ## Preview as text conversion + w3m -dump "${FILE_PATH}" && exit 5 + lynx -dump -- "${FILE_PATH}" && exit 5 + elinks -dump "${FILE_PATH}" && exit 5 + pandoc -s -t markdown -- "${FILE_PATH}" && exit 5 + ;; + + ## JSON + json) + jq --color-output . "${FILE_PATH}" && exit 5 + python -m json.tool -- "${FILE_PATH}" && exit 5 + ;; + + ## Valve Texture Format + vtf) + # You need to install no_vtf with pipx + no_vtf --always-write --no-progress -f "png|apng" -O "${IMAGE_CACHE_PATH}" -- "${FILE_PATH}" && exit 6 + ;; + + ## Direct Stream Digital/Transfer (DSDIFF) and wavpack aren't detected + ## by file(1). + dff|dsf|wv|wvc) + mediainfo "${FILE_PATH}" && exit 5 + exiftool "${FILE_PATH}" && exit 5 + ;; # Continue with next handler on failure + esac +} + +handle_image() { + ## Size of the preview if there are multiple options or it has to be + ## rendered from vector graphics. If the conversion program allows + ## specifying only one dimension while keeping the aspect ratio, the width + ## will be used. + local DEFAULT_SIZE="1920x1080" + + local mimetype="${1}" + case "${mimetype}" in + ## SVG + # image/svg+xml|image/svg) + # convert -- "${FILE_PATH}" "${IMAGE_CACHE_PATH}" && exit 6 + # exit 1;; + + ## DjVu + # image/vnd.djvu) + # ddjvu -format=tiff -quality=90 -page=1 -size="${DEFAULT_SIZE}" \ + # - "${IMAGE_CACHE_PATH}" < "${FILE_PATH}" \ + # && exit 6 || exit 1;; + + ## Image + image/*) + local orientation + orientation="$( identify -format '%[EXIF:Orientation]\n' -- "${FILE_PATH}" )" + ## If orientation data is present and the image actually + ## needs rotating ("1" means no rotation)... + if [[ -n "$orientation" && "$orientation" != 1 ]]; then + ## ...auto-rotate the image according to the EXIF data. + convert -- "${FILE_PATH}" -auto-orient "${IMAGE_CACHE_PATH}" && exit 6 + fi + + ## `w3mimgdisplay` will be called for all images (unless overriden + ## as above), but might fail for unsupported types. + exit 7;; + + ## Video + # video/*) + # # Thumbnail + # ffmpegthumbnailer -i "${FILE_PATH}" -o "${IMAGE_CACHE_PATH}" -s 0 && exit 6 + # exit 1;; + + ## PDF + # application/pdf) + # pdftoppm -f 1 -l 1 \ + # -scale-to-x "${DEFAULT_SIZE%x*}" \ + # -scale-to-y -1 \ + # -singlefile \ + # -jpeg -tiffcompression jpeg \ + # -- "${FILE_PATH}" "${IMAGE_CACHE_PATH%.*}" \ + # && exit 6 || exit 1;; + + + ## ePub, MOBI, FB2 (using Calibre) + # application/epub+zip|application/x-mobipocket-ebook|\ + # application/x-fictionbook+xml) + # # ePub (using https://github.com/marianosimone/epub-thumbnailer) + # epub-thumbnailer "${FILE_PATH}" "${IMAGE_CACHE_PATH}" \ + # "${DEFAULT_SIZE%x*}" && exit 6 + # ebook-meta --get-cover="${IMAGE_CACHE_PATH}" -- "${FILE_PATH}" \ + # >/dev/null && exit 6 + # exit 1;; + + ## Font + application/font*|application/*opentype) + preview_png="/tmp/$(basename "${IMAGE_CACHE_PATH%.*}").png" + if fontimage -o "${preview_png}" \ + --pixelsize "120" \ + --fontname \ + --pixelsize "80" \ + --text " ABCDEFGHIJKLMNOPQRSTUVWXYZ " \ + --text " abcdefghijklmnopqrstuvwxyz " \ + --text " 0123456789.:,;(*!?') ff fl fi ffi ffl " \ + --text " The quick brown fox jumps over the lazy dog. " \ + "${FILE_PATH}"; + then + convert -- "${preview_png}" "${IMAGE_CACHE_PATH}" \ + && rm "${preview_png}" \ + && exit 6 + else + exit 1 + fi + ;; + + ## Preview archives using the first image inside. + ## (Very useful for comic book collections for example.) + # application/zip|application/x-rar|application/x-7z-compressed|\ + # application/x-xz|application/x-bzip2|application/x-gzip|application/x-tar) + # local fn=""; local fe="" + # local zip=""; local rar=""; local tar=""; local bsd="" + # case "${mimetype}" in + # application/zip) zip=1 ;; + # application/x-rar) rar=1 ;; + # application/x-7z-compressed) ;; + # *) tar=1 ;; + # esac + # { [ "$tar" ] && fn=$(tar --list --file "${FILE_PATH}"); } || \ + # { fn=$(bsdtar --list --file "${FILE_PATH}") && bsd=1 && tar=""; } || \ + # { [ "$rar" ] && fn=$(unrar lb -p- -- "${FILE_PATH}"); } || \ + # { [ "$zip" ] && fn=$(zipinfo -1 -- "${FILE_PATH}"); } || return + # + # fn=$(echo "$fn" | python -c "import sys; import mimetypes as m; \ + # [ print(l, end='') for l in sys.stdin if \ + # (m.guess_type(l[:-1])[0] or '').startswith('image/') ]" |\ + # sort -V | head -n 1) + # [ "$fn" = "" ] && return + # [ "$bsd" ] && fn=$(printf '%b' "$fn") + # + # [ "$tar" ] && tar --extract --to-stdout \ + # --file "${FILE_PATH}" -- "$fn" > "${IMAGE_CACHE_PATH}" && exit 6 + # fe=$(echo -n "$fn" | sed 's/[][*?\]/\\\0/g') + # [ "$bsd" ] && bsdtar --extract --to-stdout \ + # --file "${FILE_PATH}" -- "$fe" > "${IMAGE_CACHE_PATH}" && exit 6 + # [ "$bsd" ] || [ "$tar" ] && rm -- "${IMAGE_CACHE_PATH}" + # [ "$rar" ] && unrar p -p- -inul -- "${FILE_PATH}" "$fn" > \ + # "${IMAGE_CACHE_PATH}" && exit 6 + # [ "$zip" ] && unzip -pP "" -- "${FILE_PATH}" "$fe" > \ + # "${IMAGE_CACHE_PATH}" && exit 6 + # [ "$rar" ] || [ "$zip" ] && rm -- "${IMAGE_CACHE_PATH}" + # ;; + esac + + # openscad_image() { + # TMPPNG="$(mktemp -t XXXXXX.png)" + # openscad --colorscheme="${OPENSCAD_COLORSCHEME}" \ + # --imgsize="${OPENSCAD_IMGSIZE/x/,}" \ + # -o "${TMPPNG}" "${1}" + # mv "${TMPPNG}" "${IMAGE_CACHE_PATH}" + # } + + # case "${FILE_EXTENSION_LOWER}" in + # ## 3D models + # ## OpenSCAD only supports png image output, and ${IMAGE_CACHE_PATH} + # ## is hardcoded as jpeg. So we make a tempfile.png and just + # ## move/rename it to jpg. This works because image libraries are + # ## smart enough to handle it. + # csg|scad) + # openscad_image "${FILE_PATH}" && exit 6 + # ;; + # 3mf|amf|dxf|off|stl) + # openscad_image <(echo "import(\"${FILE_PATH}\");") && exit 6 + # ;; + # esac +} + +handle_mime() { + local mimetype="${1}" + case "${mimetype}" in + ## RTF and DOC + text/rtf|*msword) + ## Preview as text conversion + ## note: catdoc does not always work for .doc files + ## catdoc: http://www.wagner.pp.ru/~vitus/software/catdoc/ + catdoc -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## DOCX, ePub, FB2 (using markdown) + ## You might want to remove "|epub" and/or "|fb2" below if you have + ## uncommented other methods to preview those formats + *wordprocessingml.document|*/epub+zip|*/x-fictionbook+xml) + ## Preview as markdown conversion + pandoc -s -t markdown -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## XLS + *ms-excel) + ## Preview as csv conversion + ## xls2csv comes with catdoc: + ## http://www.wagner.pp.ru/~vitus/software/catdoc/ + xls2csv -- "${FILE_PATH}" && exit 5 + exit 1;; + + ## Text + text/* | */xml) + ## Syntax highlight + if [[ "$( stat --printf='%s' -- "${FILE_PATH}" )" -gt "${HIGHLIGHT_SIZE_MAX}" ]]; then + exit 2 + fi + if [[ "$( tput colors )" -ge 256 ]]; then + local pygmentize_format='terminal256' + local highlight_format='xterm256' + else + local pygmentize_format='terminal' + local highlight_format='ansi' + fi + env HIGHLIGHT_OPTIONS="${HIGHLIGHT_OPTIONS}" highlight \ + --out-format="${highlight_format}" \ + --force -- "${FILE_PATH}" && exit 5 + env COLORTERM=8bit bat --color=always --style="plain" \ + -- "${FILE_PATH}" && exit 5 + pygmentize -f "${pygmentize_format}" -O "style=${PYGMENTIZE_STYLE}"\ + -- "${FILE_PATH}" && exit 5 + exit 2;; + + ## DjVu + image/vnd.djvu) + ## Preview as text conversion (requires djvulibre) + djvutxt "${FILE_PATH}" | fmt -w "${PV_WIDTH}" && exit 5 + exiftool "${FILE_PATH}" && exit 5 + exit 1;; + + ## Image + image/*) + ## Preview as text conversion + # img2txt --gamma=0.6 --width="${PV_WIDTH}" -- "${FILE_PATH}" && exit 4 + exiftool "${FILE_PATH}" && exit 5 + exit 1;; + + ## Video and audio + video/* | audio/*) + mediainfo "${FILE_PATH}" && exit 5 + exiftool "${FILE_PATH}" && exit 5 + exit 1;; + esac +} + +handle_fallback() { + echo '----- File Type Classification -----' && file --dereference --brief -- "${FILE_PATH}" && exit 5 + exit 1 +} + + +MIMETYPE="$( file --dereference --brief --mime-type -- "${FILE_PATH}" )" +if [[ "${PV_IMAGE_ENABLED}" == 'True' ]]; then + handle_image "${MIMETYPE}" +fi +handle_extension +handle_mime "${MIMETYPE}" +handle_fallback + +exit 1 diff --git a/river/.config/river/init b/river/.config/river/init deleted file mode 100755 index 073677b..0000000 --- a/river/.config/river/init +++ /dev/null @@ -1,220 +0,0 @@ -#!/bin/sh - -# Make Flatpaks visible in Fuzzel and other places -export XDG_DATA_DIRS=/var/lib/flatpak/exports/share:~/.local/share/flatpak/exports/share:$XDG_DATA_DIRS - -riverctl spawn "dbus-update-activation-environment --systemd WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=river" -TERMINAL=kitty - -cp -f ~/Pictures/Wallpapers/$(ls ~/Pictures/Wallpapers -b | shuf -n 1) ~/.wallpaper - -## Autostart -riverctl spawn kanshi # Output management -riverctl spawn /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1 # Authentication GUI -riverctl spawn mako # Notifications -riverctl spawn nm-applet # NetworkManager tray -riverctl spawn "udiskie -t -f '$TERMINAL -e ranger'" # Removeable storage management -riverctl spawn "wl-paste --type text --watch cliphist store" # Stores only text data -riverctl spawn "wl-paste --type image --watch cliphist store" # Stores only image data -riverctl spawn waybar # Bar -riverctl spawn "gnome-keyring-daemon --start --components=secrets" # Secret service - -# Per device apps -while read program; do - riverctl spawn "$program" -done < ~/.config/autostart - -## Behaviour -riverctl default-attach-mode below - -# Window rules -riverctl rule-add ssd # Use server side decorations for everything (surely this will not break shit) -riverctl rule-add -app-id blueberry.py float # Float Blueberry -riverctl rule-add -app-id Element tags 16 # Move Element to tag 5 -riverctl rule-add -app-id pavucontrol float # Float pavucontrol -riverctl rule-add -app-id steam -title "Friends List" float # Float Steam Friends -riverctl rule-add -app-id steam tags 32 # Move Steam to tag 6 -riverctl rule-add -app-id tf_linux64 fullscreen # Fullscreen Team Fortress 2 (running in borderless window) -riverctl rule-add -app-id vesktop tags 8 # Move Vesktop to tag 4 -riverctl rule-add -app-id "waydroid*" fullscreen # Fullscreen all Waydroid applications -riverctl rule-add -app-id windowkill csd -riverctl rule-add -app-id windowkill float -riverctl rule-add -app-id windowkill position 0 0 - -# If on amida and second monitor connected -if [ "$HOSTNAME" = "amida" ] && wlr-randr | grep -q "Model: 2470W"; then - riverctl rule-add -app-id Element output "AOC 2470W GGJH9HA056165" # Move Element to second monitor - riverctl rule-add -app-id Element tags 2 # Move Element to tag 2 - riverctl rule-add -app-id steam output "AOC 2470W GGJH9HA056165" # Move Steam to second monitor - riverctl rule-add -app-id steam tags 4 # Move Steam to tag 3 - riverctl rule-add -app-id vesktop output "AOC 2470W GGJH9HA056165" # Move Vesktop to second monitor - riverctl rule-add -app-id vesktop tags 1 # Move Vesktop to tag 1 -fi - -## Appearance -# Set background and border color -riverctl background-color 0x15161e -riverctl border-color-focused 0xbb9af7 -riverctl border-color-unfocused 0x414868 -riverctl border-color-urgent 0xe0af68 - -# Enable prefer-dark -gsettings set org.gnome.desktop.interface color-scheme 'prefer-dark' - -## Inputs -riverctl focus-follows-cursor disabled -riverctl set-cursor-warp on-output-change - -# Logitech G703 -riverctl input pointer-1133-16518-Logitech_G703_LS accel-profile flat - -# ThinkPad T480 trackpad -T480_POINTER=pointer-1739-0-Synaptics_TM3276-022 -riverctl input $T480_POINTER click-method clickfinger -riverctl input $T480_POINTER drag enabled -riverctl input $T480_POINTER drag-locked enabled -riverctl input $T480_POINTER disable-while-typing disabled -riverctl input $T480_POINTER natural-scroll enabled -riverctl input $T480_POINTER tap enabled -riverctl input $T480_POINTER tap-button-map left-right-middle - -# Lock screen after 5 mins idle or before sleep -riverctl spawn "swayidle -w timeout 300 'swaylock -f --fade-in=1 --grace=30' timeout 600 'wlopm --off \*' resume 'wlopm --on \*' before-sleep 'swaylock -f'" - -## Mappings -# Applications -riverctl map normal Super D spawn fuzzel -riverctl map normal Super Return spawn $TERMINAL -riverctl map normal Super E spawn "$TERMINAL -e lf" -riverctl map normal Super+Shift E spawn thunar -riverctl map normal Control+Shift Escape spawn "$TERMINAL -e btop" -riverctl map normal Super Period spawn bemoji # Emoji picker -riverctl map normal Super Slash spawn "xdg-open https://wiki.archlinux.org" # tech support :3 - -# Screenshots -mkdir -p ~/Pictures/Screenshots # Make screenshots folder if missing -riverctl map normal None Print spawn "~/config/screenshot.sh ~/Pictures/Screenshots full true" -riverctl map normal Super Print spawn "~/config/screenshot.sh ~/Pictures/Screenshots display true" -riverctl map normal Alt Print spawn "~/config/screenshot.sh ~/Pictures/Screenshots region true" - -# Clipboard -riverctl map normal Super V spawn "cliphist list | fuzzel --dmenu | cliphist decode | wl-copy" - -# Super+Shift+Escape to lock the screen -riverctl map normal Super+Shift Escape spawn swaylock - -# Super+Alt+Shift+Escape to exit session -riverctl map normal Super+Alt+Shift Escape exit - -# Toggle microphone mute -riverctl map normal Super M spawn 'pamixer --default-source -t && notify-send "$([[ $(pamixer --default-source --get-mute) == "true" ]] && echo "Microphone muted" || echo "Microphone unmuted")" -t 2000' - -# Super+Q to close the focused view -riverctl map normal Super+Shift Q close - -# Super+J and Super+K to focus the next/previous view in the layout stack -riverctl map normal Super J focus-view next -riverctl map normal Super K focus-view previous - -# Super+Shift+J and Super+Shift+K to swap the focused view with the next/previous -# view in the layout stack -riverctl map normal Super+Shift J swap next -riverctl map normal Super+Shift K swap previous - -# Super+H and Super+L to focus the previous/next output -riverctl map normal Super H focus-output previous -riverctl map normal Super L focus-output next - -# Super+Shift+H and Super+Shift+L to send the focused view to the next/previous output -riverctl map normal Super+Shift H send-to-output previous -riverctl map normal Super+Shift L send-to-output next - -# Super+Return to bump the focused view to the top of the layout stack -riverctl map normal Super I zoom - -# Super+- and Super+= to decrease/increase the main ratio of rivertile(1) -riverctl map normal Super Minus send-layout-cmd rivertile "main-ratio -0.05" -riverctl map normal Super Equal send-layout-cmd rivertile "main-ratio +0.05" - -# Super+Shift+- and Super+Shift+= to decrement/increment the main count of rivertile(1) -riverctl map normal Super+Shift Minus send-layout-cmd rivertile "main-count -1" -riverctl map normal Super+Shift Equal send-layout-cmd rivertile "main-count +1" - -# Super + Left Mouse Button to move views -riverctl map-pointer normal Super BTN_LEFT move-view - -# Super + Right Mouse Button to resize views -riverctl map-pointer normal Super BTN_RIGHT resize-view - -# Super + Middle Mouse Button to toggle float -riverctl map-pointer normal Super BTN_MIDDLE toggle-float - -for i in $(seq 1 9) -do - tags=$((1 << ($i - 1))) - - # Super+[1-9] to focus tag [0-8] - riverctl map normal Super $i set-focused-tags $tags - - # Super+Shift+[1-9] to tag focused view with tag [0-8] - riverctl map normal Super+Shift $i set-view-tags $tags - - # Super+Control+[1-9] to toggle focus of tag [0-8] - riverctl map normal Super+Control $i toggle-focused-tags $tags - - # Super+Shift+Control+[1-9] to toggle tag [0-8] of focused view - riverctl map normal Super+Shift+Control $i toggle-view-tags $tags -done - -# Super+0 to focus all tags -# Super+Shift+0 to tag focused view with all tags -all_tags=$(((1 << 32) - 1)) -riverctl map normal Super 0 set-focused-tags $all_tags -riverctl map normal Super+Shift 0 set-view-tags $all_tags - -# Super+Space to toggle float -riverctl map normal Super Space toggle-float - -# Super+Shift+Space to toggle fullscreen -riverctl map normal Super+Shift Space toggle-fullscreen - -# Super+{Up,Right,Down,Left} to change layout orientation -riverctl map normal Super Up send-layout-cmd rivertile "main-location top" -riverctl map normal Super Right send-layout-cmd rivertile "main-location right" -riverctl map normal Super Down send-layout-cmd rivertile "main-location bottom" -riverctl map normal Super Left send-layout-cmd rivertile "main-location left" - -# Declare a passthrough mode. This mode has only a single mapping to return to -# normal mode. This makes it useful for testing a nested wayland compositor -riverctl declare-mode passthrough - -# Super+F11 to enter passthrough mode -riverctl map normal Super F11 enter-mode passthrough - -# Super+F11 to return to normal mode -riverctl map passthrough Super F11 enter-mode normal - -# Various media key mapping examples for both normal and locked mode which do -# not have a modifier -for mode in normal locked -do - # Control audio volume - riverctl map $mode None XF86AudioRaiseVolume spawn 'pamixer -i 5' - riverctl map $mode None XF86AudioLowerVolume spawn 'pamixer -d 5' - riverctl map $mode None XF86AudioMute spawn 'pamixer --toggle-mute' - - # Control MPRIS aware media players with playerctl (https://github.com/altdesktop/playerctl) - riverctl map $mode None XF86AudioMedia spawn 'playerctl play-pause' - riverctl map $mode None XF86AudioPlay spawn 'playerctl play-pause' - riverctl map $mode None XF86AudioPrev spawn 'playerctl previous' - riverctl map $mode None XF86AudioNext spawn 'playerctl next' - - # Control screen backlight brightness - riverctl map $mode None XF86MonBrightnessUp spawn 'brightnessctl s +5%' - riverctl map $mode None XF86MonBrightnessDown spawn 'brightnessctl s 5%-' -done - -# Set the default layout generator to be rivertile and start it. -# Leave this at the bottom -riverctl default-layout rivertile -rivertile -view-padding 4 -outer-padding 4 & diff --git a/river/.config/xdg-desktop-portal-wlr/river b/river/.config/xdg-desktop-portal-wlr/river deleted file mode 100644 index eceb915..0000000 --- a/river/.config/xdg-desktop-portal-wlr/river +++ /dev/null @@ -1,3 +0,0 @@ -[screencast] -chooser_type=default -max_fps=60 diff --git a/river/.config/xdg-desktop-portal/portals/gnome-keyring.portal b/river/.config/xdg-desktop-portal/portals/gnome-keyring.portal deleted file mode 100644 index 5b830a6..0000000 --- a/river/.config/xdg-desktop-portal/portals/gnome-keyring.portal +++ /dev/null @@ -1,4 +0,0 @@ -[portal] -DBusName=org.freedesktop.secrets -Interfaces=org.freedesktop.impl.portal.Secret -UseIn=river \ No newline at end of file diff --git a/river/.config/xdg-desktop-portal/river-portals.conf b/river/.config/xdg-desktop-portal/river-portals.conf deleted file mode 100644 index d55d092..0000000 --- a/river/.config/xdg-desktop-portal/river-portals.conf +++ /dev/null @@ -1,4 +0,0 @@ -[preferred] -default=gtk -org.freedesktop.impl.portal.Screenshot=wlr -org.freedesktop.impl.portal.ScreenCast=wlr diff --git a/screenshot.sh b/screenshot.sh deleted file mode 100755 index 068360c..0000000 --- a/screenshot.sh +++ /dev/null @@ -1,41 +0,0 @@ -#!/usr/bin/env bash - -# pancakes' wayland screenshot script -# takes screenshots, saves them, copies to clipboard, and notifies you -# depends on grim, libnotify, slurp, and wl-copy - -set -e - -if [ -z $2 ]; then - echo "Usage: $0 path full|display|region [notify=true|false]" - exit -fi - -FILENAME="$1/$(date +%F_%H-%M-%S)_$2.png" - -case $2 in - "full") - # capture full screen screenshot with cursor - grim -c $FILENAME - ;; - "display") - # capture display screenshot with cursor - grim -c -g "$(slurp -o)" $FILENAME - ;; - "region") - # capture screenshot of slurped region - grim -g "$(slurp)" $FILENAME - ;; - *) - echo "Mode must be either full, display, or region" - exit - ;; -esac - -NOTIFY=$3 -if [ ${NOTIFY:=false} = true ]; then - notify-send "Screenshot captured" "$FILENAME" -fi - -# copy screenshot to clipboard -wl-copy < $FILENAME diff --git a/ssh/dot-ssh/config b/ssh/dot-ssh/config new file mode 100644 index 0000000..3c04601 --- /dev/null +++ b/ssh/dot-ssh/config @@ -0,0 +1,2 @@ +Host * +SetEnv TERM=xterm-256color \ No newline at end of file diff --git a/swaylock/.config/swaylock/config b/swaylock/.config/swaylock/config deleted file mode 100644 index 6642118..0000000 --- a/swaylock/.config/swaylock/config +++ /dev/null @@ -1,26 +0,0 @@ -daemonize -clock -indicator -show-failed-attempts -image=~/.wallpaper -scaling=fill -bs-hl-color=e0af68 -caps-lock-bs-hl-color=f7768e -caps-lock-key-hl-color=7dcfff -font=Noto Sans -font-size=24 -inside-color=1a1b26e6 -inside-clear-color=e0af68e6 -inside-caps-lock-color=7dcfffe6 -inside-ver-color=7aa2f7e6 -inside-wrong-color=f7768ee6 -key-hl-color=bb9af7 -ring-color=bb9af7 -ring-clear-color=e0af68 -ring-caps-lock-color=7dcfff -ring-ver-color=7aa2f7 -ring-wrong-color=f7768e -text-color=c0caf5 -text-caps-lock-color=c0caf5 -effect-blur=10x3 -effect-greyscale \ No newline at end of file diff --git a/waybar/.config/waybar/config b/waybar/.config/waybar/config deleted file mode 100644 index 604e27c..0000000 --- a/waybar/.config/waybar/config +++ /dev/null @@ -1,101 +0,0 @@ -{ - "layer": "top", - "output": "!HDMI-A-1", - "spacing": 4, - "modules-left": [ - "river/tags", - "tray", - "privacy" - ], - "modules-center": [], - "modules-right": [ - "custom/micmute", - "gamemode", - "idle_inhibitor", - "network", - "bluetooth", - "wireplumber", - "backlight", - "battery", - "clock", - "custom/exit" - ], - "tray": { - "icon-size": 16, - "spacing": 10 - }, - "custom/micmute": { - "exec": "~/.config/waybar/scripts/micmute.sh", - "interval": 2 - }, - "idle_inhibitor": { - "format": "{icon}", - "format-icons": { - "activated": "", - "deactivated": "" - } - }, - "clock": { - "tooltip-format": "{:%Y-%m-%d}", - "format-alt": "{:%Y-%m-%d}" - }, - "backlight": { - "format": "{icon} {percent}%", - "format-icons": [ - "", - "", - "", - "", - "", - "", - "", - "", - "" - ] - }, - "battery": { - "states": { - "warning": 30, - "critical": 15 - }, - "format": "{icon} {capacity}%", - "format-charging": " {capacity}%", - "format-plugged": " {capacity}%", - "format-alt": "{icon} {time}", - "format-icons": [ - " ", - " ", - " ", - " ", - " " - ] - }, - "bluetooth": { - "on-click": "blueberry", - "tooltip-format": "{controller_alias}\t{controller_address}", - "tooltip-format-connected": "{controller_alias:20}\t{controller_address}\n\n{num_connections} connected:{device_enumerate}", - "tooltip-format-enumerate-connected": "\n{device_alias}\t\t{device_address}" - }, - "network": { - "format-wifi": " {essid} ({signalStrength}%)", - "format-ethernet": " {ipaddr}/{cidr}", - "tooltip-format": " {ifname} via {gwaddr}", - "format-linked": " {ifname} (No IP)", - "format-disconnected": "⚠ Disconnected", - "format-alt": "{ifname}: {ipaddr}/{cidr}" - }, - "wireplumber": { - "format": "{icon} {volume}%", - "format-muted": "", - "format-icons": [ - "", - " ", - " " - ], - "on-click": "pavucontrol" - }, - "custom/exit": { - "format": " ", - "on-click": "wlogout -s -b 5 -L 200 -R 200 -T 400 -B 400" - } -} \ No newline at end of file diff --git a/waybar/.config/waybar/scripts/micmute.sh b/waybar/.config/waybar/scripts/micmute.sh deleted file mode 100755 index 2bf2543..0000000 --- a/waybar/.config/waybar/scripts/micmute.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -[[ $(pamixer --default-source --get-mute) == "true" ]] && echo " Muted" || echo "" \ No newline at end of file diff --git a/waybar/.config/waybar/style.css b/waybar/.config/waybar/style.css deleted file mode 100644 index 40247b7..0000000 --- a/waybar/.config/waybar/style.css +++ /dev/null @@ -1,163 +0,0 @@ -* { - /* `otf-font-awesome` is required to be installed for icons */ - font-family: FontAwesome, "Noto Sans", sans-serif; - font-size: 18px; -} - -window#waybar { - background-color: rgba(26, 27, 38, 0.9); - color: #c0caf5; -} - -window#waybar.hidden { - opacity: 0.2; -} - -button { - /* Use box-shadow instead of border so the text isn't offset */ - box-shadow: inset 0 -2px transparent; - /* Avoid rounded borders under each button name */ - border: none; - border-radius: 0; -} - -button:hover { - background: inherit; - box-shadow: inset 0 -2px #414868; -} - -#tags button { - color: #c0caf5; - padding: 0 5px; -} - -#tags button:hover { - background: inherit; - border: none; - box-shadow: inset 0 -2px #414868; - text-shadow: inherit; -} - -#tags button.focused { - box-shadow: inset 0 -2px #bb9af7; -} - -#tags button.urgent { - box-shadow: inset 0 -2px #e0af68; -} - -#custom-micmute, -#bluetooth, -#clock, -#battery, -#cpu, -#memory, -#disk, -#temperature, -#backlight, -#network, -#pulseaudio, -#wireplumber, -#custom-media, -#tray, -#mode, -#idle_inhibitor, -#scratchpad, -#mpd { - padding: 0 10px; -} - -#window, -#workspaces { - margin: 0 4px; -} - -/* If workspaces is the leftmost module, omit left margin */ -.modules-left>widget:first-child>#workspaces { - margin-left: 0; -} - -/* If workspaces is the rightmost module, omit right margin */ -.modules-right>widget:last-child>#workspaces { - margin-right: 0; -} - -#custom-micmute { - box-shadow: inset 0 -2px #f7768e; -} - -#battery {} - -#battery.charging, -#battery.plugged { - box-shadow: inset 0 -2px #9ece6a; -} - -#battery.critical:not(.charging) { - box-shadow: inset 0 -2px #f7768e; -} - -label:focus { - background-color: rgba(26, 27, 38, 0.9); - border: 2px solid #414868; -} - -#idle_inhibitor.activated { - box-shadow: inset 0 -2px #e0af68; -} - -#backlight {} - -#network {} - -#network.disconnected { - box-shadow: inset 0 -2px #f7768e; -} - -#network.linked { - box-shadow: inset 0 -2px #e0af68; -} - -#privacy { - box-shadow: inset 0 -2px #e0af68; -} - -#wireplumber {} - -#wireplumber.muted {} - -#tray {} - -#tray>.passive { - -gtk-icon-effect: dim; -} - -#tray>.needs-attention { - -gtk-icon-effect: highlight; - background-color: #eb4d4b; -} - -#idle_inhibitor {} - -#idle_inhibitor.activated {} - -#privacy { - padding: 0; -} - -#privacy-item { - padding: 0 5px; - color: white; -} - -#privacy-item.screenshare { - background-color: #cf5700; -} - -#privacy-item.audio-in { - background-color: #1ca000; -} - -#privacy-item.audio-out { - background-color: #0069d4; -} \ No newline at end of file diff --git a/wlogout/.config/wlogout/icons/lock-hover.png b/wlogout/.config/wlogout/icons/lock-hover.png deleted file mode 100644 index 93aa694..0000000 Binary files a/wlogout/.config/wlogout/icons/lock-hover.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/lock.png b/wlogout/.config/wlogout/icons/lock.png deleted file mode 100644 index ab1505f..0000000 Binary files a/wlogout/.config/wlogout/icons/lock.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/logout-hover.png b/wlogout/.config/wlogout/icons/logout-hover.png deleted file mode 100644 index 8af8d20..0000000 Binary files a/wlogout/.config/wlogout/icons/logout-hover.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/logout.png b/wlogout/.config/wlogout/icons/logout.png deleted file mode 100644 index 0978e26..0000000 Binary files a/wlogout/.config/wlogout/icons/logout.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/reboot-hover.png b/wlogout/.config/wlogout/icons/reboot-hover.png deleted file mode 100644 index 878c75b..0000000 Binary files a/wlogout/.config/wlogout/icons/reboot-hover.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/reboot.png b/wlogout/.config/wlogout/icons/reboot.png deleted file mode 100644 index 6f31d70..0000000 Binary files a/wlogout/.config/wlogout/icons/reboot.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/shutdown-hover.png b/wlogout/.config/wlogout/icons/shutdown-hover.png deleted file mode 100644 index 5337c2c..0000000 Binary files a/wlogout/.config/wlogout/icons/shutdown-hover.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/shutdown.png b/wlogout/.config/wlogout/icons/shutdown.png deleted file mode 100644 index 530fcde..0000000 Binary files a/wlogout/.config/wlogout/icons/shutdown.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/suspend-hover.png b/wlogout/.config/wlogout/icons/suspend-hover.png deleted file mode 100644 index f126722..0000000 Binary files a/wlogout/.config/wlogout/icons/suspend-hover.png and /dev/null differ diff --git a/wlogout/.config/wlogout/icons/suspend.png b/wlogout/.config/wlogout/icons/suspend.png deleted file mode 100644 index 2dbfdaf..0000000 Binary files a/wlogout/.config/wlogout/icons/suspend.png and /dev/null differ diff --git a/wlogout/.config/wlogout/layout b/wlogout/.config/wlogout/layout deleted file mode 100644 index 3a76a23..0000000 --- a/wlogout/.config/wlogout/layout +++ /dev/null @@ -1,30 +0,0 @@ -{ - "label" : "lock", - "action" : "swaylock", - "text" : "Lock", - "keybind" : "l" -} -{ - "label" : "logout", - "action" : "riverctl exit", - "text" : "Logout", - "keybind" : "e" -} -{ - "label" : "suspend", - "action" : "systemctl suspend", - "text" : "Suspend", - "keybind" : "u" -} -{ - "label" : "shutdown", - "action" : "systemctl poweroff", - "text" : "Shutdown", - "keybind" : "s" -} -{ - "label" : "reboot", - "action" : "systemctl reboot", - "text" : "Reboot", - "keybind" : "r" -} \ No newline at end of file diff --git a/wlogout/.config/wlogout/style.css b/wlogout/.config/wlogout/style.css deleted file mode 100644 index 2ab715d..0000000 --- a/wlogout/.config/wlogout/style.css +++ /dev/null @@ -1,87 +0,0 @@ -* { - background-image: none; - box-shadow: none; - font-family: "Noto Sans", sans-serif; - font-weight: bold; -} - -window { - background-color: rgba(26, 27, 38, 0.9); -} - -button { - text-decoration-color: #c0caf5; - color: #c0caf5; - background-color: #414868; - background-repeat: no-repeat; - background-position: center; - background-size: 40%; -} - -button:focus, -button:active, -button:hover { - color: rgb(26, 27, 38); - outline-style: none; -} - -#lock { - background-image: image(url("icons/lock.png")); -} - -#lock:focus, -#lock:active, -#lock:hover { - background-color: #bb9af7; - background-image: image(url("icons/lock-hover.png")); - background-size: 50%; -} - -#logout { - background-image: image(url("icons/logout.png")); -} - -#logout:focus, -#logout:active, -#logout:hover { - background-color: #9ece6a; - background-image: image(url("icons/logout-hover.png")); - background-size: 50%; -} - -#suspend { - background-image: image(url("icons/suspend.png")); -} - -#suspend:focus, -#suspend:active, -#suspend:hover { - background-color: #e0af68; - background-image: image(url("icons/suspend-hover.png")); - background-size: 50%; -} - -#shutdown { - background-image: image(url("icons/shutdown.png")); -} - -#shutdown:focus, -#shutdown:active, -#shutdown:hover { - background-color: #f7768e; - background-image: image(url("icons/shutdown-hover.png")); - background-size: 50%; -} - - -#reboot { - background-image: image(url("icons/reboot.png")); -} - -#reboot:focus, -#reboot:active, -#reboot:hover { - background-color: #f7768e; - background-image: image(url("icons/reboot-hover.png")); - background-size: 50%; -} \ No newline at end of file diff --git a/wm/dot-config/fuzzel/fuzzel.ini b/wm/dot-config/fuzzel/fuzzel.ini new file mode 100644 index 0000000..c732f70 --- /dev/null +++ b/wm/dot-config/fuzzel/fuzzel.ini @@ -0,0 +1,29 @@ +[main] +font=Noto Sans:size=13 +use-bold=yes +dpi-aware=no +placeholder=program name +prompt=":3 " +show-actions=yes +terminal=alacritty -e +y-margin=15 +lines=5 +horizontal-pad=5 +vertical-pad=5 +inner-pad=5 + +[colors] +background=1a1b26e5 +text=a9b1d6ff +prompt=bb9af7ff +placeholder=bb9af7b2 +input=bb9af7ff +match=bb9af7ff +selection=bb9af7ff +selection-text=565f89ff +selection-match=1a1b26ff +border=bb9af7ff + +[border] +width=2 +radius=5 diff --git a/wm/dot-config/gtklock/config.ini b/wm/dot-config/gtklock/config.ini new file mode 100644 index 0000000..8caad4a --- /dev/null +++ b/wm/dot-config/gtklock/config.ini @@ -0,0 +1,6 @@ +[main] +gtk-theme=Adwaita-dark +background=Pictures/Wallpapers/cafe.png +idle-hide=true +idle-timeout=30 +start-hidden=true \ No newline at end of file diff --git a/wm/dot-config/mako/config b/wm/dot-config/mako/config new file mode 100644 index 0000000..c33bf49 --- /dev/null +++ b/wm/dot-config/mako/config @@ -0,0 +1,14 @@ +font=Noto Sans 13 +background-color=#1a1b26e5 +text-color=#a9b1d6ff +width=400 +height=200 +border-color=#bb9af7ff +margin=15 +border-radius=5 +format=%a - %s\n%b +default-timeout=30000 +group-by=app-name,summary + +[grouped] +format=(%g) %a - %s\n%b \ No newline at end of file diff --git a/wm/dot-config/niri/config.kdl b/wm/dot-config/niri/config.kdl new file mode 100644 index 0000000..0a2617d --- /dev/null +++ b/wm/dot-config/niri/config.kdl @@ -0,0 +1,373 @@ +// This config is in the KDL format: https://kdl.dev +// "/-" comments out the following node. +// Check the wiki for a full description of the configuration: +// https://github.com/YaLTeR/niri/wiki/Configuration:-Overview + +// Input device configuration. +// Find the full list of options on the wiki: +// https://github.com/YaLTeR/niri/wiki/Configuration:-Input +input { + keyboard { + xkb { + // You can set rules, model, layout, variant and options. + // For more information, see xkeyboard-config(7). + + // For example: + // layout "us,ru" + // options "grp:win_space_toggle,compose:ralt,ctrl:nocaps" + } + } + + touchpad { + tap + // dwt + // dwtp + natural-scroll + scroll-method "two-finger" + disabled-on-external-mouse + } + + mouse { + accel-profile "flat" + } + + // warp-mouse-to-focus +} + +// You can configure outputs by their name, which you can find +// by running `niri msg outputs` while inside a niri instance. +// Remember to uncomment the node by removing "/-"! +output "eDP-1" { + scale 1.5 +} + +output "LG Electronics LG ULTRAGEAR 404NTCZ0R931" { + scale 1.5 + // variable-refresh-rate +} + +// Settings that influence how windows are positioned and sized. +// Find more information on the wiki: +// https://github.com/YaLTeR/niri/wiki/Configuration:-Layout +layout { + // Set gaps around windows in logical pixels. + gaps 10 + + // When to center a column when changing focus, options are: + // - "never", default behavior, focusing an off-screen column will keep at the left + // or right edge of the screen. + // - "always", the focused column will always be centered. + // - "on-overflow", focusing a column will center it if it doesn't fit + // together with the previously focused column. + center-focused-column "on-overflow" + + // You can customize the widths that "switch-preset-column-width" (Mod+R) toggles between. + preset-column-widths { + // Proportion sets the width as a fraction of the output width, taking gaps into account. + // For example, you can perfectly fit four windows sized "proportion 0.25" on an output. + // The default preset widths are 1/3, 1/2 and 2/3 of the output. + proportion 0.33333 + proportion 0.5 + proportion 0.66667 + + // Fixed sets the width in logical pixels exactly. + // fixed 1920 + } + + // You can also customize the heights that "switch-preset-window-height" (Mod+Shift+R) toggles between. + preset-window-heights { + proportion 0.33333 + proportion 0.5 + proportion 0.66667 + } + + // You can change the default width of the new windows. + // default-column-width { proportion 0.5; } + // If you leave the brackets empty, the windows themselves will decide their initial width. + default-column-width {} + + focus-ring { + off + } + + border { + width 2 + active-color "#bb9af7" + inactive-color "#565f89" + } +} + +environment { + DISPLAY ":10" + MOZ_ENABLE_WAYLAND "1" + MOZ_USE_XINPUT2 "1" +} + +// Add lines like this to spawn processes at startup. +// Note that running niri as a session supports xdg-desktop-autostart + +// Services +spawn-at-startup "mako" +spawn-at-startup "xwayland-satellite" ":10" +spawn-at-startup "swayidle" "-w" +spawn-at-startup "waybar" +spawn-at-startup "swww-daemon" +spawn-at-startup "wl-paste" "--watch" "cliphist" "store" +spawn-at-startup "flatpak" "run" "it.mijorus.smile" "--start-hidden" + +// Applications +spawn-at-startup "firefox" +spawn-at-startup "easyeffects" +spawn-at-startup "vesktop" +spawn-at-startup "foot" "-e" "btop" + +// Uncomment this line to ask the clients to omit their client-side decorations if possible. +// If the client will specifically ask for CSD, the request will be honored. +// Additionally, clients will be informed that they are tiled, removing some rounded corners. +prefer-no-csd + +// You can change the path where screenshots are saved. +// A ~ at the front will be expanded to the home directory. +// The path is formatted with strftime(3) to give you the screenshot date and time. +screenshot-path "~/Pictures/Screenshots/Screenshot from %Y-%m-%d %H-%M-%S.png" + +// You can also set this to null to disable saving screenshots to disk. +// screenshot-path null + +// Animation settings. +// The wiki explains how to configure individual animations: +// https://github.com/YaLTeR/niri/wiki/Configuration:-Animations +animations { + // Uncomment to turn off all animations. + // off + + // Slow down all animations by this factor. Values below 1 speed them up instead. + // slowdown 3.0 +} + +workspace "web" +workspace "chat" + +// Window rules let you adjust behavior for individual windows. +// Find more information on the wiki: +// https://github.com/YaLTeR/niri/wiki/Configuration:-Window-Rules + +// Round corners +window-rule { + geometry-corner-radius 5 + clip-to-geometry true +} + +// Firefox +window-rule { + match app-id="firefox" + + open-on-workspace "web" +} + +// Chat applications +window-rule { + match app-id="vesktop" + + block-out-from "screencast" + open-maximized true + open-on-workspace "chat" +} + +window-rule { + match app-id="com.github.wwmm.easyeffects" + + open-on-workspace "chat" +} + +// Steam +window-rule { + match app-id="steam" title="Steam" + + open-maximized true +} + +window-rule { + match app-id="gamescope" + + open-fullscreen true +} + +// foot +window-rule { + match app-id="foot" + + default-column-width { proportion 0.5; } +} + +// Hide private stuff :3 +window-rule { + match app-id="firefox" title=r#"^Extension: \(Bitwarden Password Manager\)"# + match app-id="org.gnome.Nautilus" + + block-out-from "screencast" +} + +binds { + // "Mod" is a special modifier equal to Super when running on a TTY, and to Alt + // when running as a winit window. + + // Mod-Shift-/, which is usually the same as Mod-?, + // shows a list of important hotkeys. + Mod+Shift+Slash { show-hotkey-overlay; } + + Mod+Return { spawn "foot"; } + Mod+D { spawn "fuzzel"; } + Mod+E { spawn "foot" "-e" "ranger"; } + Mod+Alt+L { spawn "gtklock" "-d"; } + Mod+V { spawn "sh" "-c" "cliphist list | fuzzel -d -p '> ' --placeholder=clipboard | cliphist decode | wl-copy"; } + Mod+slash { spawn "flatpak" "run" "it.mijorus.smile"; } + + XF86AudioRaiseVolume allow-when-locked=true { spawn "wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "0.1+"; } + XF86AudioLowerVolume allow-when-locked=true { spawn "wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "0.1-"; } + XF86AudioMute allow-when-locked=true { spawn "wpctl" "set-mute" "@DEFAULT_AUDIO_SINK@" "toggle"; } + XF86AudioMicMute allow-when-locked=true { spawn "wpctl" "set-mute" "@DEFAULT_AUDIO_SOURCE@" "toggle"; } + + Mod+Shift+Q { close-window; } + + Mod+H { focus-column-left; } + Mod+J { focus-window-down; } + Mod+K { focus-window-up; } + Mod+L { focus-column-right; } + + Mod+Shift+H { move-column-left; } + Mod+Shift+J { move-window-down; } + Mod+Shift+K { move-window-up; } + Mod+Shift+L { move-column-right; } + + Mod+Home { focus-column-first; } + Mod+End { focus-column-last; } + Mod+Shift+Home { move-column-to-first; } + Mod+Shift+End { move-column-to-last; } + + Mod+Page_Down { focus-workspace-down; } + Mod+Page_Up { focus-workspace-up; } + Mod+U { focus-workspace-down; } + Mod+I { focus-workspace-up; } + + + Mod+Shift+Page_Down { move-workspace-down; } + Mod+Shift+Page_Up { move-workspace-up; } + Mod+Shift+U { move-workspace-down; } + Mod+Shift+I { move-workspace-up; } + + // You can bind mouse wheel scroll ticks using the following syntax. + // These binds will change direction based on the natural-scroll setting. + // + // To avoid scrolling through workspaces really fast, you can use + // the cooldown-ms property. The bind will be rate-limited to this value. + // You can set a cooldown on any bind, but it's most useful for the wheel. + Mod+WheelScrollDown cooldown-ms=150 { focus-workspace-down; } + Mod+WheelScrollUp cooldown-ms=150 { focus-workspace-up; } + Mod+Ctrl+WheelScrollDown cooldown-ms=150 { move-column-to-workspace-down; } + Mod+Ctrl+WheelScrollUp cooldown-ms=150 { move-column-to-workspace-up; } + + Mod+WheelScrollRight { focus-column-right; } + Mod+WheelScrollLeft { focus-column-left; } + Mod+Ctrl+WheelScrollRight { move-column-right; } + Mod+Ctrl+WheelScrollLeft { move-column-left; } + + // Usually scrolling up and down with Shift in applications results in + // horizontal scrolling; these binds replicate that. + Mod+Shift+WheelScrollDown { focus-column-right; } + Mod+Shift+WheelScrollUp { focus-column-left; } + Mod+Ctrl+Shift+WheelScrollDown { move-column-right; } + Mod+Ctrl+Shift+WheelScrollUp { move-column-left; } + + // Similarly, you can bind touchpad scroll "ticks". + // Touchpad scrolling is continuous, so for these binds it is split into + // discrete intervals. + // These binds are also affected by touchpad's natural-scroll, so these + // example binds are "inverted", since we have natural-scroll enabled for + // touchpads by default. + // Mod+TouchpadScrollDown { spawn "wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "0.02+"; } + // Mod+TouchpadScrollUp { spawn "wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "0.02-"; } + + // You can refer to workspaces by index. However, keep in mind that + // niri is a dynamic workspace system, so these commands are kind of + // "best effort". Trying to refer to a workspace index bigger than + // the current workspace count will instead refer to the bottommost + // (empty) workspace. + // + // For example, with 2 workspaces + 1 empty, indices 3, 4, 5 and so on + // will all refer to the 3rd workspace. + Mod+1 { focus-workspace 1; } + Mod+2 { focus-workspace 2; } + Mod+3 { focus-workspace 3; } + Mod+4 { focus-workspace 4; } + Mod+5 { focus-workspace 5; } + Mod+6 { focus-workspace 6; } + Mod+7 { focus-workspace 7; } + Mod+8 { focus-workspace 8; } + Mod+9 { focus-workspace 9; } + Mod+Shift+1 { move-window-to-workspace 1; } + Mod+Shift+2 { move-window-to-workspace 2; } + Mod+Shift+3 { move-window-to-workspace 3; } + Mod+Shift+4 { move-window-to-workspace 4; } + Mod+Shift+5 { move-window-to-workspace 5; } + Mod+Shift+6 { move-window-to-workspace 6; } + Mod+Shift+7 { move-window-to-workspace 7; } + Mod+Shift+8 { move-window-to-workspace 8; } + Mod+Shift+9 { move-window-to-workspace 9; } + + // Switches focus between the current and the previous workspace. + // Mod+Tab { focus-workspace-previous; } + + Mod+Comma { consume-window-into-column; } + Mod+Period { expel-window-from-column; } + + // There are also commands that consume or expel a single window to the side. + Mod+BracketLeft { consume-or-expel-window-left; } + Mod+BracketRight { consume-or-expel-window-right; } + + Mod+R { switch-preset-column-width; } + Mod+Shift+R { switch-preset-window-height; } + Mod+Ctrl+R { reset-window-height; } + Mod+F { maximize-column; } + Mod+Shift+F { fullscreen-window; } + Mod+C { center-column; } + + // Finer width adjustments. + // This command can also: + // * set width in pixels: "1000" + // * adjust width in pixels: "-5" or "+5" + // * set width as a percentage of screen width: "25%" + // * adjust width as a percentage of screen width: "-10%" or "+10%" + // Pixel sizes use logical, or scaled, pixels. I.e. on an output with scale 2.0, + // set-column-width "100" will make the column occupy 200 physical screen pixels. + Mod+Minus { set-column-width "-10%"; } + Mod+Equal { set-column-width "+10%"; } + + // Finer height adjustments when in column with other windows. + Mod+Shift+Minus { set-window-height "-10%"; } + Mod+Shift+Equal { set-window-height "+10%"; } + + // Actions to switch layouts. + // Note: if you uncomment these, make sure you do NOT have + // a matching layout switch hotkey configured in xkb options above. + // Having both at once on the same hotkey will break the switching, + // since it will switch twice upon pressing the hotkey (once by xkb, once by niri). + // Mod+Space { switch-layout "next"; } + // Mod+Shift+Space { switch-layout "prev"; } + + Print { screenshot; } + Ctrl+Print { screenshot-screen; } + Alt+Print { screenshot-window; } + + // The quit action will show a confirmation dialog to avoid accidental exits. + Mod+Shift+E { quit; } + + // Powers off the monitors. To turn them back on, do any input like + // moving the mouse or pressing any other key. + Mod+Shift+P { power-off-monitors; } +} + +hotkey-overlay { + skip-at-startup +} + diff --git a/wm/dot-config/swayidle/config b/wm/dot-config/swayidle/config new file mode 100644 index 0000000..0643783 --- /dev/null +++ b/wm/dot-config/swayidle/config @@ -0,0 +1,3 @@ +timeout 300 'gtklock -d' +timeout 600 'niri msg action power-off-monitors' +before-sleep 'gtklock -d' \ No newline at end of file diff --git a/wm/dot-config/waybar/config.jsonc b/wm/dot-config/waybar/config.jsonc new file mode 100644 index 0000000..6edc516 --- /dev/null +++ b/wm/dot-config/waybar/config.jsonc @@ -0,0 +1,93 @@ +{ + // make sure this renders above all non-fullscreen windows + "layer": "top", + // modules + "modules-left": [ + "niri/workspaces", + "niri/window" + ], + "modules-center": [ + "clock" + ], + "modules-right": [ + "privacy", + "gamemode", + "tray", + "idle_inhibitor", + "battery", + "wireplumber", + "bluetooth", + "network" + ], + // config + "niri/workspaces": { + "format": "{icon}{name}", + "format-icons": { + "web": " ", + "chat": " " + } + }, + "niri/window": { + // "format": "{app_id} | {title}" + }, + "clock": { + "format": "{:%a %R}", + "tooltip-format": "{calendar}", + "calendar": { + "mode": "month", + "weeks-pos": "right", + "format": { + "months": "{}", + "days": "{}", + "weeks": "W{}", + "weekdays": "{}", + "today": "{}" + } + } + }, + "privacy": { + "icon-size": 13, + "icon-spacing": 5 + }, + "gamemode": { + "icon-size": 13 + }, + "tray": { + "reverse-direction": true, + "show-passive-items": true, + "spacing": 5 + }, + "idle_inhibitor": { + "format": "{icon}", + "format-icons": { + "activated": "", + "deactivated": "" + } + }, + "wireplumber": { + "format": "{icon} {volume}%", + "format-icons": [ + "", + "", + " " + ], + "format-muted": "", + "on-click": "pavucontrol", + "on-click-right": "helvum" + }, + "bluetooth": { + "format": "", + "format-connected": " {num_connections}", + "format-disabled": "", + "tooltip-format": "{controller_alias} {controller_address}", + "tooltip-format-connected": "{controller_alias} {controller_address}\n\n{num_connections} connected:\n{device_enumerate}", + "tooltip-format-enumerate-connected": "{device_alias} {device_address}" + }, + "network": { + "format-disconnected": "Disconnected", + "format-ethernet": "", + "format-wifi": " {essid}", + "tooltip-format-ethernet": "{ipaddr}/{cidr} via {ifname}", + "tooltip-format-wifi": "{ipaddr}/{cidr} via {ifname}\n{signalStrength}% signal" + } +} \ No newline at end of file diff --git a/wm/dot-config/waybar/style.css b/wm/dot-config/waybar/style.css new file mode 100644 index 0000000..b24f300 --- /dev/null +++ b/wm/dot-config/waybar/style.css @@ -0,0 +1,97 @@ +* { + border: none; + border-radius: 0; + font-family: "Noto Sans", sans-serif; + font-size: 13px; + min-height: 0; +} + +window#waybar { + background: rgba(26, 27, 38, 0.9); + color: #a9b1d6; +} + +tooltip { + background: rgba(26, 27, 38, 0.9); + border: 2px solid #565f89; + border-radius: 5px; +} + +tooltip label { + color: #a9b1d6; +} + +#workspaces button { + margin: 5px 5px; + padding: 2px 5px; + background: transparent; + border-radius: 5px; + color: #a9b1d6; +} + +#workspaces button.focused { + background: #bb9af7; + color: #1a1b26; +} + +#window, +#clock, +#privacy, +#gamemode, +#tray, +#idle_inhibitor, +#battery, +#wireplumber, +#bluetooth, +#network { + margin: 5px 5px; + padding: 0 5px; + border-radius: 5px; +} + +#window, +#tray { + background-color: #24283b; +} + +#privacy { + background-color: #e0af68; + color: black; +} + +#gamemode.running { + background-color: #7dcfff; + color: black; +} + +#idle_inhibitor.activated { + background-color: #ff9e64; + color: black; +} + +#battery { + background-color: #ffffff; + color: black; +} + +#battery.charging { + background-color: #9ece6a; + color: #1a1b26; +} + +#battery.warning:not(.charging), +#network.disconnected { + background: #f7768e; + color: #1a1b26; +} + +#bluetooth.connected { + background: #7aa2f7; + color: #1a1b26; +} + +#network.ethernet, +#network.wifi { + background: #73daca; + color: #1a1b26; +} \ No newline at end of file