Compare commits
5 Commits
545db10376
...
88276e4050
| Author | SHA1 | Date |
|---|---|---|
|
|
88276e4050 | 2 years ago |
|
|
1887345eab | 2 years ago |
|
|
31da710a57 | 2 years ago |
|
|
7bcd2f471b | 3 years ago |
|
|
76fb435bce | 3 years ago |
9 changed files with 547 additions and 2 deletions
@ -0,0 +1,215 @@ |
|||||
|
#!/usr/bin/env bash |
||||
|
|
||||
|
# this is a simple config for herbstluftwm |
||||
|
|
||||
|
hc() { |
||||
|
herbstclient "$@" |
||||
|
} |
||||
|
|
||||
|
hc emit_hook reload |
||||
|
|
||||
|
xsetroot -solid '#5A8E3A' |
||||
|
|
||||
|
# remove all existing keybindings |
||||
|
hc keyunbind --all |
||||
|
|
||||
|
# keybindings |
||||
|
# if you have a super key you will be much happier with Mod set to Mod4 |
||||
|
#Mod=Mod1 # Use alt as the main modifier |
||||
|
Mod=Mod4 # Use the super key as the main modifier |
||||
|
|
||||
|
hc keybind $Mod-Shift-q close |
||||
|
hc keybind $Mod-Shift-e quit |
||||
|
hc keybind $Mod-Shift-r reload |
||||
|
hc keybind $Mod-Shift-c close |
||||
|
hc keybind $Mod-Return spawn "alacritty" # use your $TERMINAL with xterm as fallback |
||||
|
|
||||
|
# basic movement in tiling and floating mode |
||||
|
# focusing clients |
||||
|
hc keybind $Mod-Left focus left |
||||
|
hc keybind $Mod-Down focus down |
||||
|
hc keybind $Mod-Up focus up |
||||
|
hc keybind $Mod-Right focus right |
||||
|
hc keybind $Mod-h focus left |
||||
|
hc keybind $Mod-j focus down |
||||
|
hc keybind $Mod-k focus up |
||||
|
hc keybind $Mod-l focus right |
||||
|
|
||||
|
# moving clients in tiling and floating mode |
||||
|
hc keybind $Mod-Shift-Left shift left |
||||
|
hc keybind $Mod-Shift-Down shift down |
||||
|
hc keybind $Mod-Shift-Up shift up |
||||
|
hc keybind $Mod-Shift-Right shift right |
||||
|
hc keybind $Mod-Shift-h shift left |
||||
|
hc keybind $Mod-Shift-j shift down |
||||
|
hc keybind $Mod-Shift-k shift up |
||||
|
hc keybind $Mod-Shift-l shift right |
||||
|
|
||||
|
# splitting frames |
||||
|
# create an empty frame at the specified direction |
||||
|
hc keybind $Mod-u split bottom 0.5 |
||||
|
hc keybind $Mod-o split right 0.5 |
||||
|
# let the current frame explode into subframes |
||||
|
hc keybind $Mod-Control-space split explode |
||||
|
|
||||
|
# resizing frames and floating clients |
||||
|
resizestep=0.02 |
||||
|
hc keybind $Mod-Control-h resize left +$resizestep |
||||
|
hc keybind $Mod-Control-j resize down +$resizestep |
||||
|
hc keybind $Mod-Control-k resize up +$resizestep |
||||
|
hc keybind $Mod-Control-l resize right +$resizestep |
||||
|
hc keybind $Mod-Control-Left resize left +$resizestep |
||||
|
hc keybind $Mod-Control-Down resize down +$resizestep |
||||
|
hc keybind $Mod-Control-Up resize up +$resizestep |
||||
|
hc keybind $Mod-Control-Right resize right +$resizestep |
||||
|
|
||||
|
# tags |
||||
|
tag_names=( {1..9} ) |
||||
|
tag_keys=( {1..9} 0 ) |
||||
|
|
||||
|
hc rename default "${tag_names[0]}" || true |
||||
|
for i in "${!tag_names[@]}" ; do |
||||
|
hc add "${tag_names[$i]}" |
||||
|
key="${tag_keys[$i]}" |
||||
|
if [ -n "$key" ] ; then |
||||
|
hc keybind "$Mod-$key" use_index "$i" |
||||
|
hc keybind "$Mod-Shift-$key" move_index "$i" |
||||
|
fi |
||||
|
done |
||||
|
|
||||
|
# cycle through tags |
||||
|
hc keybind $Mod-period use_index +1 --skip-visible |
||||
|
hc keybind $Mod-comma use_index -1 --skip-visible |
||||
|
|
||||
|
# layouting |
||||
|
hc keybind $Mod-e rotate |
||||
|
hc keybind $Mod-r remove |
||||
|
hc keybind $Mod-s floating toggle |
||||
|
hc keybind $Mod-f fullscreen toggle |
||||
|
hc keybind $Mod-Shift-f set_attr clients.focus.floating toggle |
||||
|
hc keybind $Mod-Shift-d set_attr clients.focus.decorated toggle |
||||
|
hc keybind $Mod-Shift-m set_attr clients.focus.minimized true |
||||
|
hc keybind $Mod-Control-m jumpto last-minimized |
||||
|
hc keybind $Mod-p pseudotile toggle |
||||
|
# The following cycles through the available layouts within a frame, but skips |
||||
|
# layouts, if the layout change wouldn't affect the actual window positions. |
||||
|
# I.e. if there are two windows within a frame, the grid layout is skipped. |
||||
|
hc keybind $Mod-space \ |
||||
|
or , and . compare tags.focus.curframe_wcount = 2 \ |
||||
|
. cycle_layout +1 vertical horizontal max vertical grid \ |
||||
|
, cycle_layout +1 |
||||
|
|
||||
|
# mouseover |
||||
|
hc mouseunbind --all |
||||
|
hc mousebind $Mod-Button1 move |
||||
|
hc mousebind $Mod-Button2 zoom |
||||
|
hc mousebind $Mod-Button3 resize |
||||
|
|
||||
|
# focus |
||||
|
hc keybind $Mod-BackSpace cycle_monitor |
||||
|
hc keybind $Mod-Tab cycle_all +1 |
||||
|
hc keybind $Mod-Shift-Tab cycle_all -1 |
||||
|
hc keybind $Mod-c cycle |
||||
|
hc keybind $Mod-i jumpto urgent |
||||
|
|
||||
|
# theme |
||||
|
hc attr theme.tiling.reset 1 |
||||
|
hc attr theme.floating.reset 1 |
||||
|
hc set frame_border_active_color '#222222cc' |
||||
|
hc set frame_border_normal_color '#101010cc' |
||||
|
hc set frame_bg_normal_color '#565656aa' |
||||
|
hc set frame_bg_active_color '#345F0Caa' |
||||
|
hc set frame_border_width 1 |
||||
|
hc set always_show_frame on |
||||
|
hc set frame_bg_transparent on |
||||
|
hc set frame_transparent_width 5 |
||||
|
hc set frame_gap 4 |
||||
|
|
||||
|
hc attr theme.title_height 15 |
||||
|
hc attr theme.title_when always |
||||
|
hc attr theme.title_font 'Dejavu Sans:pixelsize=12' # example using Xft |
||||
|
# hc attr theme.title_font '-*-fixed-medium-r-*-*-13-*-*-*-*-*-*-*' |
||||
|
hc attr theme.title_depth 3 # space below the title's baseline |
||||
|
hc attr theme.active.color '#345F0Cef' |
||||
|
hc attr theme.title_color '#ffffff' |
||||
|
hc attr theme.normal.color '#323232dd' |
||||
|
hc attr theme.urgent.color '#7811A1dd' |
||||
|
hc attr theme.tab_color '#1F1F1Fdd' |
||||
|
hc attr theme.active.tab_color '#2B4F0Add' |
||||
|
hc attr theme.active.tab_outer_color '#6C8257dd' |
||||
|
hc attr theme.active.tab_title_color '#ababab' |
||||
|
hc attr theme.normal.title_color '#898989' |
||||
|
hc attr theme.inner_width 1 |
||||
|
hc attr theme.inner_color black |
||||
|
hc attr theme.border_width 3 |
||||
|
hc attr theme.floating.border_width 4 |
||||
|
hc attr theme.floating.outer_width 1 |
||||
|
hc attr theme.floating.outer_color black |
||||
|
hc attr theme.active.inner_color '#789161' |
||||
|
hc attr theme.urgent.inner_color '#9A65B0' |
||||
|
hc attr theme.normal.inner_color '#606060' |
||||
|
# copy inner color to outer_color |
||||
|
for state in active urgent normal ; do |
||||
|
hc substitute C theme.${state}.inner_color \ |
||||
|
attr theme.${state}.outer_color C |
||||
|
done |
||||
|
hc attr theme.tiling.outer_width 1 |
||||
|
hc attr theme.background_color '#141414' |
||||
|
|
||||
|
hc set window_gap 0 |
||||
|
hc set frame_padding 0 |
||||
|
hc set smart_window_surroundings off |
||||
|
hc set smart_frame_surroundings on |
||||
|
hc set mouse_recenter_gap 0 |
||||
|
|
||||
|
# rules |
||||
|
hc unrule -F |
||||
|
#hc rule class=XTerm tag=3 # move all xterms to tag 3 |
||||
|
hc rule focus=on # normally focus new clients |
||||
|
hc rule floatplacement=smart |
||||
|
#hc rule focus=off # normally do not focus new clients |
||||
|
# give focus to most common terminals |
||||
|
#hc rule class~'(.*[Rr]xvt.*|.*[Tt]erm|Konsole)' focus=on |
||||
|
hc rule windowtype~'_NET_WM_WINDOW_TYPE_(DIALOG|UTILITY|SPLASH)' floating=on |
||||
|
hc rule windowtype='_NET_WM_WINDOW_TYPE_DIALOG' focus=on |
||||
|
hc rule windowtype~'_NET_WM_WINDOW_TYPE_(NOTIFICATION|DOCK|DESKTOP)' manage=off |
||||
|
hc rule fixedsize floating=on |
||||
|
|
||||
|
hc rule class=Steam tag=8 |
||||
|
hc rule class=Lutris tag=8 |
||||
|
hc rule class=Signal tag=9 |
||||
|
hc rule class=thunderbird tag=9 |
||||
|
|
||||
|
hc set tree_style '╾│ ├└╼─┐' |
||||
|
|
||||
|
# unlock, just to be sure |
||||
|
hc unlock |
||||
|
|
||||
|
# do multi monitor setup here, e.g.: |
||||
|
# hc set_monitors 1280x1024+0+0 1280x1024+1280+0 |
||||
|
# or simply: |
||||
|
# hc detect_monitors |
||||
|
|
||||
|
# find the panel |
||||
|
panel=~/.config/herbstluftwm/panel.sh |
||||
|
[ -x "$panel" ] || panel=/etc/xdg/herbstluftwm/panel.sh |
||||
|
for monitor in $(hc list_monitors | cut -d: -f1) ; do |
||||
|
# start it on each monitor |
||||
|
"$panel" "$monitor" & |
||||
|
done |
||||
|
|
||||
|
hc keybind $Mod-d spawn ~/.config/polybar/scripts/launcher.sh |
||||
|
|
||||
|
hc keybind $Mod-minus spawn ~/.config/herbstluftwm/scripts/scratchpad.sh "hlwmScratch1" "st -n hlwmScratch1" |
||||
|
hc keybind $Mod-Alt-minus spawn ~/.config/herbstluftwm/scripts/scratchpad.sh "hlwmScratch2" "st -n hlwmScratch2" |
||||
|
# put this somewhere after 'hc unrule -F' line |
||||
|
hc rule instance~hlwmScratch.* floating=on floatplacement=center # float all instances which contains 'hlwmScratch' |
||||
|
|
||||
|
# screenshot |
||||
|
hc keybind Release-$Mod-Shift-p spawn scrot |
||||
|
|
||||
|
# autostart |
||||
|
hc spawn flameshot |
||||
|
hc spawn redshift-gtk |
||||
|
|
||||
|
~/.config/polybar/launch.sh |
||||
@ -0,0 +1,63 @@ |
|||||
|
#!/usr/bin/env bash |
||||
|
|
||||
|
# a i3-like scratchpad for arbitrary applications. |
||||
|
# |
||||
|
# this lets a new monitor called "scratchpad" appear in from the top into the |
||||
|
# current monitor. There the "scratchpad" will be shown (it will be created if |
||||
|
# it doesn't exist yet). If the monitor already exists it is scrolled out of |
||||
|
# the screen and removed again. |
||||
|
# |
||||
|
# Warning: this uses much resources because herbstclient is forked for each |
||||
|
# animation step. |
||||
|
# |
||||
|
# If a tag name is supplied, this is used instead of the scratchpad |
||||
|
|
||||
|
tag="${1:-scratchpad}" |
||||
|
hc() { "${herbstclient_command[@]:-herbstclient}" "$@" ;} |
||||
|
|
||||
|
mrect=( $(hc monitor_rect "" ) ) |
||||
|
|
||||
|
width=${mrect[2]} |
||||
|
height=${mrect[3]} |
||||
|
|
||||
|
rect=( |
||||
|
$((width/2)) |
||||
|
$((height/2)) |
||||
|
$((${mrect[0]}+(width/4))) |
||||
|
$((${mrect[1]}+(height/4))) |
||||
|
) |
||||
|
|
||||
|
hc chain , add "$tag" , set_attr tags.by-name."$tag".at_end true |
||||
|
|
||||
|
monitor=scratchpad |
||||
|
|
||||
|
exists=false |
||||
|
if ! hc add_monitor $(printf "%dx%d%+d%+d" "${rect[@]}") \ |
||||
|
"$tag" $monitor 2> /dev/null ; then |
||||
|
exists=true |
||||
|
else |
||||
|
# remember which monitor was focused previously |
||||
|
hc chain \ |
||||
|
, new_attr string monitors.by-name."$monitor".my_prev_focus \ |
||||
|
, substitute M monitors.focus.index \ |
||||
|
set_attr monitors.by-name."$monitor".my_prev_focus M |
||||
|
fi |
||||
|
|
||||
|
show() { |
||||
|
hc lock |
||||
|
hc raise_monitor "$monitor" |
||||
|
hc focus_monitor "$monitor" |
||||
|
hc unlock |
||||
|
hc lock_tag "$monitor" |
||||
|
} |
||||
|
|
||||
|
hide() { |
||||
|
# if q3terminal still is focused, then focus the previously focused monitor |
||||
|
# (that mon which was focused when starting q3terminal) |
||||
|
hc substitute M monitors.by-name."$monitor".my_prev_focus \ |
||||
|
and + compare monitors.focus.name = "$monitor" \ |
||||
|
+ focus_monitor M |
||||
|
hc remove_monitor "$monitor" |
||||
|
} |
||||
|
|
||||
|
[ $exists = true ] && hide || show |
||||
@ -0,0 +1,46 @@ |
|||||
|
#!/usr/bin/env bash |
||||
|
set -e |
||||
|
# |
||||
|
# dependencies: |
||||
|
# |
||||
|
# - rofi |
||||
|
|
||||
|
# offer a window menu offering possible actions on that window like |
||||
|
# moving to a different tag or toggling its fullscreen state |
||||
|
|
||||
|
action_list() { |
||||
|
local a="$1" |
||||
|
"$a" "Close" herbstclient close |
||||
|
"$a" "Toggle fullscreen" herbstclient fullscreen toggle |
||||
|
"$a" "Toggle pseudotile" herbstclient pseudotile toggle |
||||
|
for tag in $(herbstclient complete 1 move) ; do |
||||
|
"$a" "Move to tag $tag" herbstclient move "$tag" |
||||
|
done |
||||
|
} |
||||
|
|
||||
|
print_menu() { |
||||
|
echo "$1" |
||||
|
} |
||||
|
|
||||
|
title=$(herbstclient attr clients.focus.title) |
||||
|
title=${title//&/&} |
||||
|
rofiflags=( |
||||
|
-p "herbstclient:" |
||||
|
-mesg "<i>$title</i>" |
||||
|
-columns 3 |
||||
|
-location 2 |
||||
|
-width 100 |
||||
|
-no-custom |
||||
|
) |
||||
|
result=$(action_list print_menu | rofi -i -dmenu -m -2 "${rofiflags[@]}") |
||||
|
[ $? -ne 0 ] && exit 0 |
||||
|
|
||||
|
exec_entry() { |
||||
|
if [ "$1" = "$result" ] ; then |
||||
|
shift |
||||
|
"$@" |
||||
|
exit 0 |
||||
|
fi |
||||
|
} |
||||
|
|
||||
|
action_list exec_entry |
||||
@ -0,0 +1,54 @@ |
|||||
|
-- Flatten allows you to open files from a neovim terminal buffer in your current neovim instance instead of a nested one:w |
||||
|
return { |
||||
|
'willothy/flatten.nvim', |
||||
|
opts = { |
||||
|
window = { open = 'alternate' }, |
||||
|
callbacks = { |
||||
|
should_block = function(argv) |
||||
|
-- Note that argv contains all the parts of the CLI command, including |
||||
|
-- Neovim's path, commands, options and files. |
||||
|
-- See: :help v:argv |
||||
|
|
||||
|
-- In this case, we would block if we find the `-b` flag |
||||
|
-- This allows you to use `nvim -b file1` instead of `nvim --cmd 'let g:flatten_wait=1' file1` |
||||
|
return vim.tbl_contains(argv, "-b") |
||||
|
|
||||
|
-- Alternatively, we can block if we find the diff-mode option |
||||
|
-- return vim.tbl_contains(argv, "-d") |
||||
|
end, |
||||
|
post_open = function(_bufnr, winnr, _ft, is_blocking) |
||||
|
if is_blocking then |
||||
|
require('toggleterm').toggle(0) |
||||
|
else |
||||
|
vim.api.nvim_set_current_win(winnr) |
||||
|
end |
||||
|
|
||||
|
-- If the file is a git commit, create one-shot autocmd to delete its buffer on write |
||||
|
-- If you just want the toggleable terminal integration, ignore this bit |
||||
|
if ft == "gitcommit" then |
||||
|
vim.api.nvim_create_autocmd( |
||||
|
"BufWritePost", |
||||
|
{ |
||||
|
buffer = bufnr, |
||||
|
once = true, |
||||
|
callback = function() |
||||
|
-- This is a bit of a hack, but if you run bufdelete immediately |
||||
|
-- the shell can occasionally freeze |
||||
|
vim.defer_fn( |
||||
|
function() |
||||
|
vim.api.nvim_buf_delete(bufnr, {}) |
||||
|
end, |
||||
|
50 |
||||
|
) |
||||
|
end |
||||
|
} |
||||
|
) |
||||
|
end |
||||
|
end, |
||||
|
block_end = function() |
||||
|
-- After blocking ends (for a git commit, etc), reopen the terminal |
||||
|
require("toggleterm").toggle(0) |
||||
|
end |
||||
|
}, |
||||
|
}, |
||||
|
} |
||||
@ -0,0 +1,45 @@ |
|||||
|
return { |
||||
|
'akinsho/toggleterm.nvim', |
||||
|
version = "*", |
||||
|
lazy = false, |
||||
|
priority = 1001, |
||||
|
opts = { |
||||
|
open_mapping = [[<c-\>]], |
||||
|
direction = 'float', |
||||
|
shade_terminals = true, |
||||
|
float_opts = { |
||||
|
border = "curved", |
||||
|
} |
||||
|
}, |
||||
|
keys = { |
||||
|
{ "<esc>", [[<c-\><c-n>]], mode = 't', desc = "Enter free movement" }, |
||||
|
--{ "jk", [[<C-\><C-n>]], mode = 't', desc = "" }, |
||||
|
{ "<C-h>", [[<Cmd>wincmd h<CR>]], mode = 't', desc = "Leave"} , |
||||
|
{ "<C-j>", [[<Cmd>wincmd j<CR>]], mode = 't', desc = "Leave" }, |
||||
|
{ "<C-k>", [[<Cmd>wincmd k<CR>]], mode = 't', desc = "Leave" }, |
||||
|
{ "<C-l>", [[<Cmd>wincmd l<CR>]], mode = 't', desc = "Leave" }, |
||||
|
{ "<C-w>", [[<C-\><C-n><C-w>]], mode = 't', desc = "Leave" }, |
||||
|
}, |
||||
|
config = function(_, opts) |
||||
|
require('toggleterm').setup(opts) |
||||
|
-- |
||||
|
local Terminal = require('toggleterm.terminal').Terminal |
||||
|
|
||||
|
local htop = Terminal:new({ cmd = "htop", direction = "horizontal", hidden = true }) |
||||
|
function _htop_toggle() |
||||
|
htop:toggle() |
||||
|
end |
||||
|
|
||||
|
local lazygit = Terminal:new({ cmd = "lazygit", dir = "git_dir", hidden = true }) |
||||
|
function _lazygit_toggle() |
||||
|
lazygit:toggle() |
||||
|
end |
||||
|
|
||||
|
vim.api.nvim_set_keymap("n", "<leader>tf", "<cmd>ToggleTerm direction=float<CR>", { desc = "Toggle floating terminal", noremap = true, silent = true }) |
||||
|
vim.api.nvim_set_keymap("n", "<leader>th", "<cmd>ToggleTerm direction=horizontal size=10<CR>", { desc = "Toggle horizontal terminal", noremap = true, silent = true }) |
||||
|
vim.api.nvim_set_keymap("n", "<leader>tv", "<cmd>ToggleTerm direction=vertical size=80<CR>", { desc = "Toggle vertical terminal", noremap = true, silent = true }) |
||||
|
|
||||
|
vim.api.nvim_set_keymap("n", "<leader>tg", "<cmd>lua _lazygit_toggle()<CR>", {noremap = true, silent = true}) |
||||
|
vim.api.nvim_set_keymap("n", "<leader>tt", "<cmd>lua _htop_toggle()<CR>", {noremap = true, silent = true}) |
||||
|
end, |
||||
|
} |
||||
@ -0,0 +1,100 @@ |
|||||
|
{ config, pkgs, ... }: |
||||
|
|
||||
|
let |
||||
|
mkPersistentLink = path: pkgs.runCommand "persistent-link" {} '' |
||||
|
ln -s /home/pfke/.local/share/pfke/nix-config/${path} $out |
||||
|
''; |
||||
|
in { |
||||
|
imports = [ |
||||
|
./modules/cli/bat.nix |
||||
|
./modules/cli/fish.nix |
||||
|
./modules/keychain.nix |
||||
|
./modules/cli/starship.nix |
||||
|
]; |
||||
|
|
||||
|
home.file.".config/nvim".source = mkPersistentLink "dot_files/.config/nvim"; |
||||
|
# home.file.".config/nvim".onChange = "nvim --headless \"+Lazy! sync\" +qa"; |
||||
|
|
||||
|
# Home Manager needs a bit of information about you and the |
||||
|
# paths it should manage. |
||||
|
home.username = "pfke"; |
||||
|
home.homeDirectory = "/home/pfke"; |
||||
|
|
||||
|
fonts = { |
||||
|
fonts = with pkgs; [ |
||||
|
noto-fonts |
||||
|
noto-fonts-emoji |
||||
|
font-awesome |
||||
|
source-han-sans |
||||
|
(nerdfonts.override { fonts = [ "Meslo" ]}) |
||||
|
]; |
||||
|
fontconfig = { |
||||
|
enable = true; |
||||
|
defaultFonts = { |
||||
|
monospace = [ "Meslo LG M Regular Nerd Font Complete Mono" ]; |
||||
|
serif = [ "Noto Serif" "Source Han Serif" ]; |
||||
|
sansSerif = [ "Nono Sans" "Source Han Sans" ]; |
||||
|
}; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
# Packages that should be installed to the user profile. |
||||
|
home.packages = with pkgs; [ |
||||
|
(pkgs.nerdfonts.override { fonts = [ "FiraCode" "DroidSansMono" ]; }) |
||||
|
|
||||
|
exa |
||||
|
fasd |
||||
|
fd |
||||
|
htop |
||||
|
fortune |
||||
|
python3 |
||||
|
ranger |
||||
|
ripgrep |
||||
|
rsync |
||||
|
|
||||
|
clang |
||||
|
]; |
||||
|
|
||||
|
# This value determines the Home Manager release that your |
||||
|
# configuration is compatible with. This helps avoid breakage |
||||
|
# when a new Home Manager release introduces backwards |
||||
|
# incompatible changes. |
||||
|
# |
||||
|
# You can update Home Manager without changing this value. See |
||||
|
# the Home Manager release notes for a list of state version |
||||
|
# changes in each release. |
||||
|
home.stateVersion = "23.05"; |
||||
|
|
||||
|
# Let Home Manager install and manage itself. |
||||
|
programs.home-manager.enable = true; |
||||
|
|
||||
|
# git |
||||
|
programs.git = { |
||||
|
enable = true; |
||||
|
userName = "pfke"; |
||||
|
userEmail = "heiko.blobner@pfke.de"; |
||||
|
aliases = { |
||||
|
st = "status"; |
||||
|
}; |
||||
|
}; |
||||
|
|
||||
|
programs.neovim = { |
||||
|
enable = true; |
||||
|
vimAlias = true; |
||||
|
}; |
||||
|
|
||||
|
home.sessionPath = [ "/home/pfke/.gu/bin" ]; |
||||
|
home.sessionVariables = { |
||||
|
EDITOR = "nvim"; |
||||
|
PERL5LIB = "/home/pfke/.gu/lib/perl"; |
||||
|
GU_ENV = "1"; |
||||
|
MAKE_J_OPTION = "$(nproc)"; |
||||
|
MAKEFLAGS = "-j$(nproc)"; |
||||
|
}; |
||||
|
|
||||
|
services.gpg-agent = { |
||||
|
enable = true; |
||||
|
defaultCacheTtl = 1800; |
||||
|
enableSshSupport = true; |
||||
|
}; |
||||
|
} |
||||
Loading…
Reference in new issue