mirror of
https://github.com/js0ny/dotfiles.git
synced 2025-12-21 08:43:00 +00:00
feat(hyprland): Add hyprland config
This commit is contained in:
parent
981dd2170c
commit
4bf9687d72
28 changed files with 540 additions and 80 deletions
|
|
@ -8,7 +8,6 @@ mkdir -p $XDG_CONFIG_HOME/conda $XDG_CONFIG_HOME/git $XDG_CONFIG_HOME/ideavim $X
|
||||||
mkdir -p ~/.config/zellij ~/.config/yazi ~/.config/glow
|
mkdir -p ~/.config/zellij ~/.config/yazi ~/.config/glow
|
||||||
# mkdir -p $WAKATIME_HOME
|
# mkdir -p $WAKATIME_HOME
|
||||||
# mkdir -p $XDG_STATE_HOME/vim/undo $XDG_STATE_HOME/vim/backup $XDG_STATE_HOME/vim/swap $XDG_STATE_HOME/vim/view
|
# mkdir -p $XDG_STATE_HOME/vim/undo $XDG_STATE_HOME/vim/backup $XDG_STATE_HOME/vim/swap $XDG_STATE_HOME/vim/view
|
||||||
mkdir -p $HOME/Obsidian
|
|
||||||
# $DOTFILES/common
|
# $DOTFILES/common
|
||||||
ln -sf $DOTFILES/common/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
|
ln -sf $DOTFILES/common/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
|
||||||
# ln -sf $DOTFILES/common/gitconfig $XDG_CONFIG_HOME/git/config
|
# ln -sf $DOTFILES/common/gitconfig $XDG_CONFIG_HOME/git/config
|
||||||
|
|
@ -19,7 +18,6 @@ ln -sf $DOTFILES/common/ideavimrc $XDG_CONFIG_HOME/ideavim/ideavimrc
|
||||||
ln -sf $DOTFILES/common/lesskey $XDG_CONFIG_HOME/lesskey
|
ln -sf $DOTFILES/common/lesskey $XDG_CONFIG_HOME/lesskey
|
||||||
ln -sf $DOTFILES/common/npmrc $NPM_CONFIG_USERCONFIG
|
ln -sf $DOTFILES/common/npmrc $NPM_CONFIG_USERCONFIG
|
||||||
ln -sf $DOTFILES/common/NuGet.Config $XDG_CONFIG_HOME/NuGet/NuGet.Config
|
ln -sf $DOTFILES/common/NuGet.Config $XDG_CONFIG_HOME/NuGet/NuGet.Config
|
||||||
ln -sf $DOTFILES/common/obsidian.vimrc $HOME/Obsidian/.obsidian.vimrc
|
|
||||||
ln -sf $DOTFILES/common/pip.conf $XDG_CONFIG_HOME/pip/pip.conf
|
ln -sf $DOTFILES/common/pip.conf $XDG_CONFIG_HOME/pip/pip.conf
|
||||||
ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
|
ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
|
||||||
ln -sf $DOTFILES/common/vimrc $XDG_CONFIG_HOME/vim/vimrc
|
ln -sf $DOTFILES/common/vimrc $XDG_CONFIG_HOME/vim/vimrc
|
||||||
|
|
@ -32,7 +30,7 @@ ln -sf $DOTFILES/tools/yazi/config/yazi.toml ~/.config/yazi/yazi.toml
|
||||||
ln -sf $DOTFILES/tools/fish ~/.config
|
ln -sf $DOTFILES/tools/fish ~/.config
|
||||||
|
|
||||||
|
|
||||||
if [ $(uname) = "Darwin"]; then
|
if [ $(uname) = "Darwin" ]; then
|
||||||
mkdir -p ~/.config/karabiner $XDG_CONFIG_HOME/skhd $XDG_CONFIG_HOME/yabai $XDG_CONFIG_HOME/sketchybar
|
mkdir -p ~/.config/karabiner $XDG_CONFIG_HOME/skhd $XDG_CONFIG_HOME/yabai $XDG_CONFIG_HOME/sketchybar
|
||||||
ln -sf $DOTFILES/platforms/mac/karabiner/karabiner.json ~/.config/karabiner/karabiner.json
|
ln -sf $DOTFILES/platforms/mac/karabiner/karabiner.json ~/.config/karabiner/karabiner.json
|
||||||
ln -sf $DOTFILES/platforms/mac/skhdrc $XDG_CONFIG_HOME/skhd/skhdrc
|
ln -sf $DOTFILES/platforms/mac/skhdrc $XDG_CONFIG_HOME/skhd/skhdrc
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,12 @@
|
||||||
# $XDG_CONFIG_HOME/conda/condarc.yaml
|
# $DOTFILES/common/condarc.yaml
|
||||||
# ==================================================================
|
# Date: 2024-12-22
|
||||||
# New-Item -ItemType SymbolicLink -Path $Env:XDG_CONFIG_HOME\conda\.condarc -Target $DOTFILES\.config\conda\condarc.yaml
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/conda/.condarc
|
||||||
|
# Linking:
|
||||||
# ln -s $DOTFILES/.config/conda/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
|
# ln -s $DOTFILES/.config/conda/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
|
||||||
# ==================================================================
|
# ================================================================================
|
||||||
|
# Reference:
|
||||||
# https://docs.conda.io/projects/conda/en/latest/user-guide/configuration/use-condarc.html
|
# https://docs.conda.io/projects/conda/en/latest/user-guide/configuration/use-condarc.html
|
||||||
auto_activate_base: false
|
auto_activate_base: false
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,19 @@
|
||||||
# $XDG_CONFIG_HOME/git/config
|
# $DOTFILES/common/gitconfig.example
|
||||||
# %USERPROFILE%\.gitconfig # No XDG support on Windows
|
# Date: 2024-12-22
|
||||||
# ln -sf $DOTFILES/.config/git/.gitconfig $XDG_CONFIG_HOME/git/config
|
# Author: js0ny
|
||||||
# New-Item -ItemType SymbolicLink -Path "$Env:XDG_CONFIG_HOME\git\config" -Target "$DOTFILES\.config\git\.gitconfig"
|
|
||||||
[user]
|
# Location:
|
||||||
|
# Windows: %USERPROFILE%\.gitconfig
|
||||||
|
# *nix: ~/.config/git/config
|
||||||
|
# Linking: (Note that this file is an example, only copy this then edit)
|
||||||
|
# cp $DOTFILES/common/gitconfig.example ~/.config/git/config
|
||||||
|
[user] # Modify the name and email
|
||||||
name = whoami
|
name = whoami
|
||||||
email = whoami@example.com
|
email = whoami@example.com
|
||||||
[core]
|
[core]
|
||||||
editor = nvim
|
editor = nvim
|
||||||
pager = delta
|
pager = delta
|
||||||
autocrlf = input
|
autocrlf = input # Force End of Line in different platforms
|
||||||
[interactive]
|
[interactive]
|
||||||
diffFilter = delta --color-only
|
diffFilter = delta --color-only
|
||||||
[delta]
|
[delta]
|
||||||
|
|
@ -19,5 +24,5 @@
|
||||||
smudge = git-lfs smudge -- %f
|
smudge = git-lfs smudge -- %f
|
||||||
process = git-lfs filter-process
|
process = git-lfs filter-process
|
||||||
required = true
|
required = true
|
||||||
[url "git@github.com:"]
|
# [url "git@github.com:"] # Force ssh
|
||||||
insteadOf = https://github.com/
|
# insteadOf = https://github.com/
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,10 @@
|
||||||
# ~/.config/glow/glow.yaml
|
# $DOTFILES/common/glow.yaml
|
||||||
# ln -sf $DOTFILES/glow/glow.yaml ~/.config/glow/glow.yaml
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/glow/config.yml
|
||||||
|
# ln -sf $DOTFILES/glow/glow.yaml ~/.config/glow/config.yml
|
||||||
# style name or JSON path (default "auto")
|
# style name or JSON path (default "auto")
|
||||||
style: "auto"
|
style: "auto"
|
||||||
# mouse support (TUI-mode only)
|
# mouse support (TUI-mode only)
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,12 @@
|
||||||
"$XDG_CONFIG_HOME/ideavim/ideavimrc
|
" $DOTFILES/common/ideavimrc
|
||||||
" New-Item -ItemType SymbolicLink -Path ~\.ideavimrc -Target $DOTFILES\.config\ideavim\ideavimrc.vimrc
|
" Date: 2024-12-22
|
||||||
" ln -sf $DOTFILES/.config/ideavim/ideavimrc.vimrc $XDG_CONFIG_HOME/ideavim/ideavimrc
|
" Author: js0ny
|
||||||
|
|
||||||
|
" Location:
|
||||||
|
" $XDG_CONFIG_HOME/ideavim/ideavimrc
|
||||||
|
" Linking:
|
||||||
|
" ln -sf $DOTFILES/common/ideavimrc $XDG_CONFIG_HOME/ideavim/ideavimrc
|
||||||
|
|
||||||
""" Basic Configs """
|
""" Basic Configs """
|
||||||
let mapleader = " " " set <leader> to <space>
|
let mapleader = " " " set <leader> to <space>
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,13 @@
|
||||||
|
# $DOTFILES/common/gitconfig.example
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# GNU Readline config file, works for programs that use that library
|
||||||
|
# e.g. Python REPL, Lua REPL, Bash on Linux
|
||||||
|
|
||||||
|
# Location:
|
||||||
# $XDG_CONFIG_HOME/readline/inputrc
|
# $XDG_CONFIG_HOME/readline/inputrc
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/common/inputrc $XDG_CONFIG_HOME/readline/inputrc
|
||||||
|
|
||||||
# Colemak Key Remaps
|
# Colemak Key Remaps
|
||||||
set editing-mode vi
|
set editing-mode vi
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,16 @@
|
||||||
# $XDG_CONFIG_HOME/lesskey -- less options
|
# $DOTFILES/common/lesskey
|
||||||
# ln -sf $DOTFILES/.config/lesskey $XDG_CONFIG_HOME/lesskey
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Less the pager.
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/lesskey
|
||||||
|
# Or specified by the environment variable $LESSKEYIN
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/common/lesskey ~/.config/lesskey
|
||||||
|
# ===========================================================
|
||||||
# work for less -V > 582, for mac, use brew install less to override the system less
|
# work for less -V > 582, for mac, use brew install less to override the system less
|
||||||
|
# In Windows (current version), the default pager is `more`, should be specifed to `less` by `$Env:Pager = less`
|
||||||
|
|
||||||
# Format: key action
|
# Format: key action
|
||||||
|
|
||||||
|
|
|
||||||
12
common/npmrc
12
common/npmrc
|
|
@ -1,6 +1,14 @@
|
||||||
|
# $DOTFILES/common/npmrc
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $NPM_CONFIG_USERCONFIG
|
||||||
|
# ~/.npmrc (Default location)
|
||||||
|
# Linking:
|
||||||
# export NPM_CONFIG_USERCONFIG="$XDG_CONFIG_HOME"/npm/npmrc
|
# export NPM_CONFIG_USERCONFIG="$XDG_CONFIG_HOME"/npm/npmrc
|
||||||
# ===========================================================
|
|
||||||
# $XDG_CONFIG_HOME/npm/npmrc
|
|
||||||
# ln -s $DOTFILES/.config/npm/npmrc $NPM_CONFIG_USERCONFIG
|
# ln -s $DOTFILES/.config/npm/npmrc $NPM_CONFIG_USERCONFIG
|
||||||
# New-Item -ItemType SymbolicLink -Path $env:NPM_CONFIG_USERCONFIG -Value $env:DOTFILES/.config/npm/npmrc
|
# New-Item -ItemType SymbolicLink -Path $env:NPM_CONFIG_USERCONFIG -Value $env:DOTFILES/.config/npm/npmrc
|
||||||
|
|
||||||
|
|
||||||
# registry=https://registry.npmmirror.com
|
# registry=https://registry.npmmirror.com
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,12 @@
|
||||||
|
# $DOTFILES/common/tmux.conf
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# `tmux` - Terminal Multiplexer
|
||||||
|
|
||||||
|
# Location:
|
||||||
# $XDG_CONFIG_HOME/tmux/tmux.conf
|
# $XDG_CONFIG_HOME/tmux/tmux.conf
|
||||||
# ln -sf $DOTFILES/.config/tmux/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
|
||||||
|
|
||||||
# Prefix
|
# Prefix
|
||||||
# -----------------
|
# -----------------
|
||||||
|
|
@ -14,7 +21,7 @@ set-option -g allow-rename on
|
||||||
set-option -g alternate-screen on
|
set-option -g alternate-screen on
|
||||||
set-option -g visual-activity on
|
set-option -g visual-activity on
|
||||||
set-option -g pane-border-style fg=colour244
|
set-option -g pane-border-style fg=colour244
|
||||||
set-option -g pane-activity-border-style fg=colour239
|
# set-option -g pane-activity-border-style fg=colour239
|
||||||
|
|
||||||
# Index
|
# Index
|
||||||
# -----------------
|
# -----------------
|
||||||
|
|
@ -54,17 +61,17 @@ bind ` resize-pane -Z
|
||||||
|
|
||||||
# Status Bar
|
# Status Bar
|
||||||
# -----------------
|
# -----------------
|
||||||
# set -g status-position top
|
|
||||||
# set-option -g status-bg black
|
|
||||||
# set-option -g status-fg white
|
|
||||||
# set-option -g status-left '#[fg=green][#S] '
|
|
||||||
# setw -g window-status-current-format '#[fg=colour236,bg=colour39] #I #W '
|
|
||||||
|
|
||||||
set -g status-position top
|
set -g status-position top
|
||||||
set -g @catppuccin_flavor "frappe"
|
set-option -g status-bg black
|
||||||
run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
|
set-option -g status-fg white
|
||||||
set -g status-right-length 100
|
set-option -g status-left '#[fg=green][#S] '
|
||||||
set -g status-left-length 100
|
setw -g window-status-current-format '#[fg=colour236,bg=colour39] #I #W '
|
||||||
set -g status-left ""
|
|
||||||
set -g status-right "#{E:@catppuccin_status_application}"
|
# set -g status-position top
|
||||||
set -ag status-right "#{E:@catppuccin_status_session}"
|
# set -g @catppuccin_flavor "frappe"
|
||||||
|
# run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
|
||||||
|
# set -g status-right-length 100
|
||||||
|
# set -g status-left-length 100
|
||||||
|
# set -g status-left ""
|
||||||
|
# set -g status-right "#{E:@catppuccin_status_application}"
|
||||||
|
# set -ag status-right "#{E:@catppuccin_status_session}"
|
||||||
|
|
|
||||||
|
|
@ -13,9 +13,9 @@ keybinds {
|
||||||
}
|
}
|
||||||
pane {
|
pane {
|
||||||
bind "h" "Left" { MoveFocus "Left"; }
|
bind "h" "Left" { MoveFocus "Left"; }
|
||||||
bind "i" "Right" { MoveFocus "Right"; }
|
|
||||||
bind "n" "Down" { MoveFocus "Down"; }
|
bind "n" "Down" { MoveFocus "Down"; }
|
||||||
bind "e" "Up" { MoveFocus "Up"; }
|
bind "e" "Up" { MoveFocus "Up"; }
|
||||||
|
bind "i" "Right" { MoveFocus "Right"; }
|
||||||
bind "p" { SwitchFocus; }
|
bind "p" { SwitchFocus; }
|
||||||
}
|
}
|
||||||
locked {
|
locked {
|
||||||
|
|
|
||||||
12
platforms/linux/hyprland/code-flags.conf
Normal file
12
platforms/linux/hyprland/code-flags.conf
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
# $DOTFILES/platforms/linux/hyprland/code-flags.conf
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Force VSCode to use Wayland
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/code-flags.conf
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/hyprland/code-flags.conf ~/.config/
|
||||||
|
|
||||||
|
--enable-features=UseOzonePlatform
|
||||||
|
--ozone-platform=wayland
|
||||||
13
platforms/linux/hyprland/electron-flags.conf
Normal file
13
platforms/linux/hyprland/electron-flags.conf
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
# $DOTFILES/platforms/linux/hyprland/electron-flags.conf
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Force electron apps to use Wayland
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/electron-flags.conf
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/hyprland/electron-flags.conf ~/.config/
|
||||||
|
|
||||||
|
--enable-features=UseOzonePlatform
|
||||||
|
--ozone-platform=wayland
|
||||||
|
--enable-icd
|
||||||
315
platforms/linux/hyprland/hypr/hyprland.conf
Normal file
315
platforms/linux/hyprland/hypr/hyprland.conf
Normal file
|
|
@ -0,0 +1,315 @@
|
||||||
|
# $DOTFILES/platforms/linux/hyprland/hypr/hyprland.conf
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Hyprland Window Manager Configuration
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/hypr/hyprland.conf
|
||||||
|
# Linking: (Link the whole `hypr` directory)
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/hyprland/hypr $XDG_CONFIG_HOME/hypr
|
||||||
|
|
||||||
|
# #######################################################################################
|
||||||
|
# AUTOGENERATED HYPRLAND CONFIG.
|
||||||
|
# PLEASE USE THE CONFIG PROVIDED IN THE GIT REPO /examples/hyprland.conf AND EDIT IT,
|
||||||
|
# OR EDIT THIS ONE ACCORDING TO THE WIKI INSTRUCTIONS.
|
||||||
|
# #######################################################################################
|
||||||
|
|
||||||
|
autogenerated = 0 # remove this line to remove the warning
|
||||||
|
|
||||||
|
# This is an example Hyprland config file.
|
||||||
|
# Refer to the wiki for more information.
|
||||||
|
# https://wiki.hyprland.org/Configuring/
|
||||||
|
|
||||||
|
# Please note not all available settings / options are set here.
|
||||||
|
# For a full list, see the wiki
|
||||||
|
|
||||||
|
# You can split this configuration into multiple files
|
||||||
|
# Create your files separately and then link them to this file like this:
|
||||||
|
# source = ~/.config/hypr/myColors.conf
|
||||||
|
#
|
||||||
|
|
||||||
|
xwayland {
|
||||||
|
force_zero_scaling = true
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
################
|
||||||
|
### MONITORS ###
|
||||||
|
################
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Monitors/
|
||||||
|
monitor=,preferred,auto,auto
|
||||||
|
|
||||||
|
|
||||||
|
###################
|
||||||
|
### MY PROGRAMS ###
|
||||||
|
###################
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Keywords/
|
||||||
|
|
||||||
|
# Set programs that you use
|
||||||
|
$terminal = kitty
|
||||||
|
$fileManager = dolphin
|
||||||
|
$menu = wofi --show drun
|
||||||
|
|
||||||
|
|
||||||
|
#################
|
||||||
|
### AUTOSTART ###
|
||||||
|
#################
|
||||||
|
|
||||||
|
# Autostart necessary processes (like notifications daemons, status bars, etc.)
|
||||||
|
# Or execute your favorite apps at launch like this:
|
||||||
|
|
||||||
|
# exec-once = $terminal
|
||||||
|
# exec-once = nm-applet &
|
||||||
|
exec-once = waybar & hyprpaper & mako & systemctl --user start hyprpolkitagent
|
||||||
|
|
||||||
|
|
||||||
|
#############################
|
||||||
|
### ENVIRONMENT VARIABLES ###
|
||||||
|
#############################
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Environment-variables/
|
||||||
|
|
||||||
|
env = XCURSOR_SIZE,24
|
||||||
|
env = HYPRCURSOR_SIZE,24
|
||||||
|
|
||||||
|
|
||||||
|
#####################
|
||||||
|
### LOOK AND FEEL ###
|
||||||
|
#####################
|
||||||
|
|
||||||
|
# Refer to https://wiki.hyprland.org/Configuring/Variables/
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#general
|
||||||
|
general {
|
||||||
|
gaps_in = 5
|
||||||
|
gaps_out = 20
|
||||||
|
|
||||||
|
border_size = 2
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#variable-types for info about colors
|
||||||
|
col.active_border = rgba(33ccffee) rgba(00ff99ee) 45deg
|
||||||
|
col.inactive_border = rgba(595959aa)
|
||||||
|
|
||||||
|
# Set to true enable resizing windows by clicking and dragging on borders and gaps
|
||||||
|
resize_on_border = false
|
||||||
|
|
||||||
|
# Please see https://wiki.hyprland.org/Configuring/Tearing/ before you turn this on
|
||||||
|
allow_tearing = false
|
||||||
|
|
||||||
|
layout = dwindle
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#decoration
|
||||||
|
decoration {
|
||||||
|
rounding = 10
|
||||||
|
|
||||||
|
# Change transparency of focused and unfocused windows
|
||||||
|
active_opacity = 1.0
|
||||||
|
inactive_opacity = 1.0
|
||||||
|
|
||||||
|
shadow {
|
||||||
|
enabled = true
|
||||||
|
range = 4
|
||||||
|
render_power = 3
|
||||||
|
color = rgba(1a1a1aee)
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#blur
|
||||||
|
blur {
|
||||||
|
enabled = true
|
||||||
|
size = 3
|
||||||
|
passes = 1
|
||||||
|
|
||||||
|
vibrancy = 0.1696
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#animations
|
||||||
|
animations {
|
||||||
|
enabled = yes, please :)
|
||||||
|
|
||||||
|
# Default animations, see https://wiki.hyprland.org/Configuring/Animations/ for more
|
||||||
|
|
||||||
|
bezier = easeOutQuint,0.23,1,0.32,1
|
||||||
|
bezier = easeInOutCubic,0.65,0.05,0.36,1
|
||||||
|
bezier = linear,0,0,1,1
|
||||||
|
bezier = almostLinear,0.5,0.5,0.75,1.0
|
||||||
|
bezier = quick,0.15,0,0.1,1
|
||||||
|
|
||||||
|
animation = global, 1, 10, default
|
||||||
|
animation = border, 1, 5.39, easeOutQuint
|
||||||
|
animation = windows, 1, 4.79, easeOutQuint
|
||||||
|
animation = windowsIn, 1, 4.1, easeOutQuint, popin 87%
|
||||||
|
animation = windowsOut, 1, 1.49, linear, popin 87%
|
||||||
|
animation = fadeIn, 1, 1.73, almostLinear
|
||||||
|
animation = fadeOut, 1, 1.46, almostLinear
|
||||||
|
animation = fade, 1, 3.03, quick
|
||||||
|
animation = layers, 1, 3.81, easeOutQuint
|
||||||
|
animation = layersIn, 1, 4, easeOutQuint, fade
|
||||||
|
animation = layersOut, 1, 1.5, linear, fade
|
||||||
|
animation = fadeLayersIn, 1, 1.79, almostLinear
|
||||||
|
animation = fadeLayersOut, 1, 1.39, almostLinear
|
||||||
|
animation = workspaces, 1, 1.94, almostLinear, fade
|
||||||
|
animation = workspacesIn, 1, 1.21, almostLinear, fade
|
||||||
|
animation = workspacesOut, 1, 1.94, almostLinear, fade
|
||||||
|
}
|
||||||
|
|
||||||
|
# Ref https://wiki.hyprland.org/Configuring/Workspace-Rules/
|
||||||
|
# "Smart gaps" / "No gaps when only"
|
||||||
|
# uncomment all if you wish to use that.
|
||||||
|
# workspace = w[tv1], gapsout:0, gapsin:0
|
||||||
|
# workspace = f[1], gapsout:0, gapsin:0
|
||||||
|
# windowrulev2 = bordersize 0, floating:0, onworkspace:w[tv1]
|
||||||
|
# windowrulev2 = rounding 0, floating:0, onworkspace:w[tv1]
|
||||||
|
# windowrulev2 = bordersize 0, floating:0, onworkspace:f[1]
|
||||||
|
# windowrulev2 = rounding 0, floating:0, onworkspace:f[1]
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
|
||||||
|
dwindle {
|
||||||
|
pseudotile = true # Master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
|
||||||
|
preserve_split = true # You probably want this
|
||||||
|
}
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Master-Layout/ for more
|
||||||
|
master {
|
||||||
|
new_status = master
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#misc
|
||||||
|
misc {
|
||||||
|
force_default_wallpaper = -1 # Set to 0 or 1 to disable the anime mascot wallpapers
|
||||||
|
disable_hyprland_logo = false # If true disables the random hyprland logo / anime girl background. :(
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#############
|
||||||
|
### INPUT ###
|
||||||
|
#############
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#input
|
||||||
|
input {
|
||||||
|
kb_layout = us
|
||||||
|
kb_variant =
|
||||||
|
kb_model =
|
||||||
|
kb_options =
|
||||||
|
kb_rules =
|
||||||
|
|
||||||
|
follow_mouse = 1
|
||||||
|
|
||||||
|
sensitivity = 0 # -1.0 - 1.0, 0 means no modification.
|
||||||
|
|
||||||
|
touchpad {
|
||||||
|
natural_scroll = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://wiki.hyprland.org/Configuring/Variables/#gestures
|
||||||
|
gestures {
|
||||||
|
workspace_swipe = false
|
||||||
|
}
|
||||||
|
|
||||||
|
# Example per-device config
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Keywords/#per-device-input-configs for more
|
||||||
|
device {
|
||||||
|
name = epic-mouse-v1
|
||||||
|
sensitivity = -0.5
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
###################
|
||||||
|
### KEYBINDINGS ###
|
||||||
|
###################
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Keywords/
|
||||||
|
$mainMod = SUPER # Sets "Windows" key as main modifier
|
||||||
|
|
||||||
|
# Example binds, see https://wiki.hyprland.org/Configuring/Binds/ for more
|
||||||
|
bind = $mainMod, R, exec, $terminal
|
||||||
|
bind = $mainMod, Q, killactive,
|
||||||
|
bind = $mainMod, M, exit,
|
||||||
|
bind = $mainMod, F, exec, $fileManager
|
||||||
|
bind = $mainMod, V, togglefloating,
|
||||||
|
bind = $mainMod, space, exec, $menu
|
||||||
|
bind = $mainMod, P, pseudo, # dwindle
|
||||||
|
bind = $mainMod, X, togglesplit, # dwindle
|
||||||
|
|
||||||
|
# Move focus with mainMod + arrow keys
|
||||||
|
bind = $mainMod, left, movefocus, l
|
||||||
|
bind = $mainMod, right, movefocus, r
|
||||||
|
bind = $mainMod, up, movefocus, u
|
||||||
|
bind = $mainMod, down, movefocus, d
|
||||||
|
bind = $mainMod, h, movefocus, l
|
||||||
|
bind = $mainMod, i, movefocus, r
|
||||||
|
bind = $mainMod, e, movefocus, u
|
||||||
|
bind = $mainMod, n, movefocus, d
|
||||||
|
|
||||||
|
# Switch workspaces with mainMod + [0-9]
|
||||||
|
bind = $mainMod, 1, workspace, 1
|
||||||
|
bind = $mainMod, 2, workspace, 2
|
||||||
|
bind = $mainMod, 3, workspace, 3
|
||||||
|
bind = $mainMod, 4, workspace, 4
|
||||||
|
bind = $mainMod, 5, workspace, 5
|
||||||
|
bind = $mainMod, 6, workspace, 6
|
||||||
|
bind = $mainMod, 7, workspace, 7
|
||||||
|
bind = $mainMod, 8, workspace, 8
|
||||||
|
bind = $mainMod, 9, workspace, 9
|
||||||
|
bind = $mainMod, 0, workspace, 10
|
||||||
|
|
||||||
|
# Move active window to a workspace with mainMod + SHIFT + [0-9]
|
||||||
|
bind = $mainMod SHIFT, 1, movetoworkspace, 1
|
||||||
|
bind = $mainMod SHIFT, 2, movetoworkspace, 2
|
||||||
|
bind = $mainMod SHIFT, 3, movetoworkspace, 3
|
||||||
|
bind = $mainMod SHIFT, 4, movetoworkspace, 4
|
||||||
|
bind = $mainMod SHIFT, 5, movetoworkspace, 5
|
||||||
|
bind = $mainMod SHIFT, 6, movetoworkspace, 6
|
||||||
|
bind = $mainMod SHIFT, 7, movetoworkspace, 7
|
||||||
|
bind = $mainMod SHIFT, 8, movetoworkspace, 8
|
||||||
|
bind = $mainMod SHIFT, 9, movetoworkspace, 9
|
||||||
|
bind = $mainMod SHIFT, 0, movetoworkspace, 10
|
||||||
|
|
||||||
|
# Example special workspace (scratchpad)
|
||||||
|
bind = $mainMod, S, togglespecialworkspace, magic
|
||||||
|
bind = $mainMod SHIFT, S, movetoworkspace, special:magic
|
||||||
|
|
||||||
|
# Scroll through existing workspaces with mainMod + scroll
|
||||||
|
bind = $mainMod, mouse_down, workspace, e+1
|
||||||
|
bind = $mainMod, mouse_up, workspace, e-1
|
||||||
|
|
||||||
|
# Move/resize windows with mainMod + LMB/RMB and dragging
|
||||||
|
bindm = $mainMod, mouse:272, movewindow
|
||||||
|
bindm = $mainMod, mouse:273, resizewindow
|
||||||
|
|
||||||
|
# Laptop multimedia keys for volume and LCD brightness
|
||||||
|
bindel = ,XF86AudioRaiseVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+
|
||||||
|
bindel = ,XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-
|
||||||
|
bindel = ,XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle
|
||||||
|
bindel = ,XF86AudioMicMute, exec, wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle
|
||||||
|
bindel = ,XF86MonBrightnessUp, exec, brightnessctl s 10%+
|
||||||
|
bindel = ,XF86MonBrightnessDown, exec, brightnessctl s 10%-
|
||||||
|
|
||||||
|
# Requires playerctl
|
||||||
|
bindl = , XF86AudioNext, exec, playerctl next
|
||||||
|
bindl = , XF86AudioPause, exec, playerctl play-pause
|
||||||
|
bindl = , XF86AudioPlay, exec, playerctl play-pause
|
||||||
|
bindl = , XF86AudioPrev, exec, playerctl previous
|
||||||
|
|
||||||
|
##############################
|
||||||
|
### WINDOWS AND WORKSPACES ###
|
||||||
|
##############################
|
||||||
|
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Window-Rules/ for more
|
||||||
|
# See https://wiki.hyprland.org/Configuring/Workspace-Rules/ for workspace rules
|
||||||
|
|
||||||
|
# Example windowrule v1
|
||||||
|
# windowrule = float, ^(kitty)$
|
||||||
|
|
||||||
|
# Example windowrule v2
|
||||||
|
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
||||||
|
|
||||||
|
# Ignore maximize requests from apps. You'll probably like this.
|
||||||
|
windowrulev2 = suppressevent maximize, class:.*
|
||||||
|
|
||||||
|
# Fix some dragging issues with XWayland
|
||||||
|
windowrulev2 = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0
|
||||||
12
platforms/linux/hyprland/hypr/hyprpaper.conf
Normal file
12
platforms/linux/hyprland/hypr/hyprpaper.conf
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
# $DOTFILES/platforms/linux/hyprland/hypr/hyprpaper.conf
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Hyprland Wallpaper autoloader
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/hypr/hyprpaper.conf
|
||||||
|
# Linking: (Link the whole `hypr` directory)
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/hyprland/hypr $XDG_CONFIG_HOME/hypr
|
||||||
|
|
||||||
|
preload = ~/Pictures/Wallpaper/current.jpg
|
||||||
|
wallpaper = DP-2, ~/Pictures/Wallpaper/current.jpg
|
||||||
|
|
@ -1,7 +1,16 @@
|
||||||
|
# $DOTFILES/platforms/linux/kde/dolphinrc
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Dolphin - KDE File Explorer
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/dolphinrc
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/kde/dolphinrc $XDG_CONFIG_HOME/dolphinrc
|
||||||
|
|
||||||
[General]
|
[General]
|
||||||
Version=202
|
Version=202
|
||||||
ViewPropsTimestamp=2024,12,10,0,19,35.931
|
ViewPropsTimestamp=2024,12,10,0,19,35.931
|
||||||
|
|
||||||
[IconsMode]
|
[IconsMode]
|
||||||
PreviewSize=80
|
PreviewSize=80
|
||||||
|
|
||||||
19
platforms/linux/kde/krunnerrc
Normal file
19
platforms/linux/kde/krunnerrc
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
# $DOTFILES/platforms/linux/kde/krunnerrc
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
# Krunner Config
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# $XDG_CONFIG_HOME/krunnerrc
|
||||||
|
# Linking:
|
||||||
|
# ln -sf $DOTFILES/platforms/linux/kde/krunnerrc $XDG_CONFIG_HOME/krunnerrc
|
||||||
|
|
||||||
|
[General]
|
||||||
|
FreeFloating=true
|
||||||
|
historyBehavior=ImmediateCompletion
|
||||||
|
|
||||||
|
[Plugins][Favorites]
|
||||||
|
plugins=krunner_dictionary,krunner_services,krunner_systemsettings
|
||||||
|
|
||||||
|
[Runners][krunner_dictionary]
|
||||||
|
triggerWord=d
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
[General]
|
|
||||||
FreeFloating=true
|
|
||||||
historyBehavior=ImmediateCompletion
|
|
||||||
|
|
||||||
[Plugins][Favorites]
|
|
||||||
plugins=krunner_dictionary,krunner_services,krunner_systemsettings
|
|
||||||
|
|
||||||
[Runners][krunner_dictionary]
|
|
||||||
triggerWord=d
|
|
||||||
|
|
@ -1,15 +1,13 @@
|
||||||
# Use powerline
|
# $DOTFILES/platforms/linux/zshrc
|
||||||
USE_POWERLINE="true"
|
# Date: 2024-12-22
|
||||||
# Has weird character width
|
# Author: js0ny
|
||||||
# Example:
|
# Sourced by user's zshrc if is Linux 在用户的 zshrc 中被引用
|
||||||
# is not a diamond
|
# Entry point in $DOTFILES/tools/zsh/common.zshrc (入口点)
|
||||||
HAS_WIDECHARS="false"
|
|
||||||
alias open=dolphin
|
|
||||||
# Source manjaro-zsh-configuration
|
if [ -n "$WAYLAND_DISPLAY" ]; then
|
||||||
if [[ -e /usr/share/zsh/manjaro-zsh-config ]]; then
|
alias clip="wl-copy"
|
||||||
source /usr/share/zsh/manjaro-zsh-config
|
alias paste="wl-paste"
|
||||||
|
else [ -n "$DISPLAY" ]; then
|
||||||
|
alias clip="xclip"
|
||||||
fi
|
fi
|
||||||
# Use manjaro zsh prompt
|
|
||||||
# if [[ -e /usr/share/zsh/manjaro-zsh-prompt ]]; then
|
|
||||||
# source /usr/share/zsh/manjaro-zsh-prompt
|
|
||||||
# fi
|
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,6 @@
|
||||||
|
|
||||||
# macOS #
|
# macOS #
|
||||||
|
|
||||||
alias xclip="pbcopy"
|
|
||||||
alias clip="pbcopy"
|
alias clip="pbcopy"
|
||||||
alias paste="pbpaste"
|
alias paste="pbpaste"
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
export FILE_EXPLORER="explorer.exe" # Directory Opus
|
export FILE_EXPLORER="explorer.exe" # Directory Opus
|
||||||
|
|
||||||
alias clip="clip.exe"
|
alias clip="clip.exe"
|
||||||
alias xclip="clip.exe"
|
alias clip="clip.exe"
|
||||||
alias paste='pwsh.exe -NoProfile -Command "Get-Clipboard"'
|
alias paste='pwsh.exe -NoProfile -Command "Get-Clipboard"'
|
||||||
alias dark-mode='pwsh.exe -Command "dark-mode" 2>&1 /dev/null'
|
alias dark-mode='pwsh.exe -Command "dark-mode" 2>&1 /dev/null'
|
||||||
alias winfetch='pwsh.exe -NoProfile -Command "winfetch"'
|
alias winfetch='pwsh.exe -NoProfile -Command "winfetch"'
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,11 @@
|
||||||
|
# $DOTFILES/tools/fish/conf.d/alias.fish
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/fish/conf.d/alias.fish
|
||||||
|
# Linking: Link the whole directory for submodules
|
||||||
|
# ln -sf $DOTFILES/tools/fish ~/.config/fish
|
||||||
|
|
||||||
# Powershell equivalent
|
# Powershell equivalent
|
||||||
abbr --add ni touch
|
abbr --add ni touch
|
||||||
|
|
@ -8,7 +15,7 @@ abbr --add ii open
|
||||||
# Editors #
|
# Editors #
|
||||||
abbr --add v nvim
|
abbr --add v nvim
|
||||||
abbr --add c code
|
abbr --add c code
|
||||||
alias sv="sudo vim -u ~/.config/vim/vimrc"
|
alias sv="sudo vim -u ~/.dotfiles/common/vim.noxdg.vimrc"
|
||||||
alias sn="sudo nvim -u ~/.config/nvim/init.lua"
|
alias sn="sudo nvim -u ~/.config/nvim/init.lua"
|
||||||
|
|
||||||
# Dev #
|
# Dev #
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,20 @@
|
||||||
|
# $DOTFILES/tools/fish/conf.d/keymap.fish
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/fish/conf.d/keymap.fish
|
||||||
|
# Linking: Link the whole directory for submodules
|
||||||
|
# ln -sf $DOTFILES/tools/fish ~/.config/fish
|
||||||
|
|
||||||
|
|
||||||
fish_vi_key_bindings
|
fish_vi_key_bindings
|
||||||
|
|
||||||
# Colemak hnei
|
# Colemak hnei
|
||||||
# ^
|
# ^
|
||||||
# n
|
|
||||||
# < h i >
|
|
||||||
# e
|
# e
|
||||||
|
# < h i >
|
||||||
|
# n
|
||||||
# v
|
# v
|
||||||
# bind -M default 'h' backward-char
|
# bind -M default 'h' backward-char
|
||||||
bind -M default 'n' down-or-search
|
bind -M default 'n' down-or-search
|
||||||
|
|
@ -14,3 +24,5 @@ bind -M default 'i' forward-char
|
||||||
# Similar position to [i] in QWERTY
|
# Similar position to [i] in QWERTY
|
||||||
bind -M default -m insert l repaint-mode
|
bind -M default -m insert l repaint-mode
|
||||||
bind -M default -m insert L beginning-of-line repaint-mode
|
bind -M default -m insert L beginning-of-line repaint-mode
|
||||||
|
|
||||||
|
# TODO: Add more key bindings here
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,11 @@
|
||||||
|
# $DOTFILES/tools/fish/conf.d/navi.fish
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/fish/conf.d/navi.fish
|
||||||
|
# Linking: Link the whole directory for submodules
|
||||||
|
# ln -sf $DOTFILES/tools/fish ~/.config/fish
|
||||||
|
|
||||||
|
|
||||||
alias ..="cd .."
|
alias ..="cd .."
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,11 @@
|
||||||
|
# $DOTFILES/tools/fish/conf.d/prompt.fish
|
||||||
|
# Date: 2024-12-22
|
||||||
|
# Author: js0ny
|
||||||
|
|
||||||
|
# Location:
|
||||||
|
# ~/.config/fish/conf.d/prompt.fish
|
||||||
|
# Linking: Link the whole directory for submodules
|
||||||
|
# ln -sf $DOTFILES/tools/fish ~/.config/fish
|
||||||
|
|
||||||
if command -v starship > /dev/null
|
if command -v starship > /dev/null
|
||||||
set -gx STARSHIP_CONFIG $DOTFILES/tools/starship/starship_fish.toml
|
set -gx STARSHIP_CONFIG $DOTFILES/tools/starship/starship_fish.toml
|
||||||
|
|
|
||||||
|
|
@ -1,17 +1,21 @@
|
||||||
-- Entry point of the plugin manager
|
-- Entry point of the plugin manager
|
||||||
local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim"
|
local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim"
|
||||||
if not vim.loop.fs_stat(lazypath) then
|
if not (vim.uv or vim.loop).fs_stat(lazypath) then
|
||||||
vim.fn.system({
|
local lazyrepo = "https://github.com/folke/lazy.nvim.git"
|
||||||
"git",
|
local out = vim.fn.system({ "git", "clone", "--filter=blob:none", "--branch=stable", lazyrepo, lazypath })
|
||||||
"clone",
|
if vim.v.shell_error ~= 0 then
|
||||||
"--filter=blob:none",
|
vim.api.nvim_echo({
|
||||||
"https://github.com/folke/lazy.nvim.git",
|
{ "Failed to clone lazy.nvim:\n", "ErrorMsg" },
|
||||||
"--branch=stable",
|
{ out, "WarningMsg" },
|
||||||
lazypath,
|
{ "\nPress any key to exit..." },
|
||||||
})
|
}, true, {})
|
||||||
|
vim.fn.getchar()
|
||||||
|
os.exit(1)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
vim.opt.rtp:prepend(lazypath)
|
vim.opt.rtp:prepend(lazypath)
|
||||||
|
|
||||||
|
|
||||||
require("lazy").setup({
|
require("lazy").setup({
|
||||||
{ import = "plugins.appearance" },
|
{ import = "plugins.appearance" },
|
||||||
{ import = "plugins.completion" },
|
{ import = "plugins.completion" },
|
||||||
|
|
|
||||||
|
|
@ -26,7 +26,7 @@ alias pulldots="cd $DOTFILES && git pull"
|
||||||
# Editors #
|
# Editors #
|
||||||
alias v=nvim
|
alias v=nvim
|
||||||
alias c=code
|
alias c=code
|
||||||
alias sv="sudo vim -u ~/.config/vim/vimrc"
|
alias sv="sudo vim -u ~/.dotfiles/common/vim.noxdg.vimrc"
|
||||||
alias sn="sudo nvim -u ~/.config/nvim/init.lua"
|
alias sn="sudo nvim -u ~/.config/nvim/init.lua"
|
||||||
|
|
||||||
# lsd - modern ls
|
# lsd - modern ls
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue