next #1
43 changed files with 238 additions and 886 deletions
.gitignoreREADME.mddot
compatibility
crates
00-system
10-zsh
20-vim
30-alacritty
files
gpackage.listhop.shpackage.listscripts
sync.sh
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +0,0 @@
|
||||||
.idea/
|
|
|
@ -1,9 +0,0 @@
|
||||||
# Faulty's Dotfiles
|
|
||||||
Version: 3
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## file sync
|
|
||||||
files in `./files` are synced across the system.
|
|
||||||
files in `./files/home` are synced to the home of the user running the script.
|
|
||||||
files in `./files/root` are synced with sudo to the root of the script.
|
|
|
@ -1,12 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
export SUDO=sudo
|
|
||||||
|
|
||||||
export PM=dnf
|
|
||||||
export PM_INSTALL=install
|
|
||||||
export PM_NOCONFIRM=-y
|
|
||||||
|
|
||||||
$SUDO dnf update
|
|
||||||
[ "${NO_GRAPHICS:-no}" = "yes" ] || $SUDO $PM $PM_INSTALL $PM_NOCONFIRM libX11-devel libXft-devel libXinerama-devel libXrandr-devel xorg-x11-xinit-session
|
|
||||||
|
|
||||||
[ -f ./sync.sh ] && ./sync.sh $@ || (cd .. && ./sync.sh $@)
|
|
11
crates/00-system/crate.arch.sh
Normal file
11
crates/00-system/crate.arch.sh
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
super_apply() {
|
||||||
|
pacman -S --needed sudo reflector
|
||||||
|
if ! grep -q "Reflector" /etc/pacman.d/mirrorlist; then
|
||||||
|
cp /etc/pacman.d/mirrorlist /etc/pacman.d/mirrorlist.bak
|
||||||
|
reflector -c NL -f 10 --threads 4 --save /etc/pacman.d/mirrorlist
|
||||||
|
else
|
||||||
|
echo "err: reflector already executed -- skipping..."
|
||||||
|
fi
|
||||||
|
|
||||||
|
cp files/pacman.conf /etc/pacman.conf
|
||||||
|
}
|
7
crates/00-system/crate.sh
Normal file
7
crates/00-system/crate.sh
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
describe="Install stuff on the system!"
|
||||||
|
|
||||||
|
super_apply() {
|
||||||
|
cp files/sudoers /etc/sudoers
|
||||||
|
}
|
31
crates/00-system/files/pacman.conf
Normal file
31
crates/00-system/files/pacman.conf
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
[options]
|
||||||
|
HoldPkg = pacman glibc yay
|
||||||
|
Architecture = auto
|
||||||
|
|
||||||
|
Color
|
||||||
|
CheckSpace
|
||||||
|
ParallelDownloads = 5
|
||||||
|
|
||||||
|
SigLevel = Required DatabaseOptional
|
||||||
|
LocalFileSigLevel = Optional
|
||||||
|
|
||||||
|
#[testing]
|
||||||
|
#Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[core]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[extra]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
#[community-testing]
|
||||||
|
#Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[community]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
#[multilib-testing]
|
||||||
|
#Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[multilib]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
4
crates/00-system/files/sudoers
Normal file
4
crates/00-system/files/sudoers
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
root ALL=(ALL:ALL) ALL
|
||||||
|
%wheel ALL=(ALL:ALL) ALL
|
||||||
|
%root ALL=(ALL:ALL) NOPASSWD: ALL
|
||||||
|
@includedir /etc/sudoers.d
|
7
crates/10-zsh/crate.arch.sh
Normal file
7
crates/10-zsh/crate.arch.sh
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
super_apply() {
|
||||||
|
pacman -S --needed zsh cmake
|
||||||
|
}
|
||||||
|
|
||||||
|
super_undo() {
|
||||||
|
pacman -R zsh
|
||||||
|
}
|
41
crates/10-zsh/crate.sh
Normal file
41
crates/10-zsh/crate.sh
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
describe="Install zsh and oh-my-zsh!"
|
||||||
|
scripts="@distro @self"
|
||||||
|
|
||||||
|
super_apply() {
|
||||||
|
[ -d /tmp/fastfetch ] || git clone https://github.com/LinusDierheimer/fastfetch /tmp/fastfetch
|
||||||
|
|
||||||
|
if ! command -v fastfetch &> /dev/null; then
|
||||||
|
cd /tmp/fastfetch
|
||||||
|
mkdir -p build
|
||||||
|
cd build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --target fastfetch
|
||||||
|
mv fastfetch /usr/local/bin/fastfetch
|
||||||
|
fi
|
||||||
|
|
||||||
|
usermod $USER --shell /bin/zsh
|
||||||
|
}
|
||||||
|
|
||||||
|
super_undo() {
|
||||||
|
usermod $USER --shell /bin/bash
|
||||||
|
}
|
||||||
|
|
||||||
|
apply() {
|
||||||
|
if [ ! -d "$HOME/.oh-my-zsh" ]; then
|
||||||
|
sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" "" --unattended
|
||||||
|
|
||||||
|
PL_DIR=${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestions
|
||||||
|
[ -d "$PL_DIR" ] || git clone https://github.com/zsh-users/zsh-autosuggestions $PL_DIR
|
||||||
|
PL_DIR=${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting
|
||||||
|
[ -d "$PL_DIR" ] || git clone https://github.com/zsh-users/zsh-syntax-highlighting.git $PL_DIR
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -e "$HOME/.zshrc" ] || ln files/.zshrc $HOME/.zshrc
|
||||||
|
}
|
||||||
|
|
||||||
|
undo() {
|
||||||
|
unlink $HOME/.zshrc
|
||||||
|
rm -rf $HOME/.oh-my-zsh
|
||||||
|
}
|
|
@ -1,10 +1,8 @@
|
||||||
export GPG_TTY=$(tty)
|
export GPG_TTY=$(tty)
|
||||||
source ~/.zsh_preferences
|
|
||||||
|
|
||||||
# paths
|
# paths
|
||||||
export PATH="$HOME/.yarn/bin:$HOME/.config/yarn/global/node_modules/.bin:$PATH"
|
export PATH="$HOME/.yarn/bin:$HOME/.config/yarn/global/node_modules/.bin:$PATH"
|
||||||
|
|
||||||
if [ $_ZSH_PREF_NO_NONSENSE != 1 ]; then
|
|
||||||
# ZSH
|
# ZSH
|
||||||
export ZSH="$HOME/.oh-my-zsh"
|
export ZSH="$HOME/.oh-my-zsh"
|
||||||
|
|
||||||
|
@ -12,24 +10,14 @@ ZSH_THEME="afowler"
|
||||||
plugins=(git docker docker-compose node zsh-autosuggestions zsh-syntax-highlighting)
|
plugins=(git docker docker-compose node zsh-autosuggestions zsh-syntax-highlighting)
|
||||||
source $ZSH/oh-my-zsh.sh
|
source $ZSH/oh-my-zsh.sh
|
||||||
|
|
||||||
source ~/.zsh_scripts
|
|
||||||
|
|
||||||
# ALIASES
|
# ALIASES
|
||||||
alias open="xdg-open"
|
alias open="xdg-open"
|
||||||
alias nobeep="sudo modprobe -r pcspkr"
|
alias nobeep="sudo modprobe -r pcspkr"
|
||||||
alias bl="sudo light -S"
|
|
||||||
alias kssh="kitty +kitten ssh"
|
|
||||||
alias get_idf='. $HOME/esp/esp-idf/export.sh'
|
|
||||||
alias get_rust='. $HOME/.cargo/env'
|
|
||||||
alias s="title $HOST && cmatrix -rs && clear"
|
alias s="title $HOST && cmatrix -rs && clear"
|
||||||
|
alias q="exit"
|
||||||
|
|
||||||
# COSMETICS
|
# COSMETICS
|
||||||
if [ $_ZSH_PREF_NO_PFETCH != 1 ]; then fastfetch; fi
|
fastfetch
|
||||||
|
|
||||||
else
|
|
||||||
PS1="$(whoami)@$(cat /etc/hostname) $ "
|
|
||||||
fi
|
|
||||||
|
|
||||||
alias q="exit"
|
|
||||||
export PATH="${PATH}:/home/${USER}/.local/bin"
|
export PATH="${PATH}:/home/${USER}/.local/bin"
|
||||||
export SSH_AUTH_SOCK="/run/user/1000/keyring/ssh"
|
export SSH_AUTH_SOCK="/run/user/1000/keyring/ssh"
|
7
crates/20-vim/crate.arch.sh
Normal file
7
crates/20-vim/crate.arch.sh
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
super_apply() {
|
||||||
|
pacman -S --needed vim
|
||||||
|
}
|
||||||
|
|
||||||
|
super_undo() {
|
||||||
|
echo "we never uninstall vim -_-"
|
||||||
|
}
|
14
crates/20-vim/crate.sh
Normal file
14
crates/20-vim/crate.sh
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
describe="Install vim and it's stuff"
|
||||||
|
scripts="@distro @self"
|
||||||
|
|
||||||
|
apply() {
|
||||||
|
[ -e "$HOME/.vimrc" ] || ln files/.vimrc $HOME/.vimrc
|
||||||
|
[ -e "$HOME/.ideavimrc" ] || ln files/.ideavimrc $HOME/.ideavimrc
|
||||||
|
}
|
||||||
|
|
||||||
|
undo() {
|
||||||
|
unlink $HOME/.vimrc
|
||||||
|
unlink $HOME/.ideavimrc
|
||||||
|
}
|
10
crates/20-vim/files/.ideavimrc
Normal file
10
crates/20-vim/files/.ideavimrc
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
source ~/.vimrc
|
||||||
|
|
||||||
|
set scrolloff=5
|
||||||
|
set incsearch
|
||||||
|
|
||||||
|
map Q gq
|
||||||
|
|
||||||
|
Plug 'machakann/vim-highlightedyank'
|
||||||
|
Plug 'tpope/vim-commentary'
|
||||||
|
Plug 'wellle/targets.vim'
|
0
files/home/.vimrc → crates/20-vim/files/.vimrc
Executable file → Normal file
0
files/home/.vimrc → crates/20-vim/files/.vimrc
Executable file → Normal file
7
crates/30-alacritty/crate.arch.sh
Normal file
7
crates/30-alacritty/crate.arch.sh
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
super_apply() {
|
||||||
|
pacman -S --needed alacritty
|
||||||
|
}
|
||||||
|
|
||||||
|
super_undo() {
|
||||||
|
pacman -R alacritty
|
||||||
|
}
|
12
crates/30-alacritty/crate.sh
Normal file
12
crates/30-alacritty/crate.sh
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
describe="Installs alacritty and configs"
|
||||||
|
scripts="@distro @self"
|
||||||
|
|
||||||
|
apply() {
|
||||||
|
[ -e "$HOME/.config/alacritty/alacritty.yml" ] || ln files/alacritty.yml $HOME/.config/alacritty/alacritty.yml
|
||||||
|
}
|
||||||
|
|
||||||
|
undo() {
|
||||||
|
unlink $HOME/.config/alacritty/alacritty.yml
|
||||||
|
}
|
|
@ -1,7 +1,3 @@
|
||||||
bell:
|
|
||||||
animation: 'Ease'
|
|
||||||
duration: 50
|
|
||||||
color: '#555555'
|
|
||||||
cursor:
|
cursor:
|
||||||
style:
|
style:
|
||||||
shape: 'Block'
|
shape: 'Block'
|
85
dot
Executable file
85
dot
Executable file
|
@ -0,0 +1,85 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
ask=0
|
||||||
|
|
||||||
|
is_function() {
|
||||||
|
type "$1" 2> /dev/null | sed "s/$1//" | grep -qwi function
|
||||||
|
}
|
||||||
|
|
||||||
|
curr_distro() {
|
||||||
|
cat /etc/os-release | grep -G "^ID=" | sed 's/ID=//'
|
||||||
|
}
|
||||||
|
|
||||||
|
include() {
|
||||||
|
[ -f "$1" ] || return 1
|
||||||
|
. $1
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
func() {
|
||||||
|
if is_function $(echo "super_$2"); then
|
||||||
|
sudo sh -c ". $1 && super_$2"
|
||||||
|
fi
|
||||||
|
is_function $2 && $2
|
||||||
|
}
|
||||||
|
|
||||||
|
get_command() {
|
||||||
|
case $1 in
|
||||||
|
a*)
|
||||||
|
printf "apply"
|
||||||
|
;;
|
||||||
|
u*)
|
||||||
|
printf "undo"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "err: not supported" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# only run this *in crate dir*
|
||||||
|
run_crate() {
|
||||||
|
include ./crate.sh || exit 1
|
||||||
|
if [ -n "$describe" ]; then
|
||||||
|
echo "desc($(basename $PWD)): $describe"
|
||||||
|
fi
|
||||||
|
cmd=$(get_command $1)
|
||||||
|
scripts=${scripts:-"@self @distro"}
|
||||||
|
for s in $scripts; do
|
||||||
|
echo "exec($(basename $PWD)): $s/$cmd"
|
||||||
|
case $s in
|
||||||
|
@self)
|
||||||
|
func ./crate.sh $cmd
|
||||||
|
;;
|
||||||
|
@distro)
|
||||||
|
unset -f super_$cmd
|
||||||
|
unset -f $cmd
|
||||||
|
include ./crate.$(curr_distro).sh
|
||||||
|
func ./crate.$(curr_distro).sh $cmd
|
||||||
|
unset -f super_$cmd
|
||||||
|
unset -f $cmd
|
||||||
|
include ./crate.sh
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
sh $s
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ $# -eq 2 ]; then
|
||||||
|
[ -d crates/*$1 ] || exit 1
|
||||||
|
cd crates/*$1
|
||||||
|
run_crate $2
|
||||||
|
cd ../..
|
||||||
|
else
|
||||||
|
[ $# -eq 0 ] && exit 2
|
||||||
|
for crate in $(find ./crates -mindepth 1 -maxdepth 1 -type d | sort); do
|
||||||
|
cd $crate
|
||||||
|
run_crate $1
|
||||||
|
cd ../..
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
|
@ -1,158 +0,0 @@
|
||||||
/* See LICENSE file for copyright and license details. */
|
|
||||||
|
|
||||||
#include <X11/XF86keysym.h>
|
|
||||||
|
|
||||||
/* appearance */
|
|
||||||
static const unsigned int borderpx = 2; /* border pixel of windows */
|
|
||||||
static const unsigned int snap = 32; /* snap pixel */
|
|
||||||
static const unsigned int systraypinning = 0; /* 0: sloppy systray follows selected monitor, >0: pin systray to monitor X */
|
|
||||||
static const unsigned int systrayonleft = 0; /* 0: systray in the right corner, >0: systray on left of status text */
|
|
||||||
static const unsigned int systrayspacing = 2; /* systray spacing */
|
|
||||||
static const int systraypinningfailfirst = 1; /* 1: if pinning fails, display systray on the first monitor, False: display systray on the last monitor*/
|
|
||||||
static const int showsystray = 1; /* 0 means no systray */
|
|
||||||
static const int showbar = 1; /* 0 means no bar */
|
|
||||||
static const int topbar = 1; /* 0 means bottom bar */
|
|
||||||
static const char *fonts[] = { "monospace:size=10" };
|
|
||||||
static const char dmenufont[] = "monospace:size=10";
|
|
||||||
|
|
||||||
static const char col_bg_inactive[] = "#444444";
|
|
||||||
static const char col_fg_inactive[] = "#bbbbbb";
|
|
||||||
|
|
||||||
static const char col_bg_highlight[] = "#ffaaaa";
|
|
||||||
static const char col_fg_highlight[] = "#000000";
|
|
||||||
|
|
||||||
static const char *colors[][3] = {
|
|
||||||
/* fg bg border */
|
|
||||||
[SchemeNorm] = { col_fg_inactive, col_bg_inactive, col_bg_inactive },
|
|
||||||
[SchemeSel] = { col_fg_highlight, col_bg_highlight, col_bg_highlight }
|
|
||||||
};
|
|
||||||
|
|
||||||
/* tagging */
|
|
||||||
static const char *tags[] = { "main", "term", "www", "chat", "5", "6", "7", "8", "9", };
|
|
||||||
|
|
||||||
static const Rule rules[] = {
|
|
||||||
/* class instance title tags mask isfloating monitor */
|
|
||||||
{ "Gimp", NULL, NULL, 0, True, -1 },
|
|
||||||
{ "firefox", NULL, NULL, 1 << 2, False, -1 },
|
|
||||||
{ "discord", NULL, NULL, 1 << 3, False, -1 },
|
|
||||||
{ "Thunderbird", NULL, NULL, 2, False, -1 },
|
|
||||||
{ "stalonetray", NULL, NULL, 1, False, -1 },
|
|
||||||
{ "chrome", NULL, NULL, 4, False, -1 },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* layout(s) */
|
|
||||||
static const float mfact = 0.55; /* factor of master area size [0.05..0.95] */
|
|
||||||
static const Bool resizehints = True; /* True means respect size hints in tiled resizals */
|
|
||||||
static const int nmaster = 1; /* number of clients in master area */
|
|
||||||
static const int lockfullscreen = 1; /* 1 will force focus on the fullscreen window */
|
|
||||||
|
|
||||||
static const Layout layouts[] = {
|
|
||||||
/* symbol arrange function */
|
|
||||||
{ "[]=", tile }, /* first entry is default */
|
|
||||||
{ "><>", NULL }, /* no layout function means floating behavior */
|
|
||||||
{ "[M]", monocle },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* key definitions */
|
|
||||||
#define MODKEY Mod4Mask
|
|
||||||
#define TAGKEYS(KEY,TAG) \
|
|
||||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
|
||||||
|
|
||||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
|
||||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
|
||||||
|
|
||||||
/* commands */
|
|
||||||
|
|
||||||
// dmenu
|
|
||||||
static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
|
|
||||||
static const char *dmenucmd[] = {
|
|
||||||
"dmenu_run",
|
|
||||||
"-m", dmenumon,
|
|
||||||
"-fn", dmenufont,
|
|
||||||
"-nb", col_bg_inactive,
|
|
||||||
"-nf", col_fg_inactive,
|
|
||||||
"-sb", col_bg_highlight,
|
|
||||||
"-sf", col_fg_highlight, NULL };
|
|
||||||
|
|
||||||
// terminal
|
|
||||||
static const char *termcmd[] = { "alacritty", NULL };
|
|
||||||
|
|
||||||
// general & sys
|
|
||||||
static const char *locksaver[] = { "/usr/local/bin/dwm-lock", NULL };
|
|
||||||
static const char *vol_up[] = { "amixer", "set", "Master", "5%+", NULL };
|
|
||||||
static const char *vol_down[] = { "amixer", "set", "Master", "5%-", NULL };
|
|
||||||
static const char *vol_mute[] = { "amixer", "set", "Master", "toggle", NULL };
|
|
||||||
static const char *light_up[] = {"light", "-A", "5", NULL};
|
|
||||||
static const char *light_down[] = {"light", "-U", "5", NULL};
|
|
||||||
|
|
||||||
// screenshots
|
|
||||||
static const char *screenshot[] = {"flameshot", "full", "-c", NULL};
|
|
||||||
static const char *screenshot_partial[] = {"flameshot", "gui", "-c", NULL};
|
|
||||||
|
|
||||||
// kill dwm
|
|
||||||
static const char *dwmdie[] = {"/bin/sh", "-c", "pkill dwm-start && pkill dwm", "null"};
|
|
||||||
|
|
||||||
static Key keys[] = {
|
|
||||||
/* modifier key function argument */
|
|
||||||
{ MODKEY, XK_Return, spawn, {.v = termcmd } },
|
|
||||||
{ MODKEY|ShiftMask, XK_d, spawn, {.v = dmenucmd } },
|
|
||||||
{ MODKEY|ShiftMask, XK_e, spawn, {.v = dwmdie } },
|
|
||||||
{ MODKEY, XK_l, spawn, {.v = locksaver } },
|
|
||||||
{ MODKEY, XK_b, togglebar, {0} },
|
|
||||||
{ MODKEY, XK_j, focusstack, {.i = +1 } },
|
|
||||||
{ MODKEY, XK_k, focusstack, {.i = -1 } },
|
|
||||||
{ MODKEY|Mod1Mask, XK_h, incnmaster, {.i = +1} },
|
|
||||||
{ MODKEY|Mod1Mask, XK_u, incnmaster, {.i = -1} },
|
|
||||||
{ MODKEY|ShiftMask, XK_Return, zoom, {0} },
|
|
||||||
{ MODKEY, XK_Tab, view, {0} },
|
|
||||||
{ MODKEY|ShiftMask, XK_c, killclient, {0} },
|
|
||||||
{ MODKEY, XK_t, setlayout, {.v = &layouts[0]} },
|
|
||||||
{ MODKEY, XK_f, setlayout, {.v = &layouts[1]} },
|
|
||||||
{ MODKEY, XK_m, setlayout, {.v = &layouts[2]} },
|
|
||||||
{ MODKEY, XK_space, setlayout, {0} },
|
|
||||||
{ MODKEY|ShiftMask, XK_space, togglefloating, {0} },
|
|
||||||
{ MODKEY, XK_0, view, {.ui = ~0 } },
|
|
||||||
{ MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
|
|
||||||
{ MODKEY, XK_comma, focusmon, {.i = -1 } },
|
|
||||||
{ MODKEY, XK_period, focusmon, {.i = +1 } },
|
|
||||||
{ MODKEY|ShiftMask, XK_comma, tagmon, {.i = -1 } },
|
|
||||||
{ MODKEY|ShiftMask, XK_period, tagmon, {.i = +1 } },
|
|
||||||
{ 0, XK_Print, spawn, {.v = screenshot } },
|
|
||||||
{ Mod1Mask, XK_Print, spawn, {.v = screenshot_partial } },
|
|
||||||
{ 0, XF86XK_AudioRaiseVolume, spawn, {.v = vol_up } },
|
|
||||||
{ 0, XF86XK_AudioLowerVolume, spawn, {.v = vol_down } },
|
|
||||||
{ 0, XF86XK_AudioMute, spawn, {.v = vol_mute } },
|
|
||||||
{ 0, XF86XK_MonBrightnessUp, spawn, {.v = light_up} },
|
|
||||||
{ 0, XF86XK_MonBrightnessDown, spawn, {.v = light_down} },
|
|
||||||
TAGKEYS( XK_1, 0)
|
|
||||||
TAGKEYS( XK_2, 1)
|
|
||||||
TAGKEYS( XK_3, 2)
|
|
||||||
TAGKEYS( XK_4, 3)
|
|
||||||
TAGKEYS( XK_5, 4)
|
|
||||||
TAGKEYS( XK_6, 5)
|
|
||||||
TAGKEYS( XK_7, 6)
|
|
||||||
TAGKEYS( XK_8, 7)
|
|
||||||
TAGKEYS( XK_9, 8)
|
|
||||||
{ MODKEY|ShiftMask|Mod1Mask, XK_q, quit, {0} },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* button definitions */
|
|
||||||
/* click can be ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
|
|
||||||
static Button buttons[] = {
|
|
||||||
/* click event mask button function argument */
|
|
||||||
{ ClkLtSymbol, 0, Button1, setlayout, {0} },
|
|
||||||
{ ClkLtSymbol, 0, Button3, setlayout, {.v = &layouts[2]} },
|
|
||||||
{ ClkWinTitle, 0, Button2, zoom, {0} },
|
|
||||||
{ ClkStatusText, 0, Button2, spawn, {.v = termcmd } },
|
|
||||||
{ ClkClientWin, MODKEY, Button1, movemouse, {0} },
|
|
||||||
{ ClkClientWin, MODKEY, Button2, togglefloating, {0} },
|
|
||||||
{ ClkClientWin, MODKEY, Button3, resizemouse, {0} },
|
|
||||||
{ ClkTagBar, 0, Button1, view, {0} },
|
|
||||||
{ ClkTagBar, 0, Button3, toggleview, {0} },
|
|
||||||
{ ClkTagBar, MODKEY, Button1, tag, {0} },
|
|
||||||
{ ClkTagBar, MODKEY, Button3, toggletag, {0} },
|
|
||||||
};
|
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
touch /tmp/$USER-screen.lock
|
|
||||||
i3lock ${@:--nefc "#000000"}
|
|
||||||
rm -f /tmp/$USER-screen.lock
|
|
|
@ -1,18 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
LITE=${LITE:-no}
|
|
||||||
|
|
||||||
xsetroot -solid black
|
|
||||||
|
|
||||||
start_apps() {
|
|
||||||
nm-applet &
|
|
||||||
flameshot &
|
|
||||||
discord &
|
|
||||||
firefox &
|
|
||||||
}
|
|
||||||
|
|
||||||
[ "$LITE" = "yes" ] || /usr/local/bin/dwm-status &
|
|
||||||
[ "$LITE" = "yes" ] || (sleep 1 && start_apps) &
|
|
||||||
|
|
||||||
feh -zZ --bg-scale $HOME/Pictures/background.*
|
|
||||||
[ "${NO_DWM:-no}" = "yes" ] || exec dwm >/dev/null
|
|
|
@ -1,26 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
xsetroot -solid black -name "starting dwm..."
|
|
||||||
|
|
||||||
#while loop to update statusbar with some goodies
|
|
||||||
while true; do
|
|
||||||
sleep 1
|
|
||||||
[ -f /tmp/$USER-screen.lock ] && continue
|
|
||||||
#memfreak to get it in MB
|
|
||||||
memfree=$(grep MemFree /proc/meminfo | awk '{ print $2 }')
|
|
||||||
memtotal=$(grep MemTotal /proc/meminfo | awk '{ print $2 }')
|
|
||||||
memfreak=$(((memtotal - memfree) / 1024))
|
|
||||||
#time
|
|
||||||
CLK=$(date +'%a %b %d %R:%S %Z')
|
|
||||||
#volume
|
|
||||||
VOL=$(amixer get Master | tail -1 | awk '{ print $5 }' | tr -d '[]')
|
|
||||||
#loadavg
|
|
||||||
AVG=$(cat /proc/loadavg | cut -d ' ' -f -3)
|
|
||||||
#network stats in Bytes
|
|
||||||
NW=$(dstat -n --nocolor 1 1 | tail -1 | awk '{ print $1, $2}')
|
|
||||||
battper=$(cat /sys/class/power_supply/BAT0/capacity)
|
|
||||||
#this one is not so good, increases a delay of 1-2s of the updating.
|
|
||||||
#put it in the xsetrootname plz (tip of the day, do not put | as first char after "
|
|
||||||
xsetroot -name "$AVG | $memfreak MB | Bat: $battper% | Vol: $VOL | $CLK |"
|
|
||||||
done
|
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
pushd ~/.local/dotfiles
|
|
||||||
./sync.sh 30-dwm.sh
|
|
||||||
popd
|
|
||||||
|
|
||||||
loginctl kill-user $USER
|
|
|
@ -1,6 +0,0 @@
|
||||||
[Desktop Entry]
|
|
||||||
Encoding=UTF-8
|
|
||||||
Name=dwm
|
|
||||||
Comment=This session starts dwm
|
|
||||||
Exec=/usr/local/bin/dwm-start
|
|
||||||
Type=Application
|
|
|
@ -1,9 +0,0 @@
|
||||||
profile school {
|
|
||||||
output "Iiyama North America PL2483H 1156290962278" mode 1920x1080 position 0,0
|
|
||||||
output eDP-1 mode 1920x1080 position 1920,0
|
|
||||||
}
|
|
||||||
|
|
||||||
#profile sharing {
|
|
||||||
# output HDMI-A-1 mode 1920x1080 position 0,1080
|
|
||||||
# output eDP-1 mode 1920x1080 position 0,0
|
|
||||||
#}
|
|
|
@ -1 +0,0 @@
|
||||||
/home/didier/.local/dotfiles/./files/kitty/kitty.conf
|
|
|
@ -1 +0,0 @@
|
||||||
@theme "Arc-Dark"
|
|
|
@ -1,248 +0,0 @@
|
||||||
# Faulty's sway Config
|
|
||||||
|
|
||||||
|
|
||||||
set $mod Mod1
|
|
||||||
set $sup Mod4
|
|
||||||
set $terminal alacritty #sway-sensible-terminal
|
|
||||||
set $browser firefox
|
|
||||||
set $editor gedit
|
|
||||||
|
|
||||||
#font pango:monospace 8
|
|
||||||
font pango:DejaVu Sans Mono 8
|
|
||||||
|
|
||||||
#! Startup Applications
|
|
||||||
exec --no-startup-id kanshi
|
|
||||||
exec --no-startup-id xss-lock --transfer-sleep-lock -- swaylock --nofork
|
|
||||||
exec --no-startup-id gnome-keyring-daemon --start --components=ssh,secrets,pkcs11
|
|
||||||
exec --no-startup-id nm-applet
|
|
||||||
exec thunderbird
|
|
||||||
exec discord
|
|
||||||
|
|
||||||
set $lock swaylock -c "#000000"
|
|
||||||
|
|
||||||
set $mode_system System (l) lock, (e) logout, (s) suspend, (h) hibernate, (Shift+r) reboot, (Shift+s) shutdown
|
|
||||||
mode "$mode_system" {
|
|
||||||
bindsym l exec --no-startup-id $lock, mode "default"
|
|
||||||
bindsym e exec --no-startup-id sway exit, mode "default"
|
|
||||||
bindsym s exec --no-startup-id $lock && systemctl suspend, mode "default"
|
|
||||||
bindsym h exec --no-startup-id $lock && systemctl hibernate, mode "default"
|
|
||||||
bindsym Shift+r exec --no-startup-id systemctl reboot, mode "default"
|
|
||||||
bindsym Shift+s exec --no-startup-id systemctl poweroff -i, mode "default"
|
|
||||||
|
|
||||||
# back to normal: Enter or Escape
|
|
||||||
bindsym Return mode "default"
|
|
||||||
bindsym Escape mode "default"
|
|
||||||
|
|
||||||
}
|
|
||||||
bindsym $sup+Delete mode "$mode_system"
|
|
||||||
bindsym $sup+l exec --no-startup-id $lock
|
|
||||||
|
|
||||||
#! Media
|
|
||||||
bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +10% && $refresh_swaystatus
|
|
||||||
bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -10% && $refresh_swaystatus
|
|
||||||
bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_swaystatus
|
|
||||||
bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_swaystatus
|
|
||||||
|
|
||||||
#! Light
|
|
||||||
bindsym XF86MonBrightnessUp exec light -A 10 # increase screen brightness
|
|
||||||
bindsym XF86MonBrightnessDown exec light -U 10 # decrease screen brightness
|
|
||||||
|
|
||||||
#! Customization
|
|
||||||
# class border backgr. text indicator child_border
|
|
||||||
client.focused #000000 #222299 #ffffff #000000 #222222
|
|
||||||
client.focused_inactive #333333 #5f676a #ffffff #484e50 #5f676a
|
|
||||||
client.unfocused #333333 #222222 #888888 #292d2e #222222
|
|
||||||
client.urgent #EF2929 #900000 #ffffff #900000 #900000
|
|
||||||
client.placeholder #000000 #0c0c0c #ffffff #000000 #0c0c0c
|
|
||||||
client.background #888A85
|
|
||||||
#exec --no-startup-id xsetroot -solid "#333333"
|
|
||||||
exec --no-startup-id swaybg -i ~/Pictures/background.png
|
|
||||||
no_focus [class="Fig" instance="fig" window_role="autocomplete"]
|
|
||||||
for_window [class="Fig" instance="fig" window_role="autocomplete"] border pixel 0
|
|
||||||
|
|
||||||
#! Navigation
|
|
||||||
set $up l
|
|
||||||
set $down k
|
|
||||||
set $left j
|
|
||||||
set $right semicolon
|
|
||||||
|
|
||||||
# use Mouse+Mod1 to drag floating windows to their wanted position
|
|
||||||
floating_modifier $sup
|
|
||||||
|
|
||||||
#! Applications
|
|
||||||
bindsym $sup+Return exec $terminal
|
|
||||||
bindsym $sup+q exec $browser
|
|
||||||
bindsym $sup+d exec rofi -show run
|
|
||||||
bindsym $sup+Shift+d exec --no-startup-id rofi -show drun
|
|
||||||
bindsym Ctrl+Print exec --no-startup-id grim ~/Pictures/Screenshots/$(date +"%d-%m-%y_%H:%M:%S").png
|
|
||||||
bindsym Print exec --no-startup-id grim - | xclip -selection clipboard -t image/png
|
|
||||||
|
|
||||||
# kill focused window
|
|
||||||
bindsym $sup+Shift+q kill
|
|
||||||
|
|
||||||
# change focus
|
|
||||||
bindsym $mod+$left focus left
|
|
||||||
bindsym $mod+$down focus down
|
|
||||||
bindsym $mod+$up focus up
|
|
||||||
bindsym $mod+$right focus right
|
|
||||||
|
|
||||||
# alternatively, you can use the cursor keys:
|
|
||||||
bindsym $mod+Left focus left
|
|
||||||
bindsym $mod+Down focus down
|
|
||||||
bindsym $mod+Up focus up
|
|
||||||
bindsym $mod+Right focus right
|
|
||||||
|
|
||||||
# move focused window
|
|
||||||
bindsym $mod+Shift+$left move left
|
|
||||||
bindsym $mod+Shift+$down move down
|
|
||||||
bindsym $mod+Shift+$up move up
|
|
||||||
bindsym $mod+Shift+$right move right
|
|
||||||
|
|
||||||
# alternatively, you can use the cursor keys:
|
|
||||||
bindsym $mod+Shift+Left move left
|
|
||||||
bindsym $mod+Shift+Down move down
|
|
||||||
bindsym $mod+Shift+Up move up
|
|
||||||
bindsym $mod+Shift+Right move right
|
|
||||||
|
|
||||||
# split in horizontal orientation
|
|
||||||
bindsym $mod+h split h
|
|
||||||
|
|
||||||
# split in vertical orientation
|
|
||||||
bindsym $mod+v split v
|
|
||||||
|
|
||||||
# enter fullscreen mode for the focused container
|
|
||||||
bindsym $mod+f fullscreen toggle
|
|
||||||
|
|
||||||
#! Layouts
|
|
||||||
# change container layout (stacked, tabbed, toggle split)
|
|
||||||
bindsym $sup+s layout stacking
|
|
||||||
bindsym $sup+w layout tabbed
|
|
||||||
bindsym $sup+e layout toggle split
|
|
||||||
|
|
||||||
# toggle tiling / floating
|
|
||||||
bindsym $mod+Shift+space floating toggle
|
|
||||||
|
|
||||||
# change focus between tiling / floating windows
|
|
||||||
bindsym $mod+space focus mode_toggle
|
|
||||||
|
|
||||||
# focus the parent container
|
|
||||||
bindsym $mod+a focus parent
|
|
||||||
|
|
||||||
# focus the child container
|
|
||||||
#bindsym Mod1+d focus child
|
|
||||||
|
|
||||||
# move the currently focused window to the scratchpad
|
|
||||||
bindsym $sup+Shift+minus move scratchpad
|
|
||||||
|
|
||||||
# Show the next scratchpad window or hide the focused scratchpad window.
|
|
||||||
# If there are multiple scratchpad windows, this command cycles through them.
|
|
||||||
bindsym $sup+minus scratchpad show
|
|
||||||
|
|
||||||
# Define names for default workspaces for which we configure key bindings later on.
|
|
||||||
# We use variables to avoid repeating the names in multiple places.
|
|
||||||
#! Workspaces
|
|
||||||
set $ws1 "1: main"
|
|
||||||
set $ws2 "2: browse"
|
|
||||||
set $ws3 "3: term"
|
|
||||||
set $ws4 "4: other"
|
|
||||||
set $ws5 "5: other"
|
|
||||||
set $ws6 "6: other"
|
|
||||||
set $ws7 "7: other"
|
|
||||||
set $ws8 "8: business"
|
|
||||||
set $ws9 "9: talk"
|
|
||||||
set $ws10 "10: misc"
|
|
||||||
|
|
||||||
#! Assignments
|
|
||||||
assign [class="Spotify"] $ws10
|
|
||||||
assign [class="firefox"] $ws2
|
|
||||||
assign [class="thunderbird"] $ws8
|
|
||||||
assign [class="discord"] $ws9
|
|
||||||
assign [class="jetbrains-idea-ce"] $ws1
|
|
||||||
|
|
||||||
bindsym $sup+$left workspace prev
|
|
||||||
bindsym $sup+$right workspace next
|
|
||||||
# alter.. youknow what is coming
|
|
||||||
bindsym $sup+Left workspace prev
|
|
||||||
bindsym $sup+Right workspace next
|
|
||||||
|
|
||||||
# switch to workspace
|
|
||||||
bindsym $sup+1 workspace number $ws1
|
|
||||||
bindsym $sup+2 workspace number $ws2
|
|
||||||
bindsym $sup+3 workspace number $ws3
|
|
||||||
bindsym $sup+4 workspace number $ws4
|
|
||||||
bindsym $sup+5 workspace number $ws5
|
|
||||||
bindsym $sup+6 workspace number $ws6
|
|
||||||
bindsym $sup+7 workspace number $ws7
|
|
||||||
bindsym $sup+8 workspace number $ws8
|
|
||||||
bindsym $sup+9 workspace number $ws9
|
|
||||||
bindsym $sup+0 workspace number $ws10
|
|
||||||
|
|
||||||
# move focused container to workspace
|
|
||||||
bindsym $sup+Shift+1 move container to workspace number $ws1
|
|
||||||
bindsym $sup+Shift+2 move container to workspace number $ws2
|
|
||||||
bindsym $sup+Shift+3 move container to workspace number $ws3
|
|
||||||
bindsym $sup+Shift+4 move container to workspace number $ws4
|
|
||||||
bindsym $sup+Shift+5 move container to workspace number $ws5
|
|
||||||
bindsym $sup+Shift+6 move container to workspace number $ws6
|
|
||||||
bindsym $sup+Shift+7 move container to workspace number $ws7
|
|
||||||
bindsym $sup+Shift+8 move container to workspace number $ws8
|
|
||||||
bindsym $sup+Shift+9 move container to workspace number $ws9
|
|
||||||
bindsym $sup+Shift+0 move container to workspace number $ws10
|
|
||||||
|
|
||||||
#! sway manage
|
|
||||||
# reload the configuration file
|
|
||||||
bindsym $sup+Shift+c reload
|
|
||||||
# restart sway inplace (preserves your layout/session, can be used to upgrade sway)
|
|
||||||
bindsym $sup+Shift+r restart
|
|
||||||
# exit sway (logs you out of your wayland session)
|
|
||||||
#bindsym $sup+Shift+e exec "swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your X session.' -B 'Yes, exit sway' 'sway exit'"
|
|
||||||
bindsym $sup+Shift+e exec wlogout
|
|
||||||
# edit config
|
|
||||||
bindsym $sup+Shift+Alt+c exec "$editor ~/.config/sway/config"
|
|
||||||
|
|
||||||
#! Resize
|
|
||||||
# resize window (you can also use the mouse for that)
|
|
||||||
mode "resize" {
|
|
||||||
# These bindings trigger as soon as you enter the resize mode
|
|
||||||
|
|
||||||
# Pressing left will shrink the window’s width.
|
|
||||||
# Pressing right will grow the window’s width.
|
|
||||||
# Pressing up will shrink the window’s height.
|
|
||||||
# Pressing down will grow the window’s height.
|
|
||||||
bindsym $left resize shrink width 10 px or 10 ppt
|
|
||||||
bindsym $down resize grow height 10 px or 10 ppt
|
|
||||||
bindsym $up resize shrink height 10 px or 10 ppt
|
|
||||||
bindsym $right resize grow width 10 px or 10 ppt
|
|
||||||
|
|
||||||
# same bindings, but for the arrow keys
|
|
||||||
bindsym Left resize shrink width 10 px or 10 ppt
|
|
||||||
bindsym Down resize grow height 10 px or 10 ppt
|
|
||||||
bindsym Up resize shrink height 10 px or 10 ppt
|
|
||||||
bindsym Right resize grow width 10 px or 10 ppt
|
|
||||||
|
|
||||||
# back to normal: Enter or Escape or Mod1+r
|
|
||||||
bindsym Return mode "default"
|
|
||||||
bindsym Escape mode "default"
|
|
||||||
bindsym $sup+r mode "default"
|
|
||||||
}
|
|
||||||
|
|
||||||
bindsym $sup+r mode "resize"
|
|
||||||
|
|
||||||
input "1102:4629:ALP0016:00_044E:1215" {
|
|
||||||
tap enabled
|
|
||||||
natural_scroll enabled
|
|
||||||
}
|
|
||||||
|
|
||||||
bar {
|
|
||||||
position top
|
|
||||||
|
|
||||||
# When the status_command prints a new line to stdout, swaybar updates.
|
|
||||||
# The default just shows the current date and time.
|
|
||||||
status_command while ~/.config/sway/status.sh; do printf ''; done
|
|
||||||
|
|
||||||
colors {
|
|
||||||
statusline #ffffff
|
|
||||||
background #323232
|
|
||||||
inactive_workspace #32323200 #32323200 #5c5c5c
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,25 +0,0 @@
|
||||||
import socket
|
|
||||||
from datetime import datetime
|
|
||||||
from psutil import disk_usage, sensors_battery
|
|
||||||
from psutil._common import bytes2human
|
|
||||||
import socket
|
|
||||||
from subprocess import check_output
|
|
||||||
from sys import stdout
|
|
||||||
from time import sleep
|
|
||||||
|
|
||||||
def write(data):
|
|
||||||
stdout.write('%s\n' % data)
|
|
||||||
stdout.flush()
|
|
||||||
|
|
||||||
def refresh():
|
|
||||||
disk = f"{bytes2human(disk_usage('/').used)} / {bytes2human(disk_usage('/').total)} ({bytes2human(disk_usage('/').free)})"
|
|
||||||
hostname = socket.gethostname()
|
|
||||||
ip = socket.gethostbyname(hostname+".")
|
|
||||||
battery = int(sensors_battery().percent)
|
|
||||||
status = "Charging" if sensors_battery().power_plugged else "Discharging"
|
|
||||||
date = datetime.now().strftime('%h %d %A %H:%M:%S')
|
|
||||||
write(f"d: {disk} | n: {hostname} @ {ip} | b: {battery}% ({status.lower()[:3]}) | {date}")
|
|
||||||
|
|
||||||
while True:
|
|
||||||
refresh()
|
|
||||||
sleep(1)
|
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
uptimef=$(uptime | cut -d ',' -f1 | cut -d ' ' -f4,5)
|
|
||||||
datef=$(date "+%a %F %H:%M:%S")
|
|
||||||
linux_version=$(uname -r | cut -d '-' -f1)
|
|
||||||
battery_status=$(cat /sys/class/power_supply/BAT0/status)
|
|
||||||
battery_percent=$(cat /sys/class/power_supply/BAT0/capacity)
|
|
||||||
#audio_volume=$(awk -F"[][]" '/Left:/ { print $2 }' <(amixer sget Master))
|
|
||||||
audio_volume=$(pamixer --get-volume)%
|
|
||||||
disk_usage=$(df -kh / | grep dev | awk '{print $5}')
|
|
||||||
mem_used=$(free | awk '/Mem/{printf("%.2f%"), $3/$2*100}')
|
|
||||||
local_ip=$(ip addr show wlp58s0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
|
|
||||||
|
|
||||||
# 💎 💻 💡 🔌 ⚡ 📁 \|
|
|
||||||
printf "📁 %3s | 💎 %7s | 💻 %s | 📶 %s | 🐧 %7s | 🔋 %7s | 🔉 %4s | %s\n" \
|
|
||||||
"$disk_usage" "$mem_used" "$uptimef" "$local_ip" "$linux_version" "$battery_percent% ($battery_status)" "$audio_volume" "$datef"
|
|
||||||
sleep 1
|
|
|
@ -1,2 +0,0 @@
|
||||||
_ZSH_PREF_NO_PFETCH=0
|
|
||||||
_ZSH_PREF_NO_NONSENSE=0
|
|
|
@ -1,49 +0,0 @@
|
||||||
__is_arch() {
|
|
||||||
. /etc/os-release
|
|
||||||
if [ "$ID" = "arch" ]; then return 0; else return 1; fi
|
|
||||||
}
|
|
||||||
|
|
||||||
pkg_once() {
|
|
||||||
if [ ! __is_arch ]; then
|
|
||||||
printf "This command is only for Arch Linux.\n"
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
if [ ! -n "$1" ]; then
|
|
||||||
printf "Usage: pkg_once <PACKAGE_NAME> [command]\n"
|
|
||||||
printf "command is optional; if there is no command the package name is ran\n"
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
printf "Installing $1...\n"
|
|
||||||
yay -S --noconfirm $1 > /dev/null
|
|
||||||
|
|
||||||
if [ ! -n "$2" ]; then $1; else $2; fi
|
|
||||||
printf "Remoiving $1..."
|
|
||||||
yay -R --noconfirm $1 > /dev/null
|
|
||||||
echo "done.\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
rando () {
|
|
||||||
case $1 in
|
|
||||||
*|d|default) tr -dc A-Za-z0-9 </dev/urandom | head -c $2 ; echo '' ;;
|
|
||||||
s|special) tr -dc 'A-Za-z0-9!"#$%&'\''()*+,-./:;<=>?@[\]^_`{|}~' </dev/urandom | head -c $2 ; echo ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
touchx () {
|
|
||||||
case $1 in
|
|
||||||
--shebang) content="#!/bin/sh"; file=$2 ;;
|
|
||||||
*) file=$1 ;;
|
|
||||||
esac
|
|
||||||
if [ -s $file ]; then
|
|
||||||
printf 'file exists'
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
touch $file
|
|
||||||
if [ -n "$content" ]; then
|
|
||||||
printf '%s\n' $content >> $file
|
|
||||||
fi
|
|
||||||
chmod +x $file
|
|
||||||
printf '%s' $file
|
|
||||||
}
|
|
||||||
|
|
||||||
alias docurr="docker run -itd --rm --name current"
|
|
|
@ -1,100 +0,0 @@
|
||||||
#
|
|
||||||
# /etc/pacman.conf
|
|
||||||
#
|
|
||||||
# See the pacman.conf(5) manpage for option and repository directives
|
|
||||||
|
|
||||||
#
|
|
||||||
# GENERAL OPTIONS
|
|
||||||
#
|
|
||||||
[options]
|
|
||||||
# The following paths are commented out with their default values listed.
|
|
||||||
# If you wish to use different paths, uncomment and update the paths.
|
|
||||||
#RootDir = /
|
|
||||||
#DBPath = /var/lib/pacman/
|
|
||||||
#CacheDir = /var/cache/pacman/pkg/
|
|
||||||
#LogFile = /var/log/pacman.log
|
|
||||||
#GPGDir = /etc/pacman.d/gnupg/
|
|
||||||
#HookDir = /etc/pacman.d/hooks/
|
|
||||||
HoldPkg = pacman glibc
|
|
||||||
#XferCommand = /usr/bin/curl -L -C - -f -o %o %u
|
|
||||||
#XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u
|
|
||||||
#CleanMethod = KeepInstalled
|
|
||||||
Architecture = auto
|
|
||||||
|
|
||||||
# Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup
|
|
||||||
#IgnorePkg =
|
|
||||||
#IgnoreGroup =
|
|
||||||
|
|
||||||
#NoUpgrade =
|
|
||||||
#NoExtract =
|
|
||||||
|
|
||||||
# Misc options
|
|
||||||
#UseSyslog
|
|
||||||
#Color
|
|
||||||
#NoProgressBar
|
|
||||||
CheckSpace
|
|
||||||
#VerbosePkgLists
|
|
||||||
ParallelDownloads = 5
|
|
||||||
|
|
||||||
# By default, pacman accepts packages signed by keys that its local keyring
|
|
||||||
# trusts (see pacman-key and its man page), as well as unsigned packages.
|
|
||||||
SigLevel = Required DatabaseOptional
|
|
||||||
LocalFileSigLevel = Optional
|
|
||||||
#RemoteFileSigLevel = Required
|
|
||||||
|
|
||||||
# NOTE: You must run `pacman-key --init` before first using pacman; the local
|
|
||||||
# keyring can then be populated with the keys of all official Arch Linux
|
|
||||||
# packagers with `pacman-key --populate archlinux`.
|
|
||||||
|
|
||||||
#
|
|
||||||
# REPOSITORIES
|
|
||||||
# - can be defined here or included from another file
|
|
||||||
# - pacman will search repositories in the order defined here
|
|
||||||
# - local/custom mirrors can be added here or in separate files
|
|
||||||
# - repositories listed first will take precedence when packages
|
|
||||||
# have identical names, regardless of version number
|
|
||||||
# - URLs will have $repo replaced by the name of the current repo
|
|
||||||
# - URLs will have $arch replaced by the name of the architecture
|
|
||||||
#
|
|
||||||
# Repository entries are of the format:
|
|
||||||
# [repo-name]
|
|
||||||
# Server = ServerName
|
|
||||||
# Include = IncludePath
|
|
||||||
#
|
|
||||||
# The header [repo-name] is crucial - it must be present and
|
|
||||||
# uncommented to enable the repo.
|
|
||||||
#
|
|
||||||
|
|
||||||
# The testing repositories are disabled by default. To enable, uncomment the
|
|
||||||
# repo name header and Include lines. You can add preferred servers immediately
|
|
||||||
# after the header, and they will be used before the default mirrors.
|
|
||||||
|
|
||||||
#[testing]
|
|
||||||
#Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
[core]
|
|
||||||
Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
[extra]
|
|
||||||
Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
#[community-testing]
|
|
||||||
#Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
[community]
|
|
||||||
Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
# If you want to run 32 bit applications on your x86_64 system,
|
|
||||||
# enable the multilib repositories as required here.
|
|
||||||
|
|
||||||
#[multilib-testing]
|
|
||||||
#Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
[multilib]
|
|
||||||
Include = /etc/pacman.d/mirrorlist
|
|
||||||
|
|
||||||
# An example of a custom package repository. See the pacman manpage for
|
|
||||||
# tips on creating your own repositories.
|
|
||||||
#[custom]
|
|
||||||
#SigLevel = Optional TrustAll
|
|
||||||
#Server = file:///home/custompkgs
|
|
|
@ -1,11 +0,0 @@
|
||||||
# Mirrorlist for NL setup
|
|
||||||
|
|
||||||
# Private mirror
|
|
||||||
Server = https://arch.neo.faulty.nl/$repo/os/$arch
|
|
||||||
|
|
||||||
# Public mirrors
|
|
||||||
Server = http://mirror.mikrogravitation.org/archlinux/$repo/os/$arch
|
|
||||||
Server = http://mirror.wtnet.de/archlinux/$repo/os/$arch
|
|
||||||
Server = http://mirror.pagenotfound.de/archlinux/$repo/os/$arch
|
|
||||||
Server = http://mirror.informatik.tu-freiberg.de/arch/$repo/os/$arch
|
|
||||||
Server = http://ftp.snt.utwente.nl/pub/os/linux/archlinux/$repo/os/$arch
|
|
|
@ -1,3 +0,0 @@
|
||||||
alacritty
|
|
||||||
sway
|
|
||||||
kanshi
|
|
15
hop.sh
15
hop.sh
|
@ -1,15 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# need to hop? this script copies the important stuff.
|
|
||||||
|
|
||||||
tar \
|
|
||||||
--exclude={node_modules,target,dist,cache} \
|
|
||||||
-cvf \
|
|
||||||
${TAR_FILE:-backup.tar} \
|
|
||||||
~/.ssh \
|
|
||||||
~/.config \
|
|
||||||
~/.mozilla \
|
|
||||||
~/Documents \
|
|
||||||
~/Pictures \
|
|
||||||
~/code \
|
|
||||||
~/environments
|
|
|
@ -1,4 +0,0 @@
|
||||||
curl
|
|
||||||
vim
|
|
||||||
zsh
|
|
||||||
docker
|
|
|
@ -1,6 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# This file only installs what is needed for the sync to perform...
|
|
||||||
|
|
||||||
$SUDO $PM $PM_INSTALL $PM_NOCONFIRM \
|
|
||||||
rsync
|
|
|
@ -1,32 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
$SUDO $PM $PM_INSTALL $PM_NOCONFIRM \
|
|
||||||
zsh \
|
|
||||||
cmake # for fastfetch
|
|
||||||
|
|
||||||
# install fastfetch
|
|
||||||
[ -d /tmp/fastfetch ] || \
|
|
||||||
git clone https://github.com/LinusDierheimer/fastfetch /tmp/fastfetch
|
|
||||||
|
|
||||||
if [ ! -f /tmp/fastfetch/build/fastfetch ]; then
|
|
||||||
pushd /tmp/fastfetch
|
|
||||||
mkdir -p build
|
|
||||||
pushd build
|
|
||||||
cmake ..
|
|
||||||
cmake --build . --target fastfetch
|
|
||||||
$SUDO mv fastfetch /usr/local/bin/fastfetch
|
|
||||||
popd
|
|
||||||
popd
|
|
||||||
fi
|
|
||||||
|
|
||||||
# install omz
|
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" "" --unattended || echo "zsh not installed"
|
|
||||||
|
|
||||||
# favourite omz plugins
|
|
||||||
PL_DIR=${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestions
|
|
||||||
[ -d "$PL_DIR" ] || git clone https://github.com/zsh-users/zsh-autosuggestions $PL_DIR
|
|
||||||
PL_DIR=${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting
|
|
||||||
[ -d "$PL_DIR" ] || git clone https://github.com/zsh-users/zsh-syntax-highlighting.git $PL_DIR
|
|
||||||
|
|
||||||
# set default shell
|
|
||||||
$SUDO usermod $USER --shell /bin/zsh
|
|
|
@ -1,8 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
HOME_FILES=${HOME_FILES:-./files/home}
|
|
||||||
ROOT_FILES=${ROOT_FILES:-./files/root}
|
|
||||||
|
|
||||||
# overwrite files but preserve files surrounding
|
|
||||||
rsync -av $HOME_FILES/ $HOME
|
|
||||||
$SUDO rsync -av $ROOT_FILES/ /
|
|
|
@ -1,23 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
PACKAGE_LIST=${PACKAGE_LIST:-./package.list}
|
|
||||||
GRAPHICAL_PACKAGE_LIST=${GRAPHICAL_PACKAGE_LIST:-./gpackage.list}
|
|
||||||
|
|
||||||
_APPLICATIONS=""
|
|
||||||
while read -r pkg; do
|
|
||||||
[ -z "$pkg" ] && continue
|
|
||||||
[ "$(echo "$pkg" | cut -c1)" = "#" ] && continue
|
|
||||||
_APPLICATIONS="$_APPLICATIONS $pkg"
|
|
||||||
done < "$PACKAGE_LIST"
|
|
||||||
|
|
||||||
if [ "${NO_GRAPHICS:-no}" = "no" ]; then
|
|
||||||
if [ -f "$GRAPHICAL_PACKAGE_LIST" ]; then
|
|
||||||
while read -r pkg; do
|
|
||||||
[ -z "$pkg" ] && continue
|
|
||||||
[ "$(echo "$pkg" | cut -c1)" = "#" ] && continue
|
|
||||||
_APPLICATIONS="$_APPLICATIONS $pkg"
|
|
||||||
done < "$GRAPHICAL_PACKAGE_LIST"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
$SUDO $PM $PM_INSTALL $PM_NOCONFIRM $_APPLICATIONS
|
|
|
@ -1,49 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# This file configures builds and installs DWM.
|
|
||||||
|
|
||||||
[ "${NO_GRAPHICS:-no}" = "yes" ] && return 0
|
|
||||||
|
|
||||||
# install dependencies
|
|
||||||
$SUDO $PM $PM_INSTALL $PM_NOCONFIRM \
|
|
||||||
feh \
|
|
||||||
network-manager-applet \
|
|
||||||
alsa-utils \
|
|
||||||
dstat \
|
|
||||||
curl \
|
|
||||||
flameshot \
|
|
||||||
dmenu \
|
|
||||||
i3lock
|
|
||||||
|
|
||||||
# clone
|
|
||||||
[ -d /tmp/dotfiles-dwm ] || git clone https://git.suckless.org/dwm /tmp/dotfiles-dwm
|
|
||||||
|
|
||||||
# config
|
|
||||||
cp ./files/dwm/config.h /tmp/dotfiles-dwm/config.h
|
|
||||||
|
|
||||||
# build, patch and install
|
|
||||||
pushd /tmp/dotfiles-dwm
|
|
||||||
|
|
||||||
# patches
|
|
||||||
curl https://dwm.suckless.org/patches/systray/dwm-systray-6.4.diff -o /tmp/dwm-systray.diff
|
|
||||||
git apply -3 /tmp/dwm-systray.diff
|
|
||||||
|
|
||||||
$SUDO make install
|
|
||||||
popd
|
|
||||||
|
|
||||||
# dwm boot/manage scripts
|
|
||||||
chmod +x ./files/dwm/*.sh
|
|
||||||
|
|
||||||
$SUDO cp ./files/dwm/dwm-start.sh /usr/local/bin/dwm-start
|
|
||||||
$SUDO cp ./files/dwm/dwm-status.sh /usr/local/bin/dwm-status
|
|
||||||
$SUDO cp ./files/dwm/dwm-sync.sh /usr/local/bin/dwm-sync
|
|
||||||
$SUDO cp ./files/dwm/dwm-lock.sh /usr/local/bin/dwm-lock
|
|
||||||
|
|
||||||
$SUDO chmod +x /usr/local/bin/dwm-*
|
|
||||||
|
|
||||||
# DM entry
|
|
||||||
$SUDO cp ./files/dwm/dwm.desktop /usr/share/xsessions/dwm.desktop
|
|
||||||
|
|
||||||
# background
|
|
||||||
rm -rf $HOME/Pictures/background.*
|
|
||||||
curl https://images-wixmp-ed30a86b8c4ca887773594c2.wixmp.com/i/9757d496-239b-46c5-baea-6873cbfe9b3d/ddkbeml-015b05e6-6f8f-471e-a3a4-1c4360127ea6.jpg -o $HOME/Pictures/background.jpg
|
|
24
sync.sh
24
sync.sh
|
@ -1,24 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
SUDO=${SUDO:-sudo}
|
|
||||||
|
|
||||||
PM=${PM:-pacman}
|
|
||||||
PM_INSTALL=${PM_INSTALL:--S}
|
|
||||||
PM_NOCONFIRM=${PM_NOCONFIRM:---noconfirm}
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
main() {
|
|
||||||
if [ ! -z "$@" ]; then
|
|
||||||
. ./scripts/$@
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
for script in ./scripts/* ; do
|
|
||||||
echo "# exec $script"
|
|
||||||
. $script
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
main "$@"
|
|
||||||
|
|
||||||
echo "# OK"
|
|
Loading…
Reference in a new issue