2 #+property: header-args :comments link :mkdirp yes :results silent
6 This org file contains the configuration files of pretty much every
7 program I use. The files are tangled (i.e. exported, or derived) from
8 this file using =org-babel=.
10 Note: This file is best viewed inside Emacs with org mode.
14 This section contains the configuration files (dotfiles) of various
21 :header-args+: :tangle ~/.config/bspwm/bspwmrc :shebang "#!/bin/sh"
24 #+begin_src sh :tangle no
29 sleep 0.5 && pasystray --notify=all &
31 bspc monitor -d I II III IV V VI VII VIII IX X
32 #bspc monitor eDP-1 -d I II III IV V
33 #bspc monitor HDMI-1 -d VI VII VIII IX X
35 #bspc config border_width 2
36 #bspc config window_gap 8
37 bspc config window_gap 0
39 bspc config bottom_padding 26
41 bspc config split_ratio 0.52
42 bspc config borderless_monocle true
43 bspc config gapless_monocle true
44 bspc config click_to_focus button1
45 bspc config directional_focus_tightness low
47 #bspc rule -a Firefox desktop='^1' follow=on
48 bspc rule -a Nightly desktop='^1' follow=on
49 bspc rule -a Emacs desktop='^2' state=tiled follow=on
50 #bspc rule -a Chromium desktop='^4' follow=on
51 bspc rule -a URxvt state=floating
52 bspc rule -a URxvt:tiled state=tiled
53 bspc rule -a Connman-gtk state=floating
54 bspc rule -a Xfce4-panel state=floating
55 bspc rule -a TelegramDesktop state=floating
56 bspc rule -a Ec state=floating
57 bspc rule -a Pavucontrol state=floating
58 bspc rule -a Eog state=floating
59 bspc rule -a Seahorse state=floating
60 bspc rule -a mpv state=floating
61 bspc rule -a Evince state=floating
62 bspc rule -a Meld state=floating
63 bspc rule -a Autokey-gtk state=floating
64 bspc rule -a Mousepad state=floating
65 bspc rule -a Wrapper-1.0 state=floating
66 bspc rule -a File-roller state=floating
67 bspc rule -a Gnome-disks state=floating
68 bspc rule -a Termite state=floating
69 bspc rule -a Termite:tiled state=tiled
70 bspc rule -a Thunderbird:Calendar state=floating
71 bspc rule -a Audacity state=floating
72 bspc rule -a Proof state=floating # pvs x-show-proof
73 bspc rule -a Nm-connection-editor state=floating
74 bspc rule -a Wire state=floating
75 bspc rule -a discord state=floating
76 bspc rule -a X2goclient state=floating
77 bspc rule -a SimpleScreenRecorder state=floating
78 bspc rule -a Gimp state=floating
79 bspc rule -a Wrapper-2.0 state=floating
80 bspc rule -a Zathura state=tiled
85 :header-args+: :tangle ~/.config/sxhkd/sxhkdrc
88 #+begin_src conf :tangle no
90 # wm independent hotkeys
94 super + {_,shift} + Return
97 #super + {_,shift} + Return
98 # termite{_, --name=tiled}
102 rofi -show run -display-run '> ' -display-window ' 🗔 '
105 xfce4-popup-whiskermenu
109 rofi -show window -display-run '> ' -display-window ' 🗔 '
121 # chromium -incognito
127 # make sxhkd reload its configuration files:
132 XF86Audio{Raise,Lower}Volume
133 pamixer --allow-boost --{in,de}crease 5
137 pamixer --toggle-mute
140 pactl set-source-mute 1 toggle
143 XF86Audio{Play,Prev,Next}
144 mpc {toggle,prev,next}
148 light-locker-command -l
150 # Toggle keyboard layout
154 # Toggle Xfce presentation mode
156 toggle-presentation-mode
159 XF86MonBrightness{Up,Down}
165 # keyboard brightness
166 #XF86KbdBrightness{Up,Down}
176 # quit bspwm normally
184 # alternate between the tiled and monocle layout
188 # send the newest marked node to the newest preselected node
190 bspc node newest.marked.local -n newest.!automatic.local
192 # swap the current node and the biggest node
200 # set the window state
201 super + {t,shift + t,s,f}
202 bspc node -t {tiled,pseudo_tiled,floating,fullscreen}
205 super + ctrl + {m,x,y,z}
206 bspc node -g {marked,locked,sticky,private}
212 # focus the node in the given direction
213 super + {_,shift + }{h,j,k,l}
214 bspc node -{f,s} {west,south,north,east}
216 # focus the node for the given path jump
217 super + {p,b,comma,period}
218 bspc node -f @{parent,brother,first,second}
220 # focus the next/previous node in the current desktop
221 super + {_,shift + }c
222 bspc node -f {next,prev}.local
224 # focus the next/previous desktop in the current monitor
225 super + bracket{left,right}
226 bspc desktop -f {prev,next}.local
228 # send to next/prev desktop
229 super + shift + bracket{left,right}
230 bspc node -d {prev,next} --follow
232 # focus the last node/desktop
234 bspc {node,desktop} -f last
236 # focus the older or newer node in the focus history
239 bspc node {older,newer} -f; \
242 # focus or send to the given desktop
243 super + {_,shift + }{1-9,0}
244 bspc {desktop -f,node -d} '^{1-9,10}'
250 # preselect the direction
251 super + ctrl + {h,j,k,l}
252 bspc node -p {west,south,north,east}
254 # preselect the ratio
258 # cancel the preselection for the focused node
262 # cancel the preselection for the focused desktop
263 super + ctrl + shift + space
264 bspc query -N -d | xargs -I id -n 1 bspc node id -p cancel
270 # expand a window by moving one of its side outward
271 super + alt + {h,j,k,l}
272 bspc node -z {left -20 0,bottom 0 20,top 0 -20,right 20 0}
274 # contract a window by moving one of its side inward
275 super + alt + shift + {h,j,k,l}
276 bspc node -z {right -20 0,top 0 20,bottom 0 -20,left 20 0}
278 # move a floating window
279 super + {Left,Down,Up,Right}
280 bspc node -v {-20 0,0 20,0 -20,20 0}
282 #alt + bracket{left,right}
283 # xdotool key --clearmodifiers ctrl+Page_{Up,Down}
288 :header-args+: :tangle ~/.config/compton.conf
291 #+begin_src conf :tangle no
293 shadow = false; # Enabled client-side shadows on windows.
294 no-dock-shadow = true; # Avoid drawing shadows on dock/panel windows.
295 no-dnd-shadow = true; # Don't draw shadows on DND windows.
296 clear-shadow = true; # Zero the part of the shadow's mask behind the
297 # window. Fix some weirdness with ARGB windows.
298 shadow-radius = 5; # The blur radius for shadows. (default 12)
299 shadow-offset-x = -5; # The left offset for shadows. (default -15)
300 shadow-offset-y = -5; # The top offset for shadows. (default -15)
301 # shadow-opacity = 0.7; # The translucency for shadows. (default .75)
302 # shadow-red = 0.0; # Red color value of shadow. (0.0 - 1.0, defaults to 0)
303 # shadow-green = 0.0; # Green color value of shadow. (0.0 - 1.0, defaults to 0)
304 # shadow-blue = 0.0; # Blue color value of shadow. (0.0 - 1.0, defaults to 0)
305 shadow-exclude = [ "n:e:Notification", "class_g = 'Chromium'", "class_g = 'Dmenu'", "class_g = 'Firefox' && argb" ]; # Exclude conditions for shadows.
306 # shadow-exclude = "n:e:Notification";
307 #shadow-exclude = [ "_GTK_FRAME_EXTENTS@:c" ] # Fix dual shadow on some gtk3 powered applications
308 shadow-ignore-shaped = true; # Avoid drawing shadow on all shaped windows
309 # (see also: --detect-rounded-corners)
312 menu-opacity = 1.0; # The opacity for menus. (default 1.0)
313 #inactive-opacity = 0.9; # Default opacity of inactive windows. (0.0 - 1.0)
314 # active-opacity = 0.8; # Default opacity for active windows. (0.0 - 1.0)
315 frame-opacity = 1.0; # Opacity of window titlebars and borders. (0.1 - 1.0)
316 # inactive-opacity-override = true; # Let inactive opacity set by 'inactive-opacity' overrides
317 # value of _NET_WM_OPACITY. Bad choice.
318 alpha-step = 0.06; # XRender backend: Step size for alpha pictures. Increasing
319 # it may result in less X resource usage,
320 # Yet fading may look bad.
321 #inactive-dim = 0.5; # Dim inactive windows. (0.0 - 1.0)
322 #inactive-dim-fixed = true; # Do not let dimness adjust based on window opacity.
323 # blur-background = true; # Blur background of transparent windows.
324 # Bad performance with X Render backend.
325 # GLX backend is preferred.
326 # blur-background-frame = true; # Blur background of opaque windows with transparent
328 blur-background-fixed = true; # Do not let blur radius adjust based on window opacity.
329 blur-background-exclude = [ "window_type = 'dock'", "window_type = 'desktop'" ];
330 # Exclude conditions for background blur.
333 fading = false; # Fade windows during opacity changes.
334 fade-delta = 3; # The time between steps in a fade in milliseconds. (default 10).
335 fade-in-step = 0.03; # Opacity change between steps while fading in. (default 0.028).
336 fade-out-step = 0.03; # Opacity change between steps while fading out. (default 0.03).
337 # no-fading-openclose = true; # Avoid fade windows in/out when opening/closing.
338 fade-exclude = [ ]; # Exclude conditions for fading.
341 backend = "glx" # Backend to use: "xrender" or "glx". GLX backend is typically
342 # much faster but depends on a sane driver.
343 mark-wmwin-focused = true; # Try to detect WM windows and mark them as active.
344 mark-ovredir-focused = true; # Mark all non-WM but override-redirect windows active (e.g. menus).
345 use-ewmh-active-win = true; # Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused
346 # instead of using FocusIn/Out events. Usually more reliable but
347 # depends on a EWMH-compliant WM.
348 detect-rounded-corners = false; # Detect rounded corners and treat them as rectangular when --shadow-ignore- shaped is on.
349 detect-client-opacity = true; # Detect _NET_WM_OPACITY on client windows, useful for window
350 # managers not passing _NET_WM_OPACITY of client windows to frame
352 refresh-rate = 0; # For --sw-opti: Specify refresh rate of the screen. 0 for auto.
353 vsync = "drm"; # "none", "drm", "opengl", "opengl-oml", "opengl-swc", "opengl-mswc"
354 # See man page for more details.
355 dbe = false; # Enable DBE painting mode. Rarely needed.
356 paint-on-overlay = true; # Painting on X Composite overlay window. Recommended.
357 sw-opti = false; # Limit compton to repaint at most once every 1 / refresh_rate.
358 # Incompatible with certain VSync methods.
359 unredir-if-possible = false; # Unredirect all windows if a full-screen opaque window is
360 # detected, to maximize performance for full-screen windows.
361 focus-exclude = [ ]; # A list of conditions of windows that should always be considered
363 detect-transient = true; # Use WM_TRANSIENT_FOR to group windows, and consider windows in
364 # the same group focused at the same time.
365 detect-client-leader = true; # Use WM_CLIENT_LEADER to group windows.
366 invert-color-include = [ ]; # Conditions for windows to be painted with inverted color.
368 # GLX backend # GLX backend fine-tune options. See man page for more info.
369 glx-no-stencil = true; # Recommended.
370 glx-copy-from-front = false; # Useful with --glx-swap-method,
371 # glx-use-copysubbuffermesa = true; # Recommended if it works. Breaks VSync.
372 # glx-no-rebind-pixmap = true; # Recommended if it works.
373 glx-no-rebind-pixmap = true; # Recommended if it works.
374 #glx-swap-method = "4"; # See man page.
375 glx-swap-method = "4"; # See man page.
377 # Window type settings
380 tooltip = { fade = true; shadow = false; opacity = 1; focus = true; };
381 menu = { shadow = false; };
382 dropdown_menu = { shadow = false; };
383 popup_menu = { shadow = false; };
384 utility = { shadow = false; };
385 # fade: Fade the particular type of windows.
386 # shadow: Give those windows shadow
387 # opacity: Default opacity for the type of windows.
388 # focus: Whether to always consider windows of this type focused.
394 :header-args+: :tangle ~/.config/dunst/dunstrc
399 #font = Ubuntu Mono 10.5
400 font = Inconsolata 11
402 # Path to default icons.
403 icon_folders = /usr/share/icons/Moka/16x16/status/:/usr/share/icons/Moka/16x16/devices/:/usr/share/icons/Faba-Mono/16x16/status/:/usr/share/icons/Faba-Mono/16x16/devices/:/usr/share/icons/Moka/16x16/actions/:/usr/share/icons/Moka/16x16/categories/:/usr/share/icons/Moka/16x16/mimetypes/:/usr/share/icons/Moka/16x16/apps/:/usr/share/icons/Moka/16x16/places/:/usr/share/icons/Paper/16x16/status/
408 # <s>strikethrough<s/>
411 # The format of the message. Possible variables are:
415 # %i iconname (including its path)
416 # %I iconname (without its path)
417 # %p progress value if set ([ 0%] to [100%]) or nothing
419 format = "<b>%s</b>\n%b"
420 # Sort messages by urgency
422 # Show how many messages are currently hidden (because of geometry)
424 # Alignment of message text.
425 # Possible values are "left", "center" and "right"
427 # The frequency with wich text that is longer than the notification
428 # window allows bounces back and forth.
429 # This option conflicts with 'word_wrap'.
430 # Set to 0 to disable
432 # show age of message if message is older than show_age_threshold seconds.
433 # set to -1 to disable
434 show_age_threshold = -1
435 # split notifications into multiple lines if they don't fit into geometry
437 # ignore newlines '\n' in notifications
439 # The geometry of the message window.
440 # geometry [{width}]x{height}][+/-{x}+/-{y}]
441 # The height is measured in number of notifications everything else in pixels. If the width
442 # is omitted but the height is given ("-geometry x2"), the message window
443 # expands over the whole screen (dmenu-like). If width is 0,
444 # the window expands to the longest message displayed.
445 # A positive x is measured from the left, a negative from the
446 # right side of the screen. Y is measured from the top and down respectevly.
447 # The width can be negative. In this case the actual width is the
448 # screen width minus the width defined in within the geometry option.
449 #geometry = "410x12-12+12"
450 #geometry = "0x0-30-30"
451 geometry = "260x12-30-30"
452 # The transparency of the window. range: [0; 100]
453 # This option will only work if a compositing windowmanager is present (e.g. xcompmgr, compiz, etc..)
455 # Don't remove messages, if the user is idle (no mouse or keyboard input)
456 # for longer than idle_threshold seconds.
457 # Set to 0 to disable.
459 # Which monitor should the notifications be displayed on.
461 # Display notification on focused monitor. Possible modes are:
462 # mouse: follow mouse pointer
463 # keyboard: follow window with keyboard focus
464 # none: don't follow anything
466 # "keyboard" needs a windowmanager that exports the _NET_ACTIVE_WINDOW property.
467 # This should be the case for almost all modern windowmanagers.
469 # If this option is set to mouse or keyboard, the monitor option will be
472 # should a notification popped up from history be sticky or
473 # timeout as if it would normally do.
475 # The height of a single line. If the height is smaller than the font height,
476 # it will get raised to the font height.
477 # This adds empty space above and under the text.
480 show_indicators = yes
482 # Draw a line of 'separatpr_height' pixel height between two notifications.
483 # Set to 0 to disable
485 # padding between text and separator
488 horizontal_padding = 8
489 # Define a color for the separator.
490 # possible values are:
491 # * auto: dunst tries to find a color fitting to the background
492 # * foreground: use the same color as the foreground
493 # * frame: use the same color as the frame.
494 # * anything else will be interpreted as a X color
495 separator_color = foreground
496 # print a notification on startup
497 # This is mainly for error detection, since dbus (re-)starts dunst
498 # automatically after a crash.
499 startup_notification = false
501 #dmenu = /usr/bin/dmenu -p dunst:
502 dmenu = /usr/bin/rofi -dmenu -p dunst:
503 # browser for opening urls in context menu
504 browser = /usr/bin/firefox -new-tab
509 # shortcuts are specified as [modifier+][modifier+]...key
510 # available modifiers are 'ctrl', 'mod1' (the alt-key), 'mod2', 'mod3'
511 # and 'mod4' (windows-key)
512 # xev might be helpful to find names for keys
515 # close all notifications
516 close_all = ctrl+shift+space
517 # redisplay last message(s)
518 # On the US keyboard layout 'grave' is normally above TAB and left of '1'.
519 history = ctrl+shift+h
521 context = ctrl+shift+period
523 # IMPORTANT: colors have to be defined in quotation marks.
524 # Otherwise the '#' and following would be interpreted as a comment.
525 background = "#1d2a30"
526 foreground = "#71c2af"
529 background = "#1d2a30"
530 foreground = "#71c2af"
533 background = "#1d2a30"
534 foreground = "#ff9982"
537 # Every section that isn't one of the above is interpreted as a rules
538 # to override settings for certain messages.
539 # Messages can be matched by 'appname', 'summary', 'body' or 'icon'
540 # and you can override the 'timeout', 'urgency', 'foreground', 'background'
542 # Shell-like globbing will get expanded.
545 # you can specify a script that gets run when the rule matches by setting
546 # the 'script' option.
547 # The script will be called as follows:
548 # script appname summary body icon urgency
549 # where urgency can be "LOW", "NORMAL" or "CRITICAL".
551 # NOTE: if you don't want a notification to be displayed, set the format to ""
552 # NOTE: It might be helpful to run dunst -print in a terminal in order to find
553 # fitting options for rules.
556 # script = dunst_espeak.sh
558 # summary = "*script*"
559 # script = dunst_test.sh
561 ## This notification will not be displayed
566 # summary = "*signed on*"
571 # summary = *signed off*
581 # summary = *twitter.com*
585 summary = *Brightness*
591 :header-args+: :tangle ~/.config/fontconfig/fonts.conf :comments none
595 <?xml version="1.0"?>
596 <!DOCTYPE fontconfig SYSTEM "fonts.dtd">
598 <match target="font">
599 <edit mode="assign" name="rgba">
603 <match target="font">
604 <edit mode="assign" name="hinting">
608 <match target="font">
609 <edit mode="assign" name="hintstyle">
610 <const>hintslight</const>
613 <match target="font">
614 <edit mode="assign" name="antialias">
618 <match target="font">
619 <edit mode="assign" name="lcdfilter">
620 <const>lcddefault</const>
625 <!-- Use Liberation Sans for Helvetica (instead of Nimbus Sans) -->
626 <alias binding="same">
627 <family>Helvetica</family>
629 <family>Liberation Sans</family>
639 :header-args+: :tangle ~/.gitconfig
646 email = amin@aminb.org
647 signingkey = 4E05246AB0BF7FFB
661 autocrlf = input # CRLF -> LF on commit
662 editor = emacsclient -t
663 excludesfile = ~/.gitignore_global
676 git = !exec git # handle nested git calls, e.g. git git status
677 aliases = config --get-regexp '^alias\\.'
701 remote = magenta bold
710 # showUntrackedFiles = all
724 smtpuser = amin@aminb.org
725 smtpserver = nix.aminb.org
733 :header-args+: :tangle ~/.gitignore_global
748 :header-args+: :tangle ~/.latexmkrc
752 $pdf_previewer = "start zathura %O %S";
753 $clean_ext = "aux out";
755 # $pdf_update_method = 4;
756 # $pdf_update_command = "zathura %O %S";
758 # Synctex allows one to jump to from the PDF in Zathura to the source in Emacs
759 # by Ctrl+click in the PDF.
760 # Tell latexmk to use Zathura as a previewer, and run emacsclient as the Synctex
762 # $pdf_previewer = 'exec zathura --synctex-forward -x \'emacsclient --no-wait +%{line} %{input}\' %O %S';
767 Improve XPS 15 9560's touchpad experience.
769 # begin_src conf :tangle (when (and (eq system-type 'gnu/linux) (string= (system-name) "plasma")) "/sudo::/etc/X11/xorg.conf.d/30-touchpad.conf")
770 #+begin_src conf :tangle no
772 Identifier "libinput touchpad catchall"
775 Option "ClickMethod" "clickfinger"
776 Option "NaturalScrolling" "true"
777 Option "Tapping" "on"
778 Option "TappingButtonMap" "lrm"
786 :header-args+: :tangle ~/.getmail/getmailrc
791 type = SimplePOP3SSLRetriever
792 server = fencepost.gnu.org
794 password_command = ("gpg2", "--no-tty", "-q", "-d", "/home/amin/.passwd/gnu.gpg")
800 path = ~/mail/gnu/Inbox/
808 :header-args+: :tangle ~/.config/systemd/user/getmail.service
811 #+begin_src conf :tangle no
813 Description=getmail service
817 ExecStart=/usr/bin/getmail
818 StandardOutput=syslog
824 :header-args+: :tangle ~/.config/systemd/user/getmail.timer
827 #+begin_src conf :tangle no
829 Description=getmail timer
837 WantedBy=timers.target
842 :header-args+: :tangle ~/.gnupg/gpg-agent.conf
846 default-cache-ttl 43200
849 default-cache-ttl-ssh 10800
850 max-cache-ttl-ssh 10800
852 # pinentry-program /usr/bin/pinentry-qt
859 :header-args+: :tangle ~/.gtkrc-2.0
863 gtk-theme-name="Greybird"
864 gtk-icon-theme-name="Paper"
865 gtk-font-name="Ubuntu 10"
867 # gtk-key-theme-name = "Emacs"
872 :header-args+: :tangle ~/.config/gtk-3.0/settings.ini
875 #+begin_src conf :tangle no
877 gtk-icon-theme-name = Paper
878 # gtk-theme-name = Adwaita
880 gtk-theme-name = Greybird
881 # gtk-theme-name = Arc-Darker
882 # gtk-theme-name = Numix-ArchBlue
884 gtk-font-name = Ubuntu 10
885 # gtk-key-theme-name = Emacs
892 :header-args+: :tangle ~/.mbsyncrc
903 PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/amin.gpg"
906 IMAPStore amin-remote
909 MaildirStore amin-local
911 Inbox ~/mail/amin/Inbox
922 IMAPAccount uwaterloo
923 Host connect.uwaterloo.ca
925 PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/uwaterloo.gpg"
928 IMAPStore uwaterloo-remote
931 MaildirStore uwaterloo-local
932 Path ~/mail/uwaterloo/
933 Inbox ~/mail/uwaterloo/Inbox
937 Master :uwaterloo-remote:
938 Slave :uwaterloo-local:
946 :header-args+: :tangle ~/.config/systemd/user/mbsync.service
949 #+begin_src conf :tangle no
951 Description=mbsync service
955 ExecStart=/usr/bin/mbsync -Va
956 StandardOutput=syslog
962 :header-args+: :tangle ~/.config/systemd/user/mbsync.timer
965 #+begin_src conf :tangle no
967 Description=mbsync timer
975 WantedBy=timers.target
980 :header-args+: :tangle ~/.config/mpd/mpd.conf
984 # An example configuration file for MPD.
985 # Read the user manual for documentation: http://www.musicpd.org/doc/user/
988 # Files and directories #######################################################
990 # This setting controls the top directory which MPD will search to discover the
991 # available audio files and add them to the daemon's online database. This
992 # setting defaults to the XDG directory, otherwise the music directory will be
993 # be disabled and audio files will only be accepted over ipc socket (using
994 # file:// protocol) or streaming files over an accepted protocol.
996 music_directory "~/usr/music"
998 # This setting sets the MPD internal playlist directory. The purpose of this
999 # directory is storage for playlists created by MPD. The server will use
1000 # playlist files not created by the server but only if they are in the MPD
1001 # format. This setting defaults to playlist saving being disabled.
1003 playlist_directory "~/.mpd/playlists"
1005 # This setting sets the location of the MPD database. This file is used to
1006 # load the database at server start up and store the database while the
1007 # server is not up. This setting defaults to disabled which will allow
1008 # MPD to accept files over ipc socket (using file:// protocol) or streaming
1009 # files over an accepted protocol.
1011 db_file "~/.mpd/database"
1013 # These settings are the locations for the daemon log files for the daemon.
1014 # These logs are great for troubleshooting, depending on your log_level
1017 # The special value "syslog" makes MPD use the local syslog daemon. This
1018 # setting defaults to logging to syslog, otherwise logging is disabled.
1020 log_file "~/.mpd/log"
1022 # This setting sets the location of the file which stores the process ID
1023 # for use of mpd --kill and some init scripts. This setting is disabled by
1024 # default and the pid file will not be stored.
1026 pid_file "~/.mpd/pid"
1028 # This setting sets the location of the file which contains information about
1029 # most variables to get MPD back into the same general shape it was in before
1030 # it was brought down. This setting is disabled by default and the server
1031 # state will be reset on server start up.
1033 state_file "~/.mpd/state"
1035 # The location of the sticker database. This is a database which
1036 # manages dynamic information attached to songs.
1038 sticker_file "~/.mpd/sticker.sql"
1040 ###############################################################################
1043 # General music daemon options ################################################
1045 # This setting specifies the user that MPD will run as. MPD should never run as
1046 # root and you may use this setting to make MPD change its user ID after
1047 # initialization. This setting is disabled by default and MPD is run as the
1052 # This setting specifies the group that MPD will run as. If not specified
1053 # primary group of user specified with "user" setting will be used (if set).
1054 # This is useful if MPD needs to be a member of group such as "audio" to
1055 # have permission to use sound card.
1059 # This setting sets the address for the daemon to listen on. Careful attention
1060 # should be paid if this is assigned to anything other then the default, any.
1061 # This setting can deny access to control of the daemon. Not effective if
1062 # systemd socket activiation is in use.
1065 #bind_to_address "any"
1067 # And for Unix Socket
1068 #bind_to_address "~/.mpd/socket"
1070 # This setting is the TCP port that is desired for the daemon to get assigned
1075 # This setting controls the type of information which is logged. Available
1076 # setting arguments are "default", "secure" or "verbose". The "verbose" setting
1077 # argument is recommended for troubleshooting, though can quickly stretch
1078 # available resources on limited hardware storage.
1080 #log_level "default"
1082 # If you have a problem with your MP3s ending abruptly it is recommended that
1083 # you set this argument to "no" to attempt to fix the problem. If this solves
1084 # the problem, it is highly recommended to fix the MP3 files with vbrfix
1085 # (available from <http://www.willwap.co.uk/Programs/vbrfix.php>), at which
1086 # point gapless MP3 playback can be enabled.
1088 #gapless_mp3_playback "yes"
1090 # Setting "restore_paused" to "yes" puts MPD into pause mode instead
1091 # of starting playback after startup.
1093 #restore_paused "no"
1095 # This setting enables MPD to create playlists in a format usable by other
1098 #save_absolute_paths_in_playlists "no"
1100 # This setting defines a list of tag types that will be extracted during the
1101 # audio file discovery process. The complete list of possible values can be
1102 # found in the user manual.
1103 #metadata_to_use "artist,album,title,track,name,genre,date,composer,performer,disc"
1105 # This setting enables automatic update of MPD's database when files in
1106 # music_directory are changed.
1110 # Limit the depth of the directories being watched, 0 means only watch
1111 # the music directory itself. There is no limit by default.
1113 #auto_update_depth "3"
1115 ###############################################################################
1118 # Symbolic link behavior ######################################################
1120 # If this setting is set to "yes", MPD will discover audio files by following
1121 # symbolic links outside of the configured music_directory.
1123 #follow_outside_symlinks "yes"
1125 # If this setting is set to "yes", MPD will discover audio files by following
1126 # symbolic links inside of the configured music_directory.
1128 #follow_inside_symlinks "yes"
1130 ###############################################################################
1133 # Zeroconf / Avahi Service Discovery ##########################################
1135 # If this setting is set to "yes", service information will be published with
1138 #zeroconf_enabled "yes"
1140 # The argument to this setting will be the Zeroconf / Avahi unique name for
1141 # this MPD server on the network.
1143 #zeroconf_name "Music Player"
1145 ###############################################################################
1148 # Permissions #################################################################
1150 # If this setting is set, MPD will require password authorization. The password
1151 # setting can be specified multiple times for different password profiles.
1153 #password "password@read,add,control,admin"
1155 # This setting specifies the permissions a user has who has not yet logged in.
1157 #default_permissions "read,add,control,admin"
1159 ###############################################################################
1162 # Database #######################################################################
1167 # host "other.mpd.host"
1171 # Input #######################################################################
1176 # proxy "proxy.isp.com:8080"
1178 # proxy_password "password"
1182 ###############################################################################
1184 # Audio Output ################################################################
1195 path "/tmp/mpd.fifo"
1199 # MPD supports various audio output types, as well as playing through multiple
1200 # audio outputs at the same time, through multiple audio_output settings
1201 # blocks. Setting this block is optional, though the server will only attempt
1202 # autodetection for one sound card.
1204 # An example of an ALSA output:
1208 # name "My ALSA Device"
1209 ## device "hw:0,0" # optional
1210 ## mixer_type "hardware" # optional
1211 ## mixer_device "default" # optional
1212 ## mixer_control "PCM" # optional
1213 ## mixer_index "0" # optional
1216 # An example of an OSS output:
1220 # name "My OSS Device"
1221 ## device "/dev/dsp" # optional
1222 ## mixer_type "hardware" # optional
1223 ## mixer_device "/dev/mixer" # optional
1224 ## mixer_control "PCM" # optional
1227 # An example of a shout output (for streaming to Icecast):
1231 # encoder "vorbis" # optional
1232 # name "My Shout Stream"
1239 # format "44100:16:1"
1240 ## protocol "icecast2" # optional
1241 ## user "source" # optional
1242 ## description "My Stream Description" # optional
1243 ## url "http://example.com" # optional
1244 ## genre "jazz" # optional
1245 ## public "no" # optional
1246 ## timeout "2" # optional
1247 ## mixer_type "software" # optional
1250 # An example of a recorder output:
1254 # name "My recorder"
1255 # encoder "vorbis" # optional, vorbis or lame
1256 # path "/var/lib/mpd/recorder/mpd.ogg"
1257 ## quality "5.0" # do not define if bitrate is defined
1258 # bitrate "128" # do not define if quality is defined
1259 # format "44100:16:1"
1262 # An example of a httpd output (built-in HTTP streaming server):
1266 # name "My HTTP Stream"
1267 # encoder "vorbis" # optional, vorbis or lame
1269 # bind_to_address "0.0.0.0" # optional, IPv4 or IPv6
1270 ## quality "5.0" # do not define if bitrate is defined
1271 # bitrate "128" # do not define if quality is defined
1272 # format "44100:16:1"
1273 # max_clients "0" # optional 0=no limit
1276 # An example of a pulseaudio output (streaming to a remote pulseaudio server)
1280 # name "My Pulse Output"
1281 ## server "remote_server" # optional
1282 ## sink "remote_server_sink" # optional
1285 # An example of a winmm output (Windows multimedia API).
1289 # name "My WinMM output"
1290 ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
1292 ## device "0" # optional
1293 ## mixer_type "hardware" # optional
1296 # An example of an openal output.
1300 # name "My OpenAL output"
1301 ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
1304 # An example of an sndio output.
1308 # name "sndio output"
1309 # mixer_type "software"
1312 # An example of an OS X output:
1316 # name "My OS X Device"
1317 ## device "Built-in Output" # optional
1318 ## channel_map "-1,-1,0,1" # optional
1321 ## Example "pipe" output:
1326 # command "aplay -f cd 2>/dev/null"
1327 ## Or if you're want to use AudioCompress
1328 # command "AudioCompress -m | aplay -f cd 2>/dev/null"
1329 ## Or to send raw PCM stream through PCM:
1330 # command "nc example.org 8765"
1331 # format "44100:16:2"
1334 ## An example of a null output (for no audio output):
1338 # name "My Null Output"
1339 # mixer_type "none" # optional
1342 ###############################################################################
1345 # Normalization automatic volume adjustments ##################################
1347 # This setting specifies the type of ReplayGain to use. This setting can have
1348 # the argument "off", "album", "track" or "auto". "auto" is a special mode that
1349 # chooses between "track" and "album" depending on the current state of
1350 # random playback. If random playback is enabled then "track" mode is used.
1351 # See <http://www.replaygain.org> for more details about ReplayGain.
1352 # This setting is off by default.
1356 # This setting sets the pre-amp used for files that have ReplayGain tags. By
1357 # default this setting is disabled.
1359 #replaygain_preamp "0"
1361 # This setting sets the pre-amp used for files that do NOT have ReplayGain tags.
1362 # By default this setting is disabled.
1364 #replaygain_missing_preamp "0"
1366 # This setting enables or disables ReplayGain limiting.
1367 # MPD calculates actual amplification based on the ReplayGain tags
1368 # and replaygain_preamp / replaygain_missing_preamp setting.
1369 # If replaygain_limit is enabled MPD will never amplify audio signal
1370 # above its original level. If replaygain_limit is disabled such amplification
1371 # might occur. By default this setting is enabled.
1373 #replaygain_limit "yes"
1375 # This setting enables on-the-fly normalization volume adjustment. This will
1376 # result in the volume of all playing audio to be adjusted so the output has
1377 # equal "loudness". This setting is disabled by default.
1379 #volume_normalization "no"
1381 ###############################################################################
1383 # Character Encoding ##########################################################
1385 # If file or directory names do not display correctly for your locale then you
1386 # may need to modify this setting.
1388 #filesystem_charset "UTF-8"
1390 ###############################################################################
1395 :header-args+: :tangle ~/.msmtprc
1399 # Set default values for all following accounts.
1404 #tls_trust_file /etc/ssl/certs/ca-certificates.crt
1405 logfile ~/.msmtp.log
1410 tls_fingerprint 65:DD:B8:32:D8:CD:F1:DC:B6:34:EE:35:04:18:AC:09:F3:1D:6D:20:F2:4A:E2:BD:64:48:B7:1F:90:BD:C4:BA
1414 passwordeval gpg2 --no-tty -q -d ~/.passwd/amin.gpg
1418 host fencepost.gnu.org
1419 # use `msmtp -a gnu --serverinfo --tls --tls-certcheck=off --tls-fingerprint=` to get the current fingerprint
1420 tls_fingerprint 28:70:42:76:1C:EC:91:5F:D1:B3:27:A1:CD:3B:32:A4:8B:0B:DC:3A:CD:CA:F6:6F:E4:61:BA:69:D7:4D:0D:0B
1424 passwordeval gpg2 --no-tty -q -d ~/.passwd/gnu.gpg
1428 host connect.uwaterloo.ca
1430 from abandali@uwaterloo.ca
1432 passwordeval gpg2 --no-tty -q -d ~/.passwd/uwaterloo.gpg
1433 tls_trust_file /etc/ssl/certs/ca-certificates.crt
1435 # uwaterloo (friendly address)
1436 account uwaterloo-friendly : uwaterloo
1437 from amin.bandali@uwaterloo.ca
1439 # Set a default account
1440 account default : aminb
1447 :header-args+: :tangle ~/.ncmpcpp/config
1450 #+begin_src conf :tangle no
1451 ##############################################################
1452 ## This is the example configuration file. Copy it to ##
1453 ## $HOME/.ncmpcpp/config or $XDG_CONFIG_HOME/ncmpcpp/config ##
1454 ## and set up your preferences. ##
1455 ##############################################################
1457 ##### directories ######
1459 ## Directory for storing ncmpcpp related files.
1460 ## Changing it is useful if you want to store
1461 ## everything somewhere else and provide command
1462 ## line setting for alternative location to config
1463 ## file which defines that while launching ncmpcpp.
1466 ncmpcpp_directory = ~/.ncmpcpp
1469 ## Directory for storing downloaded lyrics. It
1470 ## defaults to ~/.lyrics since other MPD clients
1471 ## (eg. ncmpc) also use that location.
1474 #lyrics_directory = ~/.lyrics
1476 ##### connection settings #####
1478 #mpd_host = localhost
1482 #mpd_connection_timeout = 5
1484 ## Needed for tag editor and file operations to work.
1486 mpd_music_dir = ~/usr/music
1488 #mpd_crossfade_time = 5
1490 ##### music visualizer #####
1492 ## Note: In order to make music visualizer work you'll
1493 ## need to use mpd fifo output, whose format parameter
1494 ## has to be set to 44100:16:1 for mono visualization
1495 ## or 44100:16:2 for stereo visualization. Example
1496 ## configuration (it has to be put into mpd.conf):
1500 ## name "Visualizer feed"
1501 ## path "/tmp/mpd.fifo"
1502 ## format "44100:16:2"
1506 visualizer_fifo_path = /tmp/mpd.fifo
1509 ## Note: Below parameter is needed for ncmpcpp
1510 ## to determine which output provides data for
1511 ## visualizer and thus allow syncing between
1512 ## visualization and sound as currently there
1513 ## are some problems with it.
1516 visualizer_output_name = my fifo
1519 ## If you set format to 44100:16:2, make it 'yes'.
1521 visualizer_in_stereo = yes
1524 ## Multiply received samples by given value. Very
1525 ## useful for proper visualization of quiet music.
1527 #visualizer_sample_multiplier = 1
1530 ## Note: Below parameter defines how often ncmpcpp
1531 ## has to "synchronize" visualizer and audio outputs.
1532 ## 30 seconds is optimal value, but if you experience
1533 ## synchronization problems, set it to lower value.
1534 ## Keep in mind that sane values start with >=10.
1537 visualizer_sync_interval = 30
1540 ## Note: To enable spectrum frequency visualization
1541 ## you need to compile ncmpcpp with fftw3 support.
1544 ## Available values: spectrum, wave, wave_filled, ellipse.
1546 visualizer_type = spectrum
1548 #visualizer_look = ●▮
1549 visualizer_look = "●•"
1551 #visualizer_color = blue, cyan, green, yellow, magenta, red
1553 ## Alternative subset of 256 colors for terminals that support it.
1555 #visualizer_color = 41, 83, 119, 155, 185, 215, 209, 203, 197, 161
1557 ##### system encoding #####
1559 ## ncmpcpp should detect your charset encoding
1560 ## but if it failed to do so, you can specify
1561 ## charset encoding you are using here.
1563 ## Note: You can see whether your ncmpcpp build
1564 ## supports charset detection by checking output
1565 ## of `ncmpcpp --version`.
1567 ## Note: Since MPD uses UTF-8 by default, setting
1568 ## this option makes sense only if your encoding
1572 #system_encoding = ""
1576 ## Time of inactivity (in seconds) after playlist
1577 ## highlighting will be disabled (0 = always on).
1579 #playlist_disable_highlight_delay = 5
1581 ## Defines how long messages are supposed to be visible.
1583 #message_delay_time = 5
1585 ##### song format #####
1587 ## For a song format you can use:
1593 ## %A - album artist
1597 ## %n - track number (01/12 -> 01)
1598 ## %N - full track info (01/12 -> 01/12)
1605 ## $R - begin right alignment
1607 ## If you want to make sure that a part of the format is displayed
1608 ## only when certain tags are present, you can archieve it by
1609 ## grouping them with brackets, e.g. '{%a - %t}' will be evaluated
1610 ## to 'ARTIST - TITLE' if both tags are present or '' otherwise.
1611 ## It is also possible to define a list of alternatives by providing
1612 ## several groups and separating them with '|', e.g. '{%t}|{%f}'
1613 ## will be evaluated to 'TITLE' or 'FILENAME' if the former is not
1616 ## Note: If you want to set limit on maximal length of a tag, just
1617 ## put the appropriate number between % and character that defines
1618 ## tag type, e.g. to make album take max. 20 terminal cells, use '%20b'.
1620 ## In addition, formats support markers used for text attributes.
1621 ## They are followed by character '$'. After that you can put:
1623 ## - 0 - default window color (discards all other colors)
1632 ## - 9 - end of current color
1634 ## - u - underline text
1635 ## - r - reverse colors
1636 ## - a - use alternative character set
1638 ## If you don't want to use a non-color attribute anymore, just put it
1639 ## again, but this time insert character '/' between '$' and attribute
1640 ## character, e.g. {$b%t$/b}|{$r%f$/r} will display bolded title tag
1641 ## or filename with reversed colors.
1643 ## If you want to use 256 colors and/or background colors in formats
1644 ## (the naming scheme is described below in section about color
1645 ## definitions), it can be done with the syntax $(COLOR), e.g. to set
1646 ## the artist tag to one of the non-standard colors and make it have
1647 ## yellow background, you need to write $(197_yellow)%a$(end). Note
1648 ## that for standard colors this is interchangable with attributes
1651 ## Note: colors can be nested.
1654 #song_list_format = {%a - }{%t}|{$8%f$9}$R{$3(%l)$9}
1656 #song_status_format = {{%a{ "%b"{ (%y)}} - }{%t}}|{%f}
1658 #song_library_format = {%n - }{%t}|{%f}
1661 #alternative_header_first_line_format = $b$1$aqqu$/a$9 {%t}|{%f} $1$atqq$/a$9$/b
1663 #alternative_header_second_line_format = {{$4$b%a$/b$9}{ - $7%b$9}{ ($4%y$9)}}|{%D}
1665 #now_playing_prefix = $b
1667 #now_playing_suffix = $/b
1669 #browser_playlist_prefix = "$2playlist$9 "
1671 #selected_item_prefix = $6
1673 #selected_item_suffix = $9
1675 #modified_item_prefix = $3> $9
1678 ## Note: attributes are not supported for the following variables.
1680 #song_window_title_format = {%a - }{%t}|{%f}
1682 ## Note: Below variables are used for sorting songs in browser.
1683 ## The sort mode determines how songs are sorted, and can be used
1684 ## in combination with a sort format to specify a custom sorting format.
1685 ## Available values for browser_sort_mode are "name", "mtime", "format"
1689 #browser_sort_mode = name
1691 #browser_sort_format = {%a - }{%t}|{%f} {(%l)}
1693 ##### columns settings #####
1695 ## syntax of song columns list format is "column column etc."
1697 ## - syntax for each column is:
1699 ## (width of the column)[color of the column]{displayed tag}
1701 ## Note: Width is by default in %, if you want a column to
1702 ## have fixed size, add 'f' after the value, e.g. (10)[white]{a}
1703 ## will be the column that take 10% of screen (so the real width
1704 ## will depend on actual screen size), whereas (10f)[white]{a}
1705 ## will take 10 terminal cells, no matter how wide the screen is.
1707 ## - color is optional (if you want the default one,
1708 ## leave the field empty).
1710 ## Note: You can give a column additional attributes by putting appropriate
1711 ## character after displayed tag character. Available attributes are:
1713 ## - r - column will be right aligned
1714 ## - E - if tag is empty, empty tag marker won't be displayed
1718 ## - give a column custom name by putting it after attributes,
1719 ## separated with character ':', e.g. {lr:Length} gives you
1720 ## right aligned column of lengths named "Length".
1722 ## - define sequence of tags, that have to be displayed in case
1723 ## predecessor is empty in a way similar to the one in classic
1724 ## song format, i.e. using '|' character, e.g. {a|c|p:Owner}
1725 ## creates column named "Owner" that tries to display artist
1726 ## tag and then composer and performer if previous ones are
1730 #song_columns_list_format = (20)[]{a} (6f)[green]{NE} (50)[white]{t|f:Title} (20)[cyan]{b} (7f)[magenta]{l}
1732 ##### various settings #####
1735 ## Note: Custom command that will be executed each
1736 ## time song changes. Useful for notifications etc.
1738 #execute_on_song_change = ""
1740 #playlist_show_mpd_host = no
1742 #playlist_show_remaining_time = no
1744 #playlist_shorten_total_times = no
1746 #playlist_separate_albums = no
1749 ## Note: Possible display modes: classic, columns.
1751 #playlist_display_mode = columns
1753 #browser_display_mode = classic
1755 #search_engine_display_mode = classic
1757 #playlist_editor_display_mode = classic
1759 #discard_colors_if_item_is_selected = yes
1761 #incremental_seeking = yes
1765 #volume_change_step = 2
1767 #autocenter_mode = no
1769 #centered_cursor = no
1772 ## Note: You can specify third character which will
1773 ## be used to build 'empty' part of progressbar.
1775 #progressbar_look = =>
1776 progressbar_look = "─╼╶"
1777 #progressbar_look = "─⊙╶"
1779 #progressbar_boldness = yes
1781 ## Available values: database, playlist.
1783 #default_place_to_search_in = database
1785 ## Available values: classic, alternative.
1787 #user_interface = classic
1789 #data_fetching_delay = yes
1791 ## Available values: artist, album_artist, date, genre, composer, performer.
1793 #media_library_primary_tag = artist
1795 ## Available values: wrapped, normal.
1797 #default_find_mode = wrapped
1799 #default_tag_editor_pattern = %n - %t
1801 #header_visibility = yes
1803 #statusbar_visibility = yes
1805 #titles_visibility = yes
1807 #header_text_scrolling = yes
1809 #cyclic_scrolling = no
1813 #follow_now_playing_lyrics = no
1815 #fetch_lyrics_for_current_song_in_background = no
1817 #store_lyrics_in_song_dir = no
1819 #generate_win32_compatible_filenames = yes
1821 #allow_for_physical_item_deletion = no
1824 ## Note: If you set this variable, ncmpcpp will try to
1825 ## get info from last.fm in language you set and if it
1826 ## fails, it will fall back to english. Otherwise it will
1827 ## use english the first time.
1829 ## Note: Language has to be expressed as an ISO 639 alpha-2 code.
1831 #lastfm_preferred_language = en
1833 #show_hidden_files_in_local_browser = no
1836 ## How shall screen switcher work?
1838 ## - "previous" - switch between the current and previous screen.
1839 ## - "screen1,...,screenN" - switch between given sequence of screens.
1841 ## Screens available for use: help, playlist, browser, search_engine,
1842 ## media_library, playlist_editor, tag_editor, outputs, visualizer, clock.
1844 #screen_switcher_mode = playlist, browser
1847 ## Note: You can define startup screen
1848 ## by choosing screen from the list above.
1850 #startup_screen = playlist
1853 ## Note: You can define startup slave screen
1854 ## by choosing screen from the list above or
1855 ## an empty value for no slave screen.
1857 #startup_slave_screen = ""
1859 #startup_slave_screen_focus = no
1862 ## Default width of locked screen (in %).
1863 ## Acceptable values are from 20 to 80.
1866 #locked_screen_width_part = 50
1868 #ask_for_locked_screen_width_part = yes
1870 #jump_to_now_playing_song_at_start = yes
1872 #ask_before_clearing_playlists = yes
1874 #clock_display_seconds = no
1876 #display_volume_level = yes
1878 #display_bitrate = no
1880 #display_remaining_time = no
1882 ## Available values: none, basic, extended, perl.
1884 #regular_expressions = perl
1887 ## Note: If below is enabled, ncmpcpp will ignore leading
1888 ## "The" word while sorting items in browser, tags in
1889 ## media library, etc.
1891 #ignore_leading_the = no
1893 #block_search_constraints_change_if_items_found = yes
1895 #mouse_support = yes
1897 #mouse_list_scroll_whole_page = yes
1899 #empty_tag_marker = <empty>
1901 #tags_separator = " | "
1903 #tag_editor_extended_numeration = no
1905 #media_library_sort_by_mtime = no
1907 #enable_window_title = yes
1910 ## Note: You can choose default search mode for search
1911 ## engine. Available modes are:
1913 ## - 1 - use mpd built-in searching (no regexes, pattern matching)
1914 ## - 2 - use ncmpcpp searching (pattern matching with support for regexes,
1915 ## but if your mpd is on a remote machine, downloading big database
1916 ## to process it can take a while
1917 ## - 3 - match only exact values (this mode uses mpd function for searching
1918 ## in database and local one for searching in current playlist)
1921 #search_engine_default_search_mode = 1
1923 #external_editor = nano
1925 ## Note: set to yes if external editor is a console application.
1927 #use_console_editor = yes
1929 ##### colors definitions #####
1931 ## It is possible to set a background color by setting a color
1932 ## value "<foreground>_<background>", e.g. red_black will set
1933 ## foregound color to red and background color to black.
1935 ## In addition, for terminals that support 256 colors it
1936 ## is possible to set one of them by using a number in range
1937 ## [1, 256] instead of color name, e.g. numerical value
1938 ## corresponding to red_black is 2_1. To find out if the
1939 ## terminal supports 256 colors, run ncmpcpp and check out
1940 ## the bottom of the help screen for list of available colors
1941 ## and their numerical values.
1943 ## Note: due to technical limitations of ncurses, if 256 colors
1944 ## are used, it is possible to either use only the colors with
1945 ## default background color, or all pairs from 1_1 up to 254_127,
1946 ## depending on the ncurses version used.
1949 #colors_enabled = yes
1951 #empty_tag_color = cyan
1953 #header_window_color = default
1955 #volume_color = default
1957 #state_line_color = default
1959 #state_flags_color = default
1961 #main_window_color = yellow
1967 #main_window_highlight_color = yellow
1969 #progressbar_color = black
1971 #progressbar_elapsed_color = green
1973 #statusbar_color = default
1975 #alternative_ui_separator_color = black
1977 #active_column_color = red
1979 #window_border_color = green
1981 #active_window_border = red
1987 :header-args+: :tangle ~/.ncmpcpp/bindings
1990 #+begin_src conf :tangle no
2015 move_sort_order_down
2024 :header-args+: :tangle ~/.notmuch-config
2028 # .notmuch-config - Configuration file for the notmuch mail system
2030 # For more information about notmuch, see https://notmuchmail.org
2032 # Database configuration
2034 # The only value supported here is 'path' which should be the top-level
2035 # directory where your mail currently exists and to where mail will be
2036 # delivered in the future. Files should be individual email messages.
2037 # Notmuch will store its database within a sub-directory of the path
2038 # configured here named ".notmuch".
2041 path=/home/amin/mail
2043 # User configuration
2045 # Here is where you can let notmuch know how you would like to be
2046 # addressed. Valid settings are
2048 # name Your full name.
2049 # primary_email Your primary email address.
2050 # other_email A list (separated by ';') of other email addresses
2051 # at which you receive email.
2053 # Notmuch will use the various email addresses configured here when
2054 # formatting replies. It will avoid including your own addresses in the
2055 # recipient list of replies, and will set the From address based on the
2056 # address to which the original email was addressed.
2060 primary_email=amin@aminb.org
2061 other_email=abandali@uwaterloo.ca;amin.bandali@uwaterloo.ca;aminb@gnu.org;
2063 # Configuration for "notmuch new"
2065 # The following options are supported here:
2067 # tags A list (separated by ';') of the tags that will be
2068 # added to all messages incorporated by "notmuch new".
2070 # ignore A list (separated by ';') of file and directory names
2071 # that will not be searched for messages by "notmuch new".
2073 # NOTE: *Every* file/directory that goes by one of those
2074 # names will be ignored, independent of its depth/location
2075 # in the mail store.
2080 ignore=.uidvalidity;.mbsyncstate;/.*/dovecot*/
2082 # Search configuration
2084 # The following option is supported here:
2087 # A ;-separated list of tags that will be excluded from
2088 # search results by default. Using an excluded tag in a
2089 # query will override that exclusion.
2092 exclude_tags=deleted;spam;
2094 # Maildir compatibility configuration
2096 # The following option is supported here:
2098 # synchronize_flags Valid values are true and false.
2100 # If true, then the following maildir flags (in message filenames)
2101 # will be synchronized with the corresponding notmuch tags:
2109 # S unread (added when 'S' flag is not present)
2111 # The "notmuch new" command will notice flag changes in filenames
2112 # and update tags, while the "notmuch tag" and "notmuch restore"
2113 # commands will notice tag changes and update flags in filenames
2116 synchronize_flags=true
2118 # Cryptography related configuration
2120 # The following option is supported here:
2123 # binary name or full path to invoke gpg.
2131 :header-args+: :tangle ~/mail/.notmuch/hooks/pre-new :shebang "#!/bin/sh"
2135 touch /tmp/gnusieve.log
2136 sieve-filter -eW -o postmaster_address=postmaster@aminb.org \
2137 -o mail_location=maildir:$MAILDIR/gnu:LAYOUT=fs:INBOX=$MAILDIR/gnu/Inbox ~/sieve/gnu.sieve INBOX delete &>>/tmp/gnusieve.log
2142 :header-args+: :tangle ~/mail/.notmuch/hooks/post-new :shebang "#!/bin/sh"
2146 # apply sent tag to messages sent by me
2147 notmuch tag -new +sent -- from:amin@aminb.org or from:aminb@gnu.org or from:abandali@uwaterloo.ca or from:amin.bandali@uwaterloo.ca
2150 notmuch tag -latest -- tag:latest
2151 notmuch tag +inbox +unread +latest -new -- tag:new
2154 # apply tags to lists
2157 notmuch tag -inbox +lists/~sircmpwn/srht-admins -- folder:amin/lists/~sircmpwn/srht-admins
2158 notmuch tag -inbox +lists/~sircmpwn/srht-announce -- folder:amin/lists/~sircmpwn/srht-announce
2159 notmuch tag -inbox +lists/~sircmpwn/srht-dev -- folder:amin/lists/~sircmpwn/srht-dev
2160 notmuch tag -inbox +lists/~sircmpwn/srht-discuss -- folder:amin/lists/~sircmpwn/srht-discuss
2162 notmuch tag -inbox +lists/hackernewsletter -- folder:amin/lists/hackernewsletter
2163 notmuch tag -inbox +lists/haskell-weekly -- folder:amin/lists/haskell-weekly
2165 notmuch tag -inbox +pay -- folder:amin/pay
2169 notmuch tag -inbox +uw/cs136 -- folder:uwaterloo/lists/cs136
2170 notmuch tag -inbox +uw/se463 -- folder:uwaterloo/lists/se463
2172 notmuch tag -inbox +lists/clvsingle -- folder:uwaterloo/lists/Clvsingle
2173 notmuch tag -inbox +lists/gsa -- folder:uwaterloo/lists/GSA
2174 notmuch tag -inbox +lists/math-grad -- folder:uwaterloo/lists/Math-grad
2175 notmuch tag -inbox +lists/scs-grads -- folder:uwaterloo/lists/scs-grads
2176 notmuch tag -inbox +lists/watform-students -- folder:uwaterloo/lists/Watform-students
2180 notmuch tag -inbox +lists/emacs-devel -- folder:gnu/l/emacs-devel
2181 notmuch tag -inbox +lists/emacs-orgmode -- folder:gnu/l/emacs-orgmode
2182 notmuch tag -inbox +lists/emacsconf-discuss -- folder:gnu/l/emacsconf-discuss
2183 notmuch tag -inbox +lists/fencepost-users -- folder:gnu/l/fencepost-users
2184 notmuch tag -inbox +lists/guix-devel -- folder:gnu/l/guix-devel
2185 notmuch tag -inbox +lists/guile-devel -- folder:gnu/l/guile-devel
2186 notmuch tag -inbox +lists/help-gnu-emacs -- folder:gnu/l/help-gnu-emacs
2187 notmuch tag -inbox +lists/info-gnu-emacs -- folder:gnu/l/info-gnu-emacs
2188 notmuch tag -inbox +lists/www-commits -- folder:gnu/l/www-commits
2189 notmuch tag -inbox +lists/www-discuss -- folder:gnu/l/www-discuss
2190 notmuch tag -inbox +webmasters -- folder:gnu/webmasters
2192 notmuch tag -inbox +lists/deepspec -- folder:gnu/l/deepspec
2193 notmuch tag -inbox +lists/haskell-cafe -- folder:gnu/l/haskell-cafe
2194 notmuch tag -inbox +lists/haskell-art -- folder:gnu/l/haskell-art
2195 notmuch tag -inbox +lists/notmuch -- folder:gnu/l/notmuch
2198 notmuch tag -inbox -unread +archive/notmuch -- path:archive/notmuch/**
2199 notmuch tag -inbox -unread +archive/emacs-devel -- path:archive/emacs-devel/**
2204 :header-args+: :tangle ~/.config/systemd/user/notmuch.service
2207 #+begin_src conf :tangle no
2209 Description=notmuch service
2213 ExecStart=/usr/bin/notmuch new
2214 StandardOutput=syslog
2215 StandardError=syslog
2220 :header-args+: :tangle ~/.config/systemd/user/notmuch.timer
2223 #+begin_src conf :tangle no
2225 Description=notmuch timer
2230 Unit=notmuch.service
2233 WantedBy=timers.target
2240 :header-args+: :tangle ~/.offlineimaprc
2243 #+begin_src conf :tangle no
2245 pythonfile = ~/.offlineimap.py
2246 accounts = Gmail, aminb
2250 localrepository = GmailL
2251 remoterepository = GmailR
2254 localrepository = aminbL
2255 remoterepository = aminbR
2259 localfolders = ~/Maildir/Gmail
2263 remotehost = imap.gmail.com
2264 remoteusereval = mailuser("gmail")
2265 remotepasseval = mailpasswd("gmail")
2266 sslcacertfile = /etc/ssl/certs/ca-certificates.crt
2268 folderfilter = lambda foldername: foldername not in '[Gmail]/All Mail'
2274 localfolders = ~/Maildir/aminb
2278 remotehost = mail.aminb.org
2279 remoteusereval = mailuser("aminb")
2280 remotepasseval = mailpasswd("aminb")
2281 sslcacertfile = /etc/ssl/certs/ca-certificates.crt
2283 folderfilter = lambda foldername: foldername not in 'dovecot.sieve'
2290 :header-args+: :tangle ~/.offlineimap.py
2293 #+begin_src python :tangle no
2297 def mailpasswd(acct):
2298 acct = os.path.basename(acct)
2299 path = "/home/amin/.passwd/%s.gpg" % acct
2300 args = ["gpg", "--use-agent", "--quiet", "--batch", "-d", path]
2302 return subprocess.check_output(args).strip()
2303 except subprocess.CalledProcessError:
2307 acct = os.path.basename(acct)
2308 path = "/home/amin/.passwd/%s" % acct
2309 args = ["cat", path]
2311 return subprocess.check_output(args).strip()
2312 except subprocess.CalledProcessError:
2315 def prime_gpg_agent():
2319 ret = (mailpasswd("prime") == "prime")
2321 from offlineimap.ui import getglobalui
2322 sys.stderr.write("Error reading in passwords. Terminating.\n")
2323 getglobalui().terminate()
2333 :header-args+: :tangle ~/sieve/gnu.sieve :comments none
2337 require [ "regex", "variables", "fileinto", "envelope", "mailbox", "imap4flags", "include" ];
2340 address :is "from" "webmasters@gnu.org",
2341 address :is "from" "webmasters-comment@gnu.org") {
2342 fileinto :create "webmasters";
2346 include :personal "lists";
2351 :header-args+: :tangle ~/sieve/lists.sieve :comments none
2355 require [ "regex", "variables", "fileinto", "envelope", "mailbox", "imap4flags",
2359 header :contains "list-id" "<emacs-devel.gnu.org>",
2360 header :contains "list-id" "<emacs-orgmode.gnu.org>",
2361 header :contains "list-id" "<emacsconf-discuss.gnu.org>",
2362 header :contains "list-id" "<fencepost-users.gnu.org>",
2363 header :contains "list-id" "<guix-devel.gnu.org>",
2364 header :contains "list-id" "<guile-devel.gnu.org>",
2365 header :contains "list-id" "<help-gnu-emacs.gnu.org>",
2366 header :contains "list-id" "<info-gnu-emacs.gnu.org>",
2367 header :contains "list-id" "<www-commits.gnu.org>",
2368 header :contains "list-id" "<www-discuss.gnu.org>",
2369 header :contains "list-id" "<deepspec.lists.cs.princeton.edu>",
2370 header :contains "list-id" "<haskell-cafe.haskell.org>",
2371 header :contains "list-id" "<haskell-art.we.lurk.org>",
2372 header :contains "list-id" "<notmuch.notmuchmail.org>") {
2373 if header :regex "list-id" "<([a-z_0-9-]+)[.@]" {
2374 set :lower "listname" "${1}";
2375 fileinto :create "l/${listname}";
2384 :header-args+: :tangle ~/.config/polybar/config
2387 #+begin_src conf :tangle no
2388 ;=====================================================
2390 ; To learn more about how to configure Polybar
2391 ; go to https://github.com/jaagr/polybar
2393 ; The README contains alot of information
2395 ;=====================================================
2398 ;background = ${xrdb:color0:#222}
2400 background-alt = #444
2401 ;foreground = ${xrdb:color7:#222}
2403 foreground-alt = #888
2409 ;monitor = ${env:MONITOR:HDMI-1}
2417 background = ${colors.background}
2418 foreground = ${colors.foreground}
2424 border-color = #00000000
2429 module-margin-left = 2
2430 module-margin-right = 2
2432 font-0 = Ubuntu:fontformat=truetype:antialias=true:pixelsize=9;1
2433 font-1 = unifont:fontformat=truetype:size=8:antialias=false;0
2434 font-2 = Wuncon Siji:pixelsize=10;1
2435 font-3 = FontAwesome:pixelsize=10;1
2437 modules-left = bspwm xwindow
2439 modules-right = volume filesystem mail xkeyboard memory cpu temperature date powermenu
2441 tray-position = right
2443 ;tray-transparent = true
2444 ;tray-background = #0063ff
2449 ;override-redirect = true
2451 scroll-up = bspwm-desknext
2452 scroll-down = bspwm-deskprev
2455 type = internal/xwindow
2456 label = %title:0:50:...%
2459 type = internal/xkeyboard
2460 blacklist-0 = num lock
2462 format-prefix = " "
2463 format-prefix-foreground = ${colors.foreground-alt}
2464 format-prefix-underline = ${colors.secondary}
2466 label-layout = %layout%
2467 label-layout-underline = ${colors.secondary}
2469 label-indicator-padding = 2
2470 label-indicator-margin = 1
2471 label-indicator-background = ${colors.secondary}
2472 label-indicator-underline = ${colors.secondary}
2480 label-mounted = %{F#0a81f5}%mountpoint%%{F-}: %percentage_used%%
2481 label-unmounted = %mountpoint% not mounted
2482 label-unmounted-foreground = ${colors.foreground-alt}
2485 type = internal/bspwm
2487 label-focused = %index%
2488 label-focused-background = ${colors.background-alt}
2489 label-focused-underline= ${colors.primary}
2490 label-focused-padding = 2
2492 label-occupied = %index%
2493 label-occupied-padding = 2
2495 label-urgent = %index%!
2496 label-urgent-background = ${colors.alert}
2497 label-urgent-padding = 2
2499 label-empty = %index%
2500 label-empty-foreground = ${colors.foreground-alt}
2501 label-empty-padding = 2
2505 format = <label-state> <label-mode>
2507 wrapping-scroll = false
2509 ; Only show workspaces on the same output as the bar
2510 ;pin-workspaces = true
2512 label-mode-padding = 2
2513 label-mode-foreground = #000
2514 label-mode-background = ${colors.primary}
2516 ; focused = Active workspace on focused monitor
2517 label-focused = %index%
2518 label-focused-background = ${module/bspwm.label-focused-background}
2519 label-focused-underline = ${module/bspwm.label-focused-underline}
2520 label-focused-padding = ${module/bspwm.label-focused-padding}
2522 ; unfocused = Inactive workspace on any monitor
2523 label-unfocused = %index%
2524 label-unfocused-padding = ${module/bspwm.label-occupied-padding}
2526 ; visible = Active workspace on unfocused monitor
2527 label-visible = %index%
2528 label-visible-background = ${self.label-focused-background}
2529 label-visible-underline = ${self.label-focused-underline}
2530 label-visible-padding = ${self.label-focused-padding}
2532 ; urgent = Workspace with urgency hint set
2533 label-urgent = %index%
2534 label-urgent-background = ${module/bspwm.label-urgent-background}
2535 label-urgent-padding = ${module/bspwm.label-urgent-padding}
2539 format-online = <label-song> <icon-prev> <icon-stop> <toggle> <icon-next>
2547 label-song-maxlen = 25
2548 label-song-ellipsis = true
2551 type = internal/xbacklight
2553 format = <label> <bar>
2558 bar-indicator-foreground = #ff
2559 bar-indicator-font = 2
2562 bar-fill-foreground = #9f78e1
2565 bar-empty-foreground = ${colors.foreground-alt}
2567 [module/backlight-acpi]
2568 inherit = module/xbacklight
2569 type = internal/backlight
2570 ;card = intel_backlight
2571 card = mba6x_backlight
2576 format-prefix = " "
2577 format-prefix-foreground = ${colors.foreground-alt}
2578 format-underline = #f90000
2579 label = %percentage%%
2582 type = internal/memory
2584 format-prefix = " "
2585 format-prefix-foreground = ${colors.foreground-alt}
2586 format-underline = #4bffdc
2587 label = %percentage_used%%
2590 type = internal/network
2594 format-connected = <ramp-signal> <label-connected>
2595 format-connected-underline = #9f78e1
2596 label-connected = %essid%
2598 format-disconnected =
2599 ;format-disconnected = <label-disconnected>
2600 ;format-disconnected-underline = ${self.format-connected-underline}
2601 ;label-disconnected = %ifname% disconnected
2602 ;label-disconnected-foreground = ${colors.foreground-alt}
2609 ramp-signal-foreground = ${colors.foreground-alt}
2612 type = internal/network
2616 format-connected-underline = #55aa55
2617 format-connected-prefix = " "
2618 format-connected-prefix-foreground = ${colors.foreground-alt}
2619 label-connected = %local_ip%
2621 format-disconnected =
2622 ;format-disconnected = <label-disconnected>
2623 ;format-disconnected-underline = ${self.format-connected-underline}
2624 ;label-disconnected = %ifname% disconnected
2625 ;label-disconnected-foreground = ${colors.foreground-alt}
2628 type = internal/date
2632 date-alt = " %Y-%m-%d"
2638 format-prefix-foreground = ${colors.foreground-alt}
2639 format-underline = #0a6cf5
2641 label = %date% %time%
2644 type = internal/volume
2646 format-volume = <label-volume> <bar-volume>
2648 label-volume-foreground = ${root.foreground}
2650 format-muted-prefix = " "
2651 format-muted-foreground = ${colors.foreground-alt}
2654 bar-volume-width = 10
2655 bar-volume-foreground-0 = #55aa55
2656 bar-volume-foreground-1 = #55aa55
2657 bar-volume-foreground-2 = #55aa55
2658 bar-volume-foreground-3 = #55aa55
2659 bar-volume-foreground-4 = #55aa55
2660 bar-volume-foreground-5 = #f5a70a
2661 bar-volume-foreground-6 = #ff5555
2662 bar-volume-gradient = false
2663 bar-volume-indicator = |
2664 bar-volume-indicator-font = 2
2666 bar-volume-fill-font = 2
2667 bar-volume-empty = ─
2668 bar-volume-empty-font = 2
2669 bar-volume-empty-foreground = ${colors.foreground-alt}
2672 type = internal/battery
2677 format-charging = <animation-charging> <label-charging>
2678 format-charging-underline = #ffb52a
2680 format-discharging = <ramp-capacity> <label-discharging>
2681 format-discharging-underline = ${self.format-charging-underline}
2683 format-full-prefix = " "
2684 format-full-prefix-foreground = ${colors.foreground-alt}
2685 format-full-underline = ${self.format-charging-underline}
2690 ramp-capacity-foreground = ${colors.foreground-alt}
2692 animation-charging-0 =
2693 animation-charging-1 =
2694 animation-charging-2 =
2695 animation-charging-foreground = ${colors.foreground-alt}
2696 animation-charging-framerate = 750
2698 [module/temperature]
2699 type = internal/temperature
2701 warn-temperature = 66
2703 format = <ramp> <label>
2704 format-underline = #f50a4d
2705 format-warn = <ramp> <label-warn>
2706 format-warn-underline = ${self.format-underline}
2708 label = %temperature%
2709 label-warn = %temperature%
2710 label-warn-foreground = ${colors.secondary}
2715 ramp-foreground = ${colors.foreground-alt}
2723 label-open-foreground = ${colors.secondary}
2724 label-close = cancel
2725 label-close-foreground = ${colors.secondary}
2727 label-separator-foreground = ${colors.foreground-alt}
2730 menu-0-0-exec = menu-open-1
2731 menu-0-1 = power off
2732 menu-0-1-exec = menu-open-2
2735 menu-1-0-exec = menu-open-0
2737 menu-1-1-exec = sudo reboot
2739 menu-2-0 = power off
2740 menu-2-0-exec = sudo poweroff
2742 menu-2-1-exec = menu-open-0
2745 type = custom/script
2748 format-prefix = " "
2749 format-prefix-foreground = ${colors.foreground-alt}
2750 format-underline = #0a6cf5
2751 exec = notmuch count tag:unread
2754 screenchange-reload = true
2755 ;compositing-background = xor
2756 ;compositing-background = screen
2757 ;compositing-foreground = source
2758 ;compositing-border = over
2769 :header-args+: :tangle ~/.local/bin/polybar-launch :shebang "#!/usr/bin/env sh"
2772 #+begin_src sh :tangle no
2773 # Terminate already running bar instances
2776 # Wait until the processes have been shut down
2777 while pgrep -x polybar >/dev/null; do sleep 1; done
2782 echo "Bars launched..."
2787 :header-args+: :tangle "/sudo::/etc/systemd/system/powertop.service"
2792 Description=Powertop tunings
2795 ExecStart=/usr/bin/powertop --auto-tune
2796 RemainAfterExit=true
2799 WantedBy=multi-user.target
2806 :header-args+: :tangle ~/.config/ranger/rc.conf
2809 #+begin_src conf :tangle no
2810 # ===================================================================
2811 # This file contains the default startup commands for ranger.
2812 # To change them, it is recommended to create the file
2813 # ~/.config/ranger/rc.conf and add your custom commands there.
2815 # If you copy this whole file there, you may want to set the environment
2816 # variable RANGER_LOAD_DEFAULT_RC to FALSE to avoid loading it twice.
2818 # The purpose of this file is mainly to define keybindings and settings.
2819 # For running more complex python code, please create a plugin in "plugins/" or
2820 # a command in "commands.py".
2822 # Each line is a command that will be run before the user interface
2823 # is initialized. As a result, you can not use commands which rely
2824 # on the UI such as :delete or :mark.
2825 # ===================================================================
2827 # ===================================================================
2829 # ===================================================================
2831 # How many columns are there, and what are their relative widths?
2832 set column_ratios 1,3,4
2834 # Which files should be hidden? (regular expression)
2835 set hidden_filter ^\.|\.(?:pyc|pyo|bak|swp)$|^lost\+found$|^__(py)?cache__$
2837 # Show hidden files? You can toggle this by typing 'zh'
2838 set show_hidden false
2840 # Ask for a confirmation when running the "delete" command?
2841 # Valid values are "always" (default), "never", "multiple"
2842 # With "multiple", ranger will ask only if you delete multiple files at once.
2843 set confirm_on_delete multiple
2845 # Which script is used to generate file previews?
2846 # ranger ships with scope.sh, a script that calls external programs (see
2847 # README for dependencies) to preview images, archives, etc.
2848 set preview_script ~/.config/ranger/scope.sh
2850 # Use the external preview script or display simple plain text previews?
2851 set use_preview_script true
2853 # Open all images in this directory when running certain image viewers
2854 # like feh or sxiv? You can still open selected files by marking them.
2855 set open_all_images true
2857 # Be aware of version control systems and display information.
2860 # State of the three backends git, hg, bzr. The possible states are
2861 # disabled, local (only show local info), enabled (show local and remote
2863 set vcs_backend_git enabled
2864 set vcs_backend_hg disabled
2865 set vcs_backend_bzr disabled
2867 # Preview images in full color with the external command "w3mimgpreview"?
2868 # This requires the console web browser "w3m" and a supported terminal.
2869 # It has been successfully tested with "xterm" and "urxvt" without tmux.
2870 set preview_images true
2872 # Use a unicode "..." character to mark cut-off filenames?
2873 set unicode_ellipsis false
2875 # Show dotfiles in the bookmark preview box?
2876 set show_hidden_bookmarks true
2878 # Which colorscheme to use? These colorschemes are available by default:
2879 # default, jungle, snow
2880 set colorscheme default
2882 # Preview files on the rightmost column?
2883 # And collapse (shrink) the last column if there is nothing to preview?
2884 set preview_files true
2885 set preview_directories true
2886 set collapse_preview true
2888 # Save the console history on exit?
2889 set save_console_history true
2891 # Draw the status bar on top of the browser window (default: bottom)
2892 set status_bar_on_top false
2894 # Draw a progress bar in the status bar which displays the average state of all
2895 # currently running tasks which support progress bars?
2896 set draw_progress_bar_in_status_bar true
2898 # Draw borders around columns?
2899 set draw_borders true
2901 # Display the directory name in tabs?
2902 set dirname_in_tabs false
2904 # Enable the mouse support?
2905 set mouse_enabled true
2907 # Display the file size in the main column or status bar?
2908 set display_size_in_main_column true
2909 set display_size_in_status_bar true
2911 # Display files tags in all columns or only in main column?
2912 set display_tags_in_all_columns true
2914 # Set a title for the window?
2915 set update_title false
2917 # Set the title to "ranger" in the tmux program?
2918 set update_tmux_title false
2920 # Shorten the title if it gets long? The number defines how many
2921 # directories are displayed at once, 0 turns off this feature.
2924 # Abbreviate $HOME with ~ in the titlebar (first line) of ranger?
2925 set tilde_in_titlebar false
2927 # How many directory-changes or console-commands should be kept in history?
2928 set max_history_size 20
2929 set max_console_history_size 50
2931 # Try to keep so much space between the top/bottom border when scrolling:
2934 # Flush the input after each key hit? (Noticable when ranger lags)
2937 # Padding on the right when there's no preview?
2938 # This allows you to click into the space to run the file.
2939 set padding_right true
2941 # Save bookmarks (used with mX and `X) instantly?
2942 # This helps to synchronize bookmarks between multiple ranger
2943 # instances but leads to *slight* performance loss.
2944 # When false, bookmarks are saved when ranger is exited.
2945 set autosave_bookmarks true
2947 # You can display the "real" cumulative size of directories by using the
2948 # command :get_cumulative_size or typing "dc". The size is expensive to
2949 # calculate and will not be updated automatically. You can choose
2950 # to update it automatically though by turning on this option:
2951 set autoupdate_cumulative_size false
2953 # Turning this on makes sense for screen readers:
2954 set show_cursor false
2956 # One of: size, basename, mtime, type
2959 # Additional sorting options
2960 set sort_reverse false
2961 set sort_case_insensitive true
2962 set sort_directories_first true
2964 # Enable this if key combinations with the Alt Key don't work for you.
2965 # (Especially on xterm)
2966 set xterm_alt_key false
2968 # ===================================================================
2970 # ===================================================================
2971 # You can set local options that only affect a single directory.
2974 # setlocal path=~/downloads sort mtime
2976 # ===================================================================
2977 # == Command Aliases in the Console
2978 # ===================================================================
2986 alias filter scout -prt
2987 alias find scout -aet
2988 alias mark scout -mr
2989 alias unmark scout -Mr
2990 alias search scout -rs
2991 alias search_inc scout -rts
2992 alias travel scout -aefiklst
2994 # ===================================================================
2995 # == Define keys for the browser
2996 # ===================================================================
3005 map <C-l> redraw_window
3007 map <esc> change_mode normal
3018 map @ console -p6 shell %%s
3019 map # console shell -p
3021 map r chain draw_possible_programs; console open_with
3028 map "<any> tag_toggle tag=%any
3029 map <Space> mark_files toggle=True
3030 map v mark_files all=True toggle=True
3031 map uv mark_files all=True val=False
3032 map V toggle_visual_mode
3033 map uV toggle_visual_mode reverse=True
3035 # For the nostalgics: Midnight Commander bindings
3037 map <F3> display_file
3041 map <F7> console mkdir
3042 map <F8> console delete
3045 # In case you work on a keyboard with dvorak layout
3047 map <DOWN> move down=1
3048 map <LEFT> move left=1
3049 map <RIGHT> move right=1
3050 map <HOME> move to=0
3051 map <END> move to=-1
3052 map <PAGEDOWN> move down=1 pages=True
3053 map <PAGEUP> move up=1 pages=True
3054 map <CR> move right=1
3055 map <DELETE> console delete
3056 map <INSERT> console touch
3065 copymap <PAGEDOWN> <C-F>
3066 copymap <PAGEUP> <C-B>
3068 map J move down=0.5 pages=True
3069 map K move up=0.5 pages=True
3077 map [ move_parent -1
3092 map gR eval fm.cd(ranger.RANGERDIR)
3094 map g? cd /usr/share/doc/ranger
3098 map du shell -p du --max-depth=1 -h --apparent-size
3099 map dU shell -p du --max-depth=1 -h --apparent-size | sort -rh
3100 map yp shell -d echo -n %d/%f | xsel -i
3101 map yd shell -d echo -n %d | xsel -i
3102 map yn shell -d echo -n %f | xsel -i
3104 # Filesystem Operations
3107 map cw console rename
3108 map A eval fm.open_console('rename ' + fm.thisfile.basename)
3109 map I eval fm.open_console('rename ' + fm.thisfile.basename, position=7)
3112 map po paste overwrite=True
3113 map pl paste_symlink relative=False
3114 map pL paste_symlink relative=True
3115 map phl paste_hardlink
3116 map pht paste_hardlinked_subtree
3121 map dr cut mode=remove
3125 map ya copy mode=add
3126 map yr copy mode=remove
3128 # Temporary workarounds
3129 map dgg eval fm.cut(dirarg=dict(to=0), narg=quantifier)
3130 map dG eval fm.cut(dirarg=dict(to=-1), narg=quantifier)
3131 map dj eval fm.cut(dirarg=dict(down=1), narg=quantifier)
3132 map dk eval fm.cut(dirarg=dict(up=1), narg=quantifier)
3133 map ygg eval fm.copy(dirarg=dict(to=0), narg=quantifier)
3134 map yG eval fm.copy(dirarg=dict(to=-1), narg=quantifier)
3135 map yj eval fm.copy(dirarg=dict(down=1), narg=quantifier)
3136 map yk eval fm.copy(dirarg=dict(up=1), narg=quantifier)
3139 map / console search
3141 map N search_next forward=False
3142 map ct search_next order=tag
3143 map cs search_next order=size
3144 map ci search_next order=mimetype
3145 map cc search_next order=ctime
3146 map cm search_next order=mtime
3147 map ca search_next order=atime
3152 map <TAB> tab_move 1
3153 map <S-TAB> tab_move -1
3154 map <A-Right> tab_move 1
3155 map <A-Left> tab_move -1
3161 map <a-1> tab_open 1
3162 map <a-2> tab_open 2
3163 map <a-3> tab_open 3
3164 map <a-4> tab_open 4
3165 map <a-5> tab_open 5
3166 map <a-6> tab_open 6
3167 map <a-7> tab_open 7
3168 map <a-8> tab_open 8
3169 map <a-9> tab_open 9
3172 map or toggle_option sort_reverse
3173 map os chain set sort=size; set sort_reverse=False
3174 map ob chain set sort=basename; set sort_reverse=False
3175 map on chain set sort=natural; set sort_reverse=False
3176 map om chain set sort=mtime; set sort_reverse=False
3177 map oc chain set sort=ctime; set sort_reverse=False
3178 map oa chain set sort=atime; set sort_reverse=False
3179 map ot chain set sort=type; set sort_reverse=False
3181 map oS chain set sort=size; set sort_reverse=True
3182 map oB chain set sort=basename; set sort_reverse=True
3183 map oN chain set sort=natural; set sort_reverse=True
3184 map oM chain set sort=mtime; set sort_reverse=True
3185 map oC chain set sort=ctime; set sort_reverse=True
3186 map oA chain set sort=atime; set sort_reverse=True
3187 map oT chain set sort=type; set sort_reverse=True
3189 map dc get_cumulative_size
3192 map zc toggle_option collapse_preview
3193 map zd toggle_option sort_directories_first
3194 map zh toggle_option show_hidden
3195 map <C-h> toggle_option show_hidden
3196 map zi toggle_option flushinput
3197 map zm toggle_option mouse_enabled
3198 map zp toggle_option preview_files
3199 map zP toggle_option preview_directories
3200 map zs toggle_option sort_case_insensitive
3201 map zu toggle_option autoupdate_cumulative_size
3202 map zv toggle_option use_preview_script
3203 map zf console filter
3206 map `<any> enter_bookmark %any
3207 map '<any> enter_bookmark %any
3208 map m<any> set_bookmark %any
3209 map um<any> unset_bookmark %any
3211 map m<bg> draw_bookmarks
3212 copymap m<bg> um<bg> `<bg> '<bg>
3214 # Generate all the chmod bindings with some python help:
3215 eval for arg in "rwxXst": cmd("map +u{0} shell -d chmod u+{0} %s".format(arg))
3216 eval for arg in "rwxXst": cmd("map +g{0} shell -d chmod g+{0} %s".format(arg))
3217 eval for arg in "rwxXst": cmd("map +o{0} shell -d chmod o+{0} %s".format(arg))
3218 eval for arg in "rwxXst": cmd("map +a{0} shell -d chmod a+{0} %s".format(arg))
3219 eval for arg in "rwxXst": cmd("map +{0} shell -d chmod u+{0} %s".format(arg))
3221 eval for arg in "rwxXst": cmd("map -u{0} shell -d chmod u-{0} %s".format(arg))
3222 eval for arg in "rwxXst": cmd("map -g{0} shell -d chmod g-{0} %s".format(arg))
3223 eval for arg in "rwxXst": cmd("map -o{0} shell -d chmod o-{0} %s".format(arg))
3224 eval for arg in "rwxXst": cmd("map -a{0} shell -d chmod a-{0} %s".format(arg))
3225 eval for arg in "rwxXst": cmd("map -{0} shell -d chmod u-{0} %s".format(arg))
3227 # ===================================================================
3228 # == Define keys for the console
3229 # ===================================================================
3230 # Note: Unmapped keys are passed directly to the console.
3233 cmap <tab> eval fm.ui.console.tab()
3234 cmap <s-tab> eval fm.ui.console.tab(-1)
3235 cmap <ESC> eval fm.ui.console.close()
3236 cmap <CR> eval fm.ui.console.execute()
3237 cmap <C-l> redraw_window
3239 copycmap <ESC> <C-c>
3243 cmap <up> eval fm.ui.console.history_move(-1)
3244 cmap <down> eval fm.ui.console.history_move(1)
3245 cmap <left> eval fm.ui.console.move(left=1)
3246 cmap <right> eval fm.ui.console.move(right=1)
3247 cmap <home> eval fm.ui.console.move(right=0, absolute=True)
3248 cmap <end> eval fm.ui.console.move(right=-1, absolute=True)
3251 cmap <backspace> eval fm.ui.console.delete(-1)
3252 cmap <delete> eval fm.ui.console.delete(0)
3253 cmap <C-w> eval fm.ui.console.delete_word()
3254 cmap <C-k> eval fm.ui.console.delete_rest(1)
3255 cmap <C-u> eval fm.ui.console.delete_rest(-1)
3256 cmap <C-y> eval fm.ui.console.paste()
3258 # And of course the emacs way
3260 copycmap <down> <C-n>
3261 copycmap <left> <C-b>
3262 copycmap <right> <C-f>
3263 copycmap <home> <C-a>
3264 copycmap <end> <C-e>
3265 copycmap <delete> <C-d>
3266 copycmap <backspace> <C-h>
3268 # Note: There are multiple ways to express backspaces. <backspace> (code 263)
3269 # and <backspace2> (code 127). To be sure, use both.
3270 copycmap <backspace> <backspace2>
3272 # This special expression allows typing in numerals:
3273 cmap <allow_quantifiers> false
3275 # ===================================================================
3276 # == Pager Keybindings
3277 # ===================================================================
3280 pmap <down> pager_move down=1
3281 pmap <up> pager_move up=1
3282 pmap <left> pager_move left=4
3283 pmap <right> pager_move right=4
3284 pmap <home> pager_move to=0
3285 pmap <end> pager_move to=-1
3286 pmap <pagedown> pager_move down=1.0 pages=True
3287 pmap <pageup> pager_move up=1.0 pages=True
3288 pmap <C-d> pager_move down=0.5 pages=True
3289 pmap <C-u> pager_move up=0.5 pages=True
3291 copypmap <UP> k <C-p>
3292 copypmap <DOWN> j <C-n> <CR>
3299 copypmap <PAGEDOWN> n f <C-F> <Space>
3300 copypmap <PAGEUP> p b <C-B>
3303 pmap <ESC> pager_close
3304 copypmap <ESC> q Q i <F3>
3307 # ===================================================================
3308 # == Taskview Keybindings
3309 # ===================================================================
3312 tmap <up> taskview_move up=1
3313 tmap <down> taskview_move down=1
3314 tmap <home> taskview_move to=0
3315 tmap <end> taskview_move to=-1
3316 tmap <pagedown> taskview_move down=1.0 pages=True
3317 tmap <pageup> taskview_move up=1.0 pages=True
3318 tmap <C-d> taskview_move down=0.5 pages=True
3319 tmap <C-u> taskview_move up=0.5 pages=True
3321 copytmap <UP> k <C-p>
3322 copytmap <DOWN> j <C-n> <CR>
3326 copytmap <PAGEDOWN> n f <C-F> <Space>
3327 copytmap <PAGEUP> p b <C-B>
3329 # Changing priority and deleting tasks
3330 tmap J eval -q fm.ui.taskview.task_move(-1)
3331 tmap K eval -q fm.ui.taskview.task_move(0)
3332 tmap dd eval -q fm.ui.taskview.task_remove()
3333 tmap <pagedown> eval -q fm.ui.taskview.task_move(-1)
3334 tmap <pageup> eval -q fm.ui.taskview.task_move(0)
3335 tmap <delete> eval -q fm.ui.taskview.task_remove()
3338 tmap <ESC> taskview_close
3339 copytmap <ESC> q Q w <C-c>
3344 :header-args+: :tangle ~/.config/ranger/scope.sh :shebang "#!/usr/bin/env sh"
3347 #+begin_src sh :tangle no
3348 # ranger supports enhanced previews. If the option "use_preview_script"
3349 # is set to True and this file exists, this script will be called and its
3350 # output is displayed in ranger. ANSI color codes are supported.
3352 # NOTES: This script is considered a configuration file. If you upgrade
3353 # ranger, it will be left untouched. (You must update it yourself.)
3354 # Also, ranger disables STDIN here, so interactive scripts won't work properly
3356 # Meanings of exit codes:
3357 # code | meaning | action of ranger
3358 # -----+------------+-------------------------------------------
3359 # 0 | success | success. display stdout as preview
3360 # 1 | no preview | failure. display no preview at all
3361 # 2 | plain text | display the plain content of the file
3362 # 3 | fix width | success. Don't reload when width changes
3363 # 4 | fix height | success. Don't reload when height changes
3364 # 5 | fix both | success. Don't ever reload
3366 # Meaningful aliases for arguments:
3367 path="$1" # Full path of the selected file
3368 width="$2" # Width of the preview pane (number of fitting characters)
3369 height="$3" # Height of the preview pane (number of fitting characters)
3371 maxln=200 # Stop after $maxln lines. Can be used like ls | head -n $maxln
3373 # Find out something about the file:
3374 mimetype=$(file --mime-type -Lb "$path")
3375 extension=${path##*.}
3378 # runs a command and saves its output into $output. Useful if you need
3379 # the return value AND want to use the output in a pipe
3380 try() { output=$(eval '"$@"'); }
3382 # writes the output of the previouosly used "try" command
3383 dump() { echo "$output"; }
3385 # a common post-processing function used after most commands
3386 trim() { head -n "$maxln"; }
3388 # wraps highlight to treat exit code 141 (killed by SIGPIPE) as success
3389 highlight() { command highlight "$@"; test $? = 0 -o $? = 141; }
3391 case "$extension" in
3392 # Archive extensions:
3393 7z|a|ace|alz|arc|arj|bz|bz2|cab|cpio|deb|gz|jar|lha|lz|lzh|lzma|lzo|\
3394 rpm|rz|t7z|tar|tbz|tbz2|tgz|tlz|txz|tZ|tzo|war|xpi|xz|Z|zip)
3395 try als "$path" && { dump | trim; exit 0; }
3396 try acat "$path" && { dump | trim; exit 3; }
3397 try bsdtar -lf "$path" && { dump | trim; exit 0; }
3400 try unrar -p- lt "$path" && { dump | trim; exit 0; } || exit 1;;
3403 try pdftotext -l 10 -nopgbrk -q "$path" - && \
3404 { dump | trim | fmt -s -w $width; exit 0; } || exit 1;;
3407 try transmission-show "$path" && { dump | trim; exit 5; } || exit 1;;
3410 try w3m -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3411 try lynx -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3412 try elinks -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3413 ;; # fall back to highlight/cat if the text browsers fail
3417 # Syntax highlight for text files:
3419 try highlight --out-format=ansi "$path" && { dump | trim; exit 5; } || exit 2;;
3420 # Ascii-previews of images:
3422 img2txt --gamma=0.6 --width="$width" "$path" && exit 4 || exit 1;;
3423 # Display information about media files:
3425 exiftool "$path" && exit 5
3426 # Use sed to remove spaces so the output fits into the narrow window
3427 try mediainfo "$path" && { dump | trim | sed 's/ \+:/: /;'; exit 5; } || exit 1;;
3435 :header-args+: :tangle ~/.config/redshift.conf :comments none
3439 ; Global settings for redshift
3441 ; Set the day and night screen temperatures (Neutral is 6500K)
3452 ; Enable/Disable a smooth transition between day and night
3453 ; 0 will cause a direct change from day to night screen temperature.
3454 ; 1 will gradually increase or decrease the screen temperature.
3457 ; Set the screen brightness. Default is 1.0.
3459 ; It is also possible to use different settings for day and night
3460 ; since version 1.8.
3462 ;brightness-night=0.4
3463 ; Set the screen gamma (for all colors, or each color channel
3468 ; This can also be set individually for day and night since
3470 ;gamma-day=0.8:0.7:0.8
3473 ; Set the location-provider: 'geoclue2' or 'manual'
3474 ; type 'redshift -l list' to see possible values.
3475 ; The location provider settings are in a different section.
3476 ;location-provider=manual
3477 location-provider=geoclue2
3479 ; Set the adjustment-method: 'randr', 'vidmode'
3480 ; type 'redshift -m list' to see all possible values.
3481 ; 'randr' is the preferred method, 'vidmode' is an older API.
3482 ; but works in some cases when 'randr' does not.
3483 ; The adjustment method settings are in a different section.
3484 adjustment-method=randr
3486 ; Configuration of the location-provider:
3487 ; type 'redshift -l PROVIDER:help' to see the settings.
3488 ; ex: 'redshift -l manual:help'
3489 ; Keep in mind that longitudes west of Greenwich (e.g. the Americas)
3490 ; are negative numbers.
3495 ; Configuration of the adjustment-method
3496 ; type 'redshift -m METHOD:help' to see the settings.
3497 ; ex: 'redshift -m randr:help'
3498 ; In this example, randr is configured to adjust screen 1.
3499 ; Note that the numbering starts from 0, so this is actually the
3500 ; second screen. If this option is not specified, Redshift will try
3501 ; to adjust _all_ screens.
3508 :header-args+: :tangle ~/.config/rofi/config
3512 rofi.font: Ubuntu Mono 13
3513 ! rofi.font: Inconsolata 16
3514 ! rofi.font: Iosevka 13
3515 ! rofi.font: Source Code Pro 11
3516 rofi.modi: run,window
3524 !rofi.theme: /usr/share/rofi/themes//Arc.rasi
3525 !rofi.theme: /usr/share/rofi/themes//Paper.rasi
3526 !rofi.theme: /usr/share/rofi/themes//sidebar.rasi
3528 rofi.theme: /usr/share/rofi/themes//gruvbox-light.rasi
3533 :header-args+: :tangle ~/.config/rofi-pass/config
3537 # permanently set alternative root dir
3538 # root=/path/to/root
3540 # rofi command. Make sure to have "$@" as last argument
3542 #rofi -no-auto-select -kb-accept-entry "!Return" -i -no-levenshtein-sort "$@"
3543 rofi -i -no-auto-select -kb-accept-entry "!Return" "$@"
3546 # xdotool needs the keyboard layout to be set using setxkbmap
3547 # You can do this in your autostart scripts (e.g. xinitrc)
3549 # If for some reason, you cannot do this, you can set the command here.
3550 # and set fix_layout to true
3559 USERNAME_field='user'
3560 AUTOTYPE_field='autotype'
3562 # delay to be used for :delay keyword
3565 ## Programs to be used
3574 default_do='menu' # menu, autotype, copyPass, typeUser, typePass, copyUser, copyUrl, viewEntry, typeMenu, actionMenu, copyMenu, openUrl
3577 default_autotype='user :tab pass'
3579 # color of the help messages
3580 # leave empty for autodetection
3581 help_color="#4872FF"
3583 # Clipboard settings
3584 # Possible options: primary, clipboard, both
3587 # Options for generating new password entries
3588 # default_user is also used for password files that have no user field.
3590 default_user2=aminban
3593 # Custom Keybindings
3615 :header-args+: :tangle ~/.config/sway/config
3619 # Default config for sway
3621 # Copy this to ~/.config/sway/config and edit it to your liking.
3623 # Read `man 5 sway` for a complete reference.
3627 # Logo key. Use Mod1 for Alt.
3629 # Home row direction keys, like vim
3634 # Your preferred terminal emulator
3636 # Your preferred application launcher
3639 ### Output configuration
3641 # Default wallpaper (more resolutions are available in __DATADIR__/backgrounds/sway/)
3642 output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill
3644 # Example configuration:
3646 # output HDMI-A-1 resolution 1920x1080 position 1920,0
3648 # You can get the names of your outputs by running: swaymsg -t get_outputs
3650 ### Idle configuration
3652 # Example configuration:
3655 # timeout 300 'swaylock -c 000000' \
3656 # timeout 600 'swaymsg "output * dpms off"' \
3657 # resume 'swaymsg "output * dpms on"' \
3658 # before-sleep 'swaylock -c 000000'
3660 # This will lock your screen after 300 seconds of inactivity, then turn off
3661 # your displays after another 600 seconds, and turn your screens back on when
3662 # resumed. It will also lock your screen before your computer goes to sleep.
3664 ### Input configuration
3666 # Example configuration:
3668 # input "2:14:SynPS/2_Synaptics_TouchPad" {
3671 # natural_scroll enabled
3672 # middle_emulation enabled
3675 # You can get the names of your inputs by running: swaymsg -t get_inputs
3676 # Read `man 5 sway-input` for more information about this section.
3683 bindsym $mod+Return exec $term
3685 # kill focused window
3686 bindsym $mod+Shift+q kill
3688 # start your launcher
3689 bindsym $mod+d exec $menu
3691 # Drag floating windows by holding down $mod and left mouse button.
3692 # Resize them with right mouse button + $mod.
3693 # Despite the name, also works for non-floating windows.
3694 # Change normal to inverse to use left mouse button for resizing and right
3695 # mouse button for dragging.
3696 floating_modifier $mod normal
3698 # reload the configuration file
3699 bindsym $mod+Shift+c reload
3701 # exit sway (logs you out of your wayland session)
3702 bindsym $mod+Shift+e exit
3706 # Move your focus around
3707 bindsym $mod+$left focus left
3708 bindsym $mod+$down focus down
3709 bindsym $mod+$up focus up
3710 bindsym $mod+$right focus right
3711 # or use $mod+[up|down|left|right]
3712 bindsym $mod+Left focus left
3713 bindsym $mod+Down focus down
3714 bindsym $mod+Up focus up
3715 bindsym $mod+Right focus right
3717 # _move_ the focused window with the same, but add Shift
3718 bindsym $mod+Shift+$left move left
3719 bindsym $mod+Shift+$down move down
3720 bindsym $mod+Shift+$up move up
3721 bindsym $mod+Shift+$right move right
3722 # ditto, with arrow keys
3723 bindsym $mod+Shift+Left move left
3724 bindsym $mod+Shift+Down move down
3725 bindsym $mod+Shift+Up move up
3726 bindsym $mod+Shift+Right move right
3730 # switch to workspace
3731 bindsym $mod+1 workspace 1
3732 bindsym $mod+2 workspace 2
3733 bindsym $mod+3 workspace 3
3734 bindsym $mod+4 workspace 4
3735 bindsym $mod+5 workspace 5
3736 bindsym $mod+6 workspace 6
3737 bindsym $mod+7 workspace 7
3738 bindsym $mod+8 workspace 8
3739 bindsym $mod+9 workspace 9
3740 bindsym $mod+0 workspace 10
3741 # move focused container to workspace
3742 bindsym $mod+Shift+1 move container to workspace 1
3743 bindsym $mod+Shift+2 move container to workspace 2
3744 bindsym $mod+Shift+3 move container to workspace 3
3745 bindsym $mod+Shift+4 move container to workspace 4
3746 bindsym $mod+Shift+5 move container to workspace 5
3747 bindsym $mod+Shift+6 move container to workspace 6
3748 bindsym $mod+Shift+7 move container to workspace 7
3749 bindsym $mod+Shift+8 move container to workspace 8
3750 bindsym $mod+Shift+9 move container to workspace 9
3751 bindsym $mod+Shift+0 move container to workspace 10
3752 # Note: workspaces can have any name you want, not just numbers.
3753 # We just use 1-10 as the default.
3757 # You can "split" the current object of your focus with
3758 # $mod+b or $mod+v, for horizontal and vertical splits
3760 bindsym $mod+b splith
3761 bindsym $mod+v splitv
3763 # Switch the current container between different layout styles
3764 bindsym $mod+s layout stacking
3765 bindsym $mod+w layout tabbed
3766 bindsym $mod+e layout toggle split
3768 # Make the current focus fullscreen
3769 bindsym $mod+f fullscreen
3771 # Toggle the current focus between tiling and floating mode
3772 bindsym $mod+Shift+space floating toggle
3774 # Swap focus between the tiling area and the floating area
3775 bindsym $mod+space focus mode_toggle
3777 # move focus to the parent container
3778 bindsym $mod+a focus parent
3782 # Sway has a "scratchpad", which is a bag of holding for windows.
3783 # You can send windows there and get them back later.
3785 # Move the currently focused window to the scratchpad
3786 bindsym $mod+Shift+minus move scratchpad
3788 # Show the next scratchpad window or hide the focused scratchpad window.
3789 # If there are multiple scratchpad windows, this command cycles through them.
3790 bindsym $mod+minus scratchpad show
3792 # Resizing containers:
3795 # left will shrink the containers width
3796 # right will grow the containers width
3797 # up will shrink the containers height
3798 # down will grow the containers height
3799 bindsym $left resize shrink width 10px
3800 bindsym $down resize grow height 10px
3801 bindsym $up resize shrink height 10px
3802 bindsym $right resize grow width 10px
3804 # ditto, with arrow keys
3805 bindsym Left resize shrink width 10px
3806 bindsym Down resize grow height 10px
3807 bindsym Up resize shrink height 10px
3808 bindsym Right resize grow width 10px
3810 # return to default mode
3811 bindsym Return mode "default"
3812 bindsym Escape mode "default"
3814 bindsym $mod+r mode "resize"
3819 # Read `man 5 sway-bar` for more information about this section.
3825 inactive_workspace #32323200 #32323200 #5c5c5c
3829 include /etc/sway/config.d/*
3837 #+begin_src conf :tangle (when (and (eq system-type 'gnu/linux) (string= (system-name) "plasma")) "/sudo::/etc/default/tlp")
3838 # ------------------------------------------------------------------------------
3839 # tlp - Parameters for power saving
3840 # See full explanation: http://linrunner.de/en/tlp/docs/tlp-configuration.html
3842 # Hint: some features are disabled by default, remove the leading # to enable
3845 # Set to 0 to disable, 1 to enable TLP.
3848 # Operation mode when no power supply can be detected: AC, BAT.
3849 # Concerns some desktop and embedded hardware only.
3852 # Operation mode select: 0=depend on power source, 1=always use TLP_DEFAULT_MODE
3853 # Hint: use in conjunction with TLP_DEFAULT_MODE=BAT for BAT settings on AC.
3854 TLP_PERSISTENT_DEFAULT=0
3856 # Seconds laptop mode has to wait after the disk goes idle before doing a sync.
3857 # Non-zero value enables, zero disables laptop mode.
3858 DISK_IDLE_SECS_ON_AC=0
3859 DISK_IDLE_SECS_ON_BAT=2
3861 # Dirty page values (timeouts in secs).
3862 MAX_LOST_WORK_SECS_ON_AC=15
3863 MAX_LOST_WORK_SECS_ON_BAT=60
3865 # Hint: CPU parameters below are disabled by default, remove the leading #
3866 # to enable them, otherwise kernel default values are used.
3868 # Select a CPU frequency scaling governor.
3869 # Intel Core i processor with intel_pstate driver:
3870 # powersave(*), performance.
3871 # Older hardware with acpi-cpufreq driver:
3872 # ondemand(*), powersave, performance, conservative, schedutil.
3873 # (*) is recommended.
3874 # Hint: use tlp-stat -p to show the active driver and available governors.
3876 # powersave for intel_pstate and ondemand for acpi-cpufreq are power
3877 # efficient for *almost all* workloads and therefore kernel and most
3878 # distributions have chosen them as defaults. If you still want to change,
3879 # you should know what you're doing! You *must* disable your distribution's
3880 # governor settings or conflicts will occur.
3881 #CPU_SCALING_GOVERNOR_ON_AC=powersave
3882 #CPU_SCALING_GOVERNOR_ON_BAT=powersave
3884 # Set the min/max frequency available for the scaling governor.
3885 # Possible values strongly depend on your CPU. For available frequencies see
3886 # the output of tlp-stat -p.
3887 #CPU_SCALING_MIN_FREQ_ON_AC=0
3888 #CPU_SCALING_MAX_FREQ_ON_AC=0
3889 #CPU_SCALING_MIN_FREQ_ON_BAT=0
3890 #CPU_SCALING_MAX_FREQ_ON_BAT=0
3892 # Set energy performance hints (HWP) for Intel P-state governor:
3893 # performance, balance_performance, default, balance_power, power
3894 # Values are given in order of increasing power saving.
3895 # Note: Intel Skylake or newer CPU and Kernel >= 4.10 required.
3896 CPU_HWP_ON_AC=balance_performance
3897 CPU_HWP_ON_BAT=balance_power
3899 # Set Intel P-state performance: 0..100 (%).
3900 # Limit the max/min P-state to control the power dissipation of the CPU.
3901 # Values are stated as a percentage of the available performance.
3902 # Requires an Intel Core i processor with intel_pstate driver.
3903 #CPU_MIN_PERF_ON_AC=0
3904 #CPU_MAX_PERF_ON_AC=100
3905 #CPU_MIN_PERF_ON_BAT=0
3906 #CPU_MAX_PERF_ON_BAT=30
3908 # Set the CPU "turbo boost" feature: 0=disable, 1=allow
3909 # Requires an Intel Core i processor.
3911 # - This may conflict with your distribution's governor settings
3912 # - A value of 1 does *not* activate boosting, it just allows it
3916 # Minimize number of used CPU cores/hyper-threads under light load conditions:
3917 # 0=disable, 1=enable.
3918 SCHED_POWERSAVE_ON_AC=0
3919 SCHED_POWERSAVE_ON_BAT=1
3921 # Kernel NMI Watchdog:
3922 # 0=disable (default, saves power), 1=enable (for kernel debugging only).
3925 # Change CPU voltages aka "undervolting" - Kernel with PHC patch required.
3926 # Frequency voltage pairs are written to:
3927 # /sys/devices/system/cpu/cpu0/cpufreq/phc_controls
3928 # CAUTION: only use this, if you thoroughly understand what you are doing!
3929 #PHC_CONTROLS="F:V F:V F:V F:V"
3931 # Set CPU performance versus energy savings policy:
3932 # performance, balance-performance, default, balance-power, power.
3933 # Values are given in order of increasing power saving.
3934 # Requires kernel module msr and x86_energy_perf_policy from linux-tools.
3935 ENERGY_PERF_POLICY_ON_AC=performance
3936 ENERGY_PERF_POLICY_ON_BAT=balance-power
3938 # Disk devices; separate multiple devices with spaces (default: sda).
3939 # Devices can be specified by disk ID also (lookup with: tlp diskid).
3940 DISK_DEVICES="sda sdb"
3942 # Disk advanced power management level: 1..254, 255 (max saving, min, off).
3943 # Levels 1..127 may spin down the disk; 255 allowable on most drives.
3944 # Separate values for multiple disks with spaces. Use the special value 'keep'
3945 # to keep the hardware default for the particular disk.
3946 DISK_APM_LEVEL_ON_AC="254 254"
3947 DISK_APM_LEVEL_ON_BAT="128 128"
3949 # Hard disk spin down timeout:
3950 # 0: spin down disabled
3951 # 1..240: timeouts from 5s to 20min (in units of 5s)
3952 # 241..251: timeouts from 30min to 5.5 hours (in units of 30min)
3953 # See 'man hdparm' for details.
3954 # Separate values for multiple disks with spaces. Use the special value 'keep'
3955 # to keep the hardware default for the particular disk.
3956 #DISK_SPINDOWN_TIMEOUT_ON_AC="0 0"
3957 #DISK_SPINDOWN_TIMEOUT_ON_BAT="0 0"
3959 # Select IO scheduler for the disk devices: cfq, deadline, noop (Default: cfq).
3960 # Separate values for multiple disks with spaces. Use the special value 'keep'
3961 # to keep the kernel default scheduler for the particular disk.
3962 #DISK_IOSCHED="cfq cfq"
3964 # AHCI link power management (ALPM) for disk devices:
3965 # min_power, med_power_with_dipm(*), medium_power, max_performance.
3966 # (*) Kernel >= 4.15 required, then recommended.
3967 # Multiple values separated with spaces are tried sequentially until success.
3968 SATA_LINKPWR_ON_AC="med_power_with_dipm max_performance"
3969 SATA_LINKPWR_ON_BAT="med_power_with_dipm min_power"
3971 # Exclude host devices from AHCI link power management.
3972 # Separate multiple hosts with spaces.
3973 #SATA_LINKPWR_BLACKLIST="host1"
3975 # Runtime Power Management for AHCI host and disks devices:
3976 # on=disable, auto=enable.
3977 # EXPERIMENTAL ** WARNING: auto will most likely cause system lockups/data loss.
3978 #AHCI_RUNTIME_PM_ON_AC=on
3979 #AHCI_RUNTIME_PM_ON_BAT=on
3981 # Seconds of inactivity before disk is suspended.
3982 AHCI_RUNTIME_PM_TIMEOUT=15
3984 # PCI Express Active State Power Management (PCIe ASPM):
3985 # default, performance, powersave.
3986 PCIE_ASPM_ON_AC=performance
3987 PCIE_ASPM_ON_BAT=powersave
3989 # Radeon graphics clock speed (profile method): low, mid, high, auto, default;
3990 # auto = mid on BAT, high on AC; default = use hardware defaults.
3991 RADEON_POWER_PROFILE_ON_AC=high
3992 RADEON_POWER_PROFILE_ON_BAT=low
3994 # Radeon dynamic power management method (DPM): battery, performance.
3995 RADEON_DPM_STATE_ON_AC=performance
3996 RADEON_DPM_STATE_ON_BAT=battery
3998 # Radeon DPM performance level: auto, low, high; auto is recommended.
3999 RADEON_DPM_PERF_LEVEL_ON_AC=auto
4000 RADEON_DPM_PERF_LEVEL_ON_BAT=auto
4002 # WiFi power saving mode: on=enable, off=disable; not supported by all adapters.
4006 # Disable wake on LAN: Y/N.
4009 # Enable audio power saving for Intel HDA, AC97 devices (timeout in secs).
4010 # A value of 0 disables, >=1 enables power saving (recommended: 1).
4011 SOUND_POWER_SAVE_ON_AC=0
4012 SOUND_POWER_SAVE_ON_BAT=0
4014 # Disable controller too (HDA only): Y/N.
4015 SOUND_POWER_SAVE_CONTROLLER=N
4017 # Power off optical drive in UltraBay/MediaBay: 0=disable, 1=enable.
4018 # Drive can be powered on again by releasing (and reinserting) the eject lever
4019 # or by pressing the disc eject button on newer models.
4020 # Note: an UltraBay/MediaBay hard disk is never powered off.
4021 BAY_POWEROFF_ON_AC=0
4022 BAY_POWEROFF_ON_BAT=0
4023 # Optical drive device to power off (default sr0).
4026 # Runtime Power Management for PCI(e) bus devices: on=disable, auto=enable.
4028 RUNTIME_PM_ON_BAT=auto
4030 # Exclude PCI(e) device adresses the following list from Runtime PM
4031 # (separate with spaces). Use lspci to get the adresses (1st column).
4032 #RUNTIME_PM_BLACKLIST="bb:dd.f 11:22.3 44:55.6"
4033 RUNTIME_PM_BLACKLIST="01:00.0"
4035 # Exclude PCI(e) devices assigned to the listed drivers from Runtime PM.
4036 # Default when unconfigured is "amdgpu nouveau nvidia radeon" which
4037 # prevents accidential power-on of dGPU in hybrid graphics setups.
4038 # Use "" to disable the feature completely.
4039 # Separate multiple drivers with spaces.
4040 #RUNTIME_PM_DRIVER_BLACKLIST="amdgpu nouveau nvidia radeon"
4042 # Set to 0 to disable, 1 to enable USB autosuspend feature.
4045 # Exclude listed devices from USB autosuspend (separate with spaces).
4046 # Use lsusb to get the ids.
4047 # Note: input devices (usbhid) are excluded automatically
4048 #USB_BLACKLIST="1111:2222 3333:4444"
4050 # Bluetooth devices are excluded from USB autosuspend:
4051 # 0=do not exclude, 1=exclude.
4052 USB_BLACKLIST_BTUSB=0
4054 # Phone devices are excluded from USB autosuspend:
4055 # 0=do not exclude, 1=exclude (enable charging).
4056 USB_BLACKLIST_PHONE=0
4058 # Printers are excluded from USB autosuspend:
4059 # 0=do not exclude, 1=exclude.
4060 USB_BLACKLIST_PRINTER=1
4062 # WWAN devices are excluded from USB autosuspend:
4063 # 0=do not exclude, 1=exclude.
4064 USB_BLACKLIST_WWAN=1
4066 # Include listed devices into USB autosuspend even if already excluded
4067 # by the blacklists above (separate with spaces).
4068 # Use lsusb to get the ids.
4069 #USB_WHITELIST="1111:2222 3333:4444"
4071 # Set to 1 to disable autosuspend before shutdown, 0 to do nothing
4072 # (workaround for USB devices that cause shutdown problems).
4073 #USB_AUTOSUSPEND_DISABLE_ON_SHUTDOWN=1
4075 # Restore radio device state (Bluetooth, WiFi, WWAN) from previous shutdown
4076 # on system startup: 0=disable, 1=enable.
4077 # Hint: the parameters DEVICES_TO_DISABLE/ENABLE_ON_STARTUP/SHUTDOWN below
4078 # are ignored when this is enabled!
4079 #RESTORE_DEVICE_STATE_ON_STARTUP=0
4080 RESTORE_DEVICE_STATE_ON_STARTUP=1
4082 # Radio devices to disable on startup: bluetooth, wifi, wwan.
4083 # Separate multiple devices with spaces.
4084 #DEVICES_TO_DISABLE_ON_STARTUP="bluetooth wifi wwan"
4086 # Radio devices to enable on startup: bluetooth, wifi, wwan.
4087 # Separate multiple devices with spaces.
4088 #DEVICES_TO_ENABLE_ON_STARTUP="wifi"
4090 # Radio devices to disable on shutdown: bluetooth, wifi, wwan.
4091 # (workaround for devices that are blocking shutdown).
4092 #DEVICES_TO_DISABLE_ON_SHUTDOWN="bluetooth wifi wwan"
4094 # Radio devices to enable on shutdown: bluetooth, wifi, wwan.
4095 # (to prevent other operating systems from missing radios).
4096 #DEVICES_TO_ENABLE_ON_SHUTDOWN="wwan"
4098 # Radio devices to enable on AC: bluetooth, wifi, wwan.
4099 #DEVICES_TO_ENABLE_ON_AC="bluetooth wifi wwan"
4101 # Radio devices to disable on battery: bluetooth, wifi, wwan.
4102 #DEVICES_TO_DISABLE_ON_BAT="bluetooth wifi wwan"
4104 # Radio devices to disable on battery when not in use (not connected):
4105 # bluetooth, wifi, wwan.
4106 #DEVICES_TO_DISABLE_ON_BAT_NOT_IN_USE="bluetooth wifi wwan"
4108 # Battery charge thresholds (ThinkPad only, tp-smapi or acpi-call kernel module
4109 # required). Charging starts when the remaining capacity falls below the
4110 # START_CHARGE_THRESH value and stops when exceeding the STOP_CHARGE_THRESH value.
4111 # Main / Internal battery (values in %)
4112 #START_CHARGE_THRESH_BAT0=75
4113 #STOP_CHARGE_THRESH_BAT0=80
4114 # Ultrabay / Slice / Replaceable battery (values in %)
4115 #START_CHARGE_THRESH_BAT1=75
4116 #STOP_CHARGE_THRESH_BAT1=80
4118 # Restore charge thresholds when AC is unplugged: 0=disable, 1=enable.
4119 #RESTORE_THRESHOLDS_ON_BAT=1
4121 # ------------------------------------------------------------------------------
4122 # tlp-rdw - Parameters for the radio device wizard
4123 # Possible devices: bluetooth, wifi, wwan.
4126 # - Parameters are disabled by default, remove the leading # to enable them
4127 # - Separate multiple radio devices with spaces
4129 # Radio devices to disable on connect.
4130 #DEVICES_TO_DISABLE_ON_LAN_CONNECT="wifi wwan"
4131 #DEVICES_TO_DISABLE_ON_WIFI_CONNECT="wwan"
4132 #DEVICES_TO_DISABLE_ON_WWAN_CONNECT="wifi"
4134 # Radio devices to enable on disconnect.
4135 #DEVICES_TO_ENABLE_ON_LAN_DISCONNECT="wifi wwan"
4136 #DEVICES_TO_ENABLE_ON_WIFI_DISCONNECT=""
4137 #DEVICES_TO_ENABLE_ON_WWAN_DISCONNECT=""
4139 # Radio devices to enable/disable when docked.
4140 #DEVICES_TO_ENABLE_ON_DOCK=""
4141 #DEVICES_TO_DISABLE_ON_DOCK=""
4143 # Radio devices to enable/disable when undocked.
4144 #DEVICES_TO_ENABLE_ON_UNDOCK="wifi"
4145 #DEVICES_TO_DISABLE_ON_UNDOCK=""
4152 :header-args+: :tangle ~/.xprofile
4155 =~/.xprofile= is similar in style to =~/.xinitrc=, but on the
4156 contrary, it's automatically sourced by LightDM, my display manager of
4159 #+begin_src sh :tangle no
4160 xset -b # disable bell
4161 xset r rate 200 45 # repeat delay (ms) and rate (repeats/sec)
4163 # setxkbmap -option compose:ralt
4165 setxkbmap -option ctrl:nocaps # turn capslock into control
4166 setxkbmap -option altwin:swap_alt_win # swap alt and super
4168 if [ $(hostname) = "plasma" ]
4170 setxkbmap -option ctrl:rctrl_ralt # turn right control into right alt
4173 if [ $(hostname) = "enigma" ]
4175 xmodmap -e "keycode 135 = Alt_R" # remap menu key to alt
4178 light -Scrs "intel_backlight" 2
4180 source $HOME/.zprofile
4182 export _JAVA_AWT_WM_NONREPARENTING=1
4183 export _JAVA_OPTIONS='-Dawt.useSystemAAFontSettings=on -Dswing.aatext=true'
4185 if [ $(hostname) = "plasma" ]
4197 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources")
4200 #+begin_src conf-xdefaults
4201 #include ".Xresources.d/fonts"
4202 ! #include ".Xresources.d/colors"
4203 #include ".Xresources.d/emacs"
4204 #include ".Xresources.d/rxvt-unicode"
4211 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/fonts")
4214 #+begin_src conf-xdefaults
4215 Xft.lcdfilter: lcddefault
4219 Xft.hintstyle: hintslight
4220 ! Xft.hintstyle: hintfull
4227 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/colors")
4230 #+begin_src conf-xdefaults :tangle no
4231 #include "gruvbox-light.xresources"
4232 ! #include "gruvbox-dark.xresources"
4233 #include "gruvbox-urxvt256.xresources"
4236 #+begin_src conf-xdefaults :tangle no
4237 ! -----------------------------------------------------------------------------
4238 ! File: gruvbox-light.xresources
4239 ! Description: Retro groove colorscheme generalized
4240 ! Author: morhetz <morhetz@gmail.com>
4241 ! Source: https://github.com/morhetz/gruvbox-generalized
4242 ! Last Modified: 6 Sep 2014
4243 ! -----------------------------------------------------------------------------
4245 ! hard contrast: *background: #f9f5d7
4246 *background: #fbf1c7
4247 ! soft contrast: *background: #f2e5bc
4248 *foreground: #3c3836
4258 ! DarkYellow + Yellow
4264 ! DarkMagenta + Magenta
4275 #+begin_src conf-xdefaults :tangle no
4276 ! -----------------------------------------------------------------------------
4277 ! File: gruvbox-dark.xresources
4278 ! Description: Retro groove colorscheme generalized
4279 ! Author: morhetz <morhetz@gmail.com>
4280 ! Source: https://github.com/morhetz/gruvbox-generalized
4281 ! Last Modified: 6 Sep 2014
4282 ! -----------------------------------------------------------------------------
4284 ! hard contrast: *background: #1d2021
4285 *background: #282828
4286 ! soft contrast: *background: #32302f
4287 *foreground: #ebdbb2
4297 ! DarkYellow + Yellow
4303 ! DarkMagenta + Magenta
4314 #+begin_src conf-xdefaults :tangle no
4315 ! -----------------------------------------------------------------------------
4316 ! File: gruvbox-urxvt256.xresources
4317 ! Description: Retro groove colorscheme generalized
4318 ! Author: morhetz <morhetz@gmail.com>
4319 ! Source: https://github.com/morhetz/gruvbox-generalized
4320 ! Last Modified: 13 Dec 2013
4321 ! -----------------------------------------------------------------------------
4323 URxvt.color24: #076678
4324 URxvt.color66: #427b58
4325 URxvt.color88: #9d0006
4326 URxvt.color96: #8f3f71
4327 URxvt.color100: #79740e
4328 URxvt.color108: #8ec07c
4329 URxvt.color109: #83a598
4330 URxvt.color130: #af3a03
4331 URxvt.color136: #b57614
4332 URxvt.color142: #b8bb26
4333 URxvt.color167: #fb4934
4334 URxvt.color175: #d3869b
4335 URxvt.color208: #fe8019
4336 URxvt.color214: #fabd2f
4337 URxvt.color223: #ebdbb2
4338 URxvt.color228: #f2e5bc
4339 URxvt.color229: #fbf1c7
4340 URxvt.color230: #f9f5d7
4341 URxvt.color234: #1d2021
4342 URxvt.color235: #282828
4343 URxvt.color236: #32302f
4344 URxvt.color237: #3c3836
4345 URxvt.color239: #504945
4346 URxvt.color241: #665c54
4347 URxvt.color243: #7c6f64
4348 URxvt.color244: #928374
4349 URxvt.color245: #928374
4350 URxvt.color246: #a89984
4351 URxvt.color248: #bdae93
4352 URxvt.color250: #d5c4a1
4357 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/emacs")
4360 #+begin_src conf-xdefaults
4363 Emacs.verticalScrollBars: off
4364 Emacs.cursorBlink: off
4365 Emacs.FontBackend: xft,x
4366 ! Emacs.font: Ubuntu Mono-12
4367 ! Emacs.font: Triplicate T4C-11
4368 ! Emacs.font: Ubuntu Mono-10.5
4369 ! Emacs.font: Ubuntu Mono-12
4370 ! Emacs.font: Iosevka-11
4372 ! Emacs.font: Fira Mono:size=15
4373 ! Emacs.font: DejaVu Sans Mono:size=15
4374 ! Emacs.font: Inconsolata:size=17
4375 ! Emacs.font: Inconsolata:size=16
4376 ! Emacs.font: Inconsolata LGC:size=14
4377 ! Emacs.font: Source Code Pro Medium-10.5
4378 Emacs.font: Ubuntu Mono:size=16
4379 ! Emacs.font: Iosevka:size=16
4384 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/rxvt-unicode")
4387 #+begin_src conf-xdefaults
4389 URxvt.font: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true
4390 URxvt.boldFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:bold, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:bold
4391 URxvt.italicFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:italic, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:italic
4392 URxvt.bolditalicFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:bold:italic, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:bolditalic
4394 URxvt.xftAntialias: true
4395 URxvt.letterSpace: 0
4398 URxvt.loginShell: true
4399 URxvt.saveLines: 100000
4400 URxvt.internalBorder: 3
4402 URxvt.scrollBar: false
4403 URxvt.scrollStyle: rxvt
4404 URxvt*scrollTtyOutput: false
4405 URxvt*scrollWithBuffer: true
4406 URxvt*scrollTtyKeypress: true
4407 URxvt.keysym.Shift-Up: command:\033]720;1\007
4408 URxvt.keysym.Shift-Down: command:\033]721;1\007
4410 URxvt.perl-ext-common: default,clipboard,url-select,keyboard-select
4411 URxvt.perl-ext: bidi
4412 URxvt.bidi.enabled: 1
4413 URxvt.url-select.launcher: firefox
4414 URxvt.url-select.underline: true
4415 URxvt.keysym.M-u: perl:url-select:select_next
4416 URxvt.keysym.M-Escape: perl:keyboard-select:activate
4417 URxvt.keysym.M-s: perl:keyboard-select:search
4418 URxvt.url-launcher: /usr/bin/firefox
4419 URxvt.matcher.button: 1
4420 URxvt.iso14755: false
4421 URxvt.iso14755_53: false
4422 URxvt.keysym.M-c: perl:clipboard:copy
4423 URxvt.keysym.M-v: perl:clipboard:paste
4424 URxvt.keysym.C-A-V: perl:clipboard:paste_escaped
4425 URxvt.keysym.C-Up: font-size:increase
4426 URxvt.keysym.C-Down: font-size:decrease
4427 URxvt.keysym.C-S-Up: font-size:incglobal
4428 URxvt.keysym.C-S-Down: font-size:decglobal
4429 URxvt.keysym.C-equal: font-size:reset
4430 !URxvt.keysym.C-question: font-size:show
4432 URxvt.iconFile: /usr/share/icons/Paper/48x48/apps/utilities-terminal.png
4434 !urxvt*foreground: white
4435 !urxvt*background: black
4454 !URxvt.foreground: #C8C8C8
4455 !URxvt.background: #FFFFFF
4475 !! orange (replaces cyan)
4482 ! Tango colour theme for rxvt-unicode
4483 URxvt.background: #FFFFFF
4484 URxvt.foreground: #000000
4487 URxvt.color0: #2E3436
4488 URxvt.color8: #757773
4491 URxvt.color1: #CC0000
4492 URxvt.color9: #EF2929
4495 URxvt.color2: #4E9A06
4496 URxvt.color10: #8AE234
4499 URxvt.color3: #C4A000
4500 URxvt.color11: #FCE94F
4503 URxvt.color4: #3465A4
4504 URxvt.color12: #729FCF
4507 URxvt.color5: #75507B
4508 URxvt.color13: #AD7FA8
4511 !URxvt.color6: #06989A
4512 !URxvt.color14: #34E2E2
4513 ! orange (replaces cyan)
4518 URxvt.color7: #D3D7CF
4519 URxvt.color15: #EEEEEC
4524 :header-args+: :tangle ~/.config/user-dirs.dirs
4528 XDG_DESKTOP_DIR="$HOME/Desktop"
4529 XDG_DOCUMENTS_DIR="$HOME/usr/docs"
4530 XDG_DOWNLOAD_DIR="$HOME/usr/dls"
4531 XDG_MUSIC_DIR="$HOME/usr/music"
4532 XDG_PICTURES_DIR="$HOME/usr/pics"
4533 XDG_PUBLICSHARE_DIR="$HOME/usr/Public"
4534 XDG_TEMPLATES_DIR="$HOME/usr/Templates"
4535 XDG_VIDEOS_DIR="$HOME/usr/vids"
4540 :header-args+: :tangle ~/.config/zathura/zathurarc
4544 set smooth-scroll true
4545 set selection-clipboard clipboard
4547 set default-bg "#272727"
4548 set statusbar-bg "#272727"
4549 set inputbar-bg "#373737"
4554 My zsh setup is built on [[https://github.com/zimfw/zimfw][Zim]]. Further, my zshrc references [[https://github.com/junegunn/fzf][fzf]],
4555 [[https://github.com/zsh-users/zsh-autosuggestions][zsh-autosuggestions]], and [[https://github.com/hlissner/zsh-autopair][zsh-autopair]]; so be sure to have them
4560 :header-args+: :tangle ~/.zimrc
4574 # Select what modules you would like enabled.
4575 # The second line of modules may depend on options set by modules in the first
4576 # line. These dependencies are noted on the respective module's README.md.
4577 zmodules=(directory environment git git-info history input ssh utility custom \
4578 syntax-highlighting history-substring-search prompt completion)
4589 # Set your desired prompt here
4590 zprompt_theme='pure'
4591 #PURE_PROMPT_SYMBOL=λ
4592 #PURE_PROMPT_SYMBOL=δ
4593 PURE_PROMPT_SYMBOL=➜
4599 # set an optional host-specific filename for the completion cache file
4600 # if none is provided, the default '.zcompdump' is used.
4601 #zcompdump_file=".zcompdump-${HOST}-${ZSH_VERSION}"
4607 # Uncomment to enable command correction prompts
4608 # See: http://zsh.sourceforge.net/Doc/Release/Options.html#Input_002fOutput
4615 # Set the string below to the desired terminal title format string.
4616 # The terminal title is redrawn upon directory change, however, variables like
4617 # ${PWD} are only evaluated once. Use prompt expansion strings for dynamic data:
4618 # http://zsh.sourceforge.net/Doc/Release/Prompt-Expansion.html#Simple-Prompt-Escapes
4619 # The example below uses the following format: 'username@host:/current/directory'
4620 ztermtitle='%n@%m:%~'
4626 # Uncomment to enable double-dot expansion.
4627 # This appends '../' to your input for each '.' you type after an initial '..'
4628 #zdouble_dot_expand='true'
4631 # Syntax-Highlighting
4634 # This determines what highlighters will be used with the syntax-highlighting module.
4635 # Documentation of the highlighters can be found here:
4636 # https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters.md
4637 # For (u)rxvt, termite and gnome-terminal users,
4638 # removing the 'cursor' highlighter will fix the disappearing cursor problem
4639 #zhighlighters=(main brackets cursor)
4640 zhighlighters=(main brackets pattern)
4647 # Load these ssh identities with the ssh module
4648 zssh_ids=(id_rsa plasma_id_rsa id_ed25519 id_rsa_aur)
4655 # Set (optional) pacman front-end.
4656 zpacman_frontend='yay'
4658 # Load any helper scripts as defined here
4659 #zpacman_helper=(aur)
4664 :header-args+: :tangle ~/.zlogin
4671 # User configuration sourced by login shells
4675 [[ -s ${ZIM_HOME}/login_init.zsh ]] && source ${ZIM_HOME}/login_init.zsh
4680 :header-args+: :tangle ~/.zprofile
4684 #PATH="$(ruby -e 'print Gem.user_dir')/bin:$PATH"
4685 #PATH=$HOME/.gem/ruby/2.4.0/bin:$PATH
4686 export PATH=$HOME/.local/bin:$HOME/.cabal/bin:$HOME/.cargo/bin:$HOME/.elan/bin:$PATH
4687 export XDG_CONFIG_HOME=$HOME/.config
4688 export XDG_DATA_HOME=$HOME/.local/share
4689 export XDG_DATA_DIRS=/usr/local/share:/usr/share
4690 export MAILDIR="$HOME/mail"
4692 #export MATHMODELS=$HOME/src/eiffel/mathmodels
4693 #export RUST_SRC_PATH=~/.multirust/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/src/rust/src
4694 #export PATH=$PATH:$HOME/.rustup/toolchains/nightly-x86_64-unknown-linux-gnu/bin/
4697 #export JAVA_HOME=/usr/lib/jvm/default
4698 #export CPATH=$CPATH:"$JAVA_HOME/include:$JAVA_HOME/include/linux"
4699 #export LIBRARY_PATH=$LIBRARY_PATH:"$JAVA_HOME/jre/lib/amd64/server"
4700 #export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:"$JAVA_HOME/jre/lib/amd64/server"
4702 #export PATH="$HOME/usr/build/pvs:$PATH"
4703 #export SBCLISP_HOME=/usr/share/sbcl-source
4704 #export PVS_LIBRARY_PATH="$HOME/usr/build/pvs/nasalib"
4706 export MOZ_USE_XINPUT2=1 # precise scrolling in firefox
4708 #export JAVA_HOME=/usr/lib/jvm/java-8-openjdk
4709 #export ANDROID_JACK_VM_ARGS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx4G"
4711 if [ -e /home/amin/.nix-profile/etc/profile.d/nix.sh ]; then . /home/amin/.nix-profile/etc/profile.d/nix.sh; fi # added by Nix installer
4716 :header-args+: :tangle ~/.zshenv
4720 # Ensure that a non-login, non-interactive shell has a defined environment.
4721 if [[ "$SHLVL" -eq 1 && ! -o LOGIN && -s "${ZDOTDIR:-$HOME}/.zprofile" ]]; then
4722 source "${ZDOTDIR:-$HOME}/.zprofile"
4728 :header-args+: :tangle ~/.zshrc
4732 # Bash-like navigation
4733 #export WORDCHARS='*?_-.[]~=&;!#$%^(){}<>'
4734 #export WORDCHARS='*?-[]~=&;!#$%^(){}<>'
4735 export WORDCHARS='*?[]~=&;!#$%^(){}<>'
4736 #ZLE_SPACE_SUFFIX_CHARS=$'|&'
4738 #disable -r time # disable shell reserved word
4739 #alias time='time -p' # -p for POSIX output
4741 # rehash if last command was pacaur or pacman
4742 # (so that zsh picks up changes in $PATH immediately)
4743 TRAPUSR1() { rehash}; precmd() { [[ $history[$[ HISTCMD -1 ]] == *(pacaur|pacman)* ]] && killall -USR1 zsh }
4746 # User configuration sourced by interactive shells
4749 # Change default zim location
4750 export ZIM_HOME=${ZDOTDIR:-${HOME}}/.zim
4753 [[ -s ${ZIM_HOME}/init.zsh ]] && source ${ZIM_HOME}/init.zsh
4755 ZSH_HIGHLIGHT_PATTERNS+=('rm -rf *' 'fg=white,bold,bg=red')
4756 #ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=red,bold'
4760 source ~/.zsh/zsh-autosuggestions/zsh-autosuggestions.zsh
4761 source ~/.zsh/zsh-autopair/autopair.zsh
4766 source /usr/share/fzf/key-bindings.zsh
4767 source /usr/share/fzf/completion.zsh
4769 # Accept history selection instead of putting it on
4771 fzf-history-widget-accept() {
4775 #zle -N fzf-history-widget-accept
4776 #bindkey '^R' fzf-history-widget-accept
4779 export FZF_ALT_C_OPTS="--preview 'tree -C {} | head -200'"
4785 alias mpv="mpv --ytdl-format mp4"
4789 alias jcl=journalctl
4790 alias m="mbsync -Va; getmail; notmuch new"
4791 alias best="youtube-dl -f best"
4792 alias nixx="ssh amin@nix.aminb.org"
4793 alias fence="ssh aminb@fencepost.gnu.org"
4797 git clone https://aur.archlinux.org/${1}.git
4808 This section contains various useful scripts and the ones used by the
4809 programs above. For instance, =toggle-tablet= for switching to and
4810 from tablet mode on my X220T, =toggle-presentation-mode= for toggling
4811 Xfce's presentation mode which keeps the screen awake, and
4812 =rofi-light= a small utility that uses [[https://github.com/DaveDavenport/rofi][Rofi]] to ask and [[https://github.com/haikarainen/light][light]] to set an
4813 exact brightness value.
4817 :header-args+: :tangle ~/.local/bin/rofi-light :shebang "#!/bin/bash"
4822 val=$(rofi -dmenu -mesg "light $cur" -p "light -S " -l 0 -width 12)
4828 :header-args+: :tangle ~/.local/bin/toggle-layout :shebang "#!/bin/bash"
4832 lang="$(setxkbmap -print | grep xkb_symbols | cut -d'+' -f 2)"
4834 if [ "$lang" = "us" ]; then
4838 # xmodmap $HOME/.Xmodmap
4842 ** toggle-presentation-mode
4844 :header-args+: :tangle ~/.local/bin/toggle-presentation-mode :shebang "#!/bin/bash"
4848 xfconf-query -c xfce4-power-manager -p /xfce4-power-manager/presentation-mode -T
4853 :header-args+: :tangle ~/.local/bin/toggle-tablet :shebang "#!/bin/bash"
4856 This script toggles between a 'normal' mode and a 'tablet' mode, doing
4859 - rotates the screen using =xrandr=, so that rotating the physical
4860 display of my X220t would have the laptop's battery on the right
4862 - enables touch screen,
4863 - properly rotates the stylus pen and touch screen pointers, and
4864 - toggles between RGB and Vertical BGR sub-pixel order.
4867 case $(xfconf-query -c pointers -p /Wacom_ISDv4_E6_Pen_stylus/Properties/Wacom_Rotation) in
4868 0) # Screen is not rotated, we should rotate it right (90°)
4870 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Pen_stylus/Properties/Wacom_Rotation -s 1
4871 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Finger_touch/Properties/Device_Enabled -s 1
4872 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Finger_touch/Properties/Wacom_Rotation -s 1
4873 xfconf-query -c xsettings -p /Xft/RGBA -s vbgr
4875 1) # Currently top is rotated right, we should set it normal (0°)
4877 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Pen_stylus/Properties/Wacom_Rotation -s 0
4878 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Finger_touch/Properties/Wacom_Rotation -s 0
4879 xfconf-query -c pointers -p /Wacom_ISDv4_E6_Finger_touch/Properties/Device_Enabled -s 0
4880 xfconf-query -c xsettings -p /Xft/RGBA -s rgb
4883 echo "Unknown result from 'xfconf-query -c pointers -p /Wacom_ISDv4_E6_Pen_stylus/Properties/Wacom_Rotation'" >&2
4891 :header-args+: :tangle ~/.local/bin/unlock-def-gk.py :shebang "#!/usr/bin/env python2"
4895 import gnomekeyring as gk
4896 # list_item_ids_sync('login')[0] == 1L
4897 gk.unlock_sync('Default_keyring',gk.item_get_info_sync('login',1L).get_secret())
4902 My little wallpaper changer script.
4906 :header-args+: :tangle ~/.local/bin/wp :shebang "#!/bin/bash"
4909 #+begin_src bash :tangle no
4914 feh --bg-scale $HOME/usr/pics/island_day_by_arsenixc-d6ctqon.jpg
4917 feh --bg-scale $HOME/usr/pics/island_night_by_arsenixc-d6cz757.jpg
4920 echo $"Usage: $0 {day|night}"
4927 :header-args+: :tangle ~/.local/bin/wp-auto :shebang "#!/bin/bash"
4930 #+begin_src bash :tangle no
4939 echo "Did not find 'sed', script cannot continue."
4944 echo "Did not find rofi, there is no point to continue."
4949 # Create if not exists, then removes #include of .theme file (if present) and add the selected theme to the end.
4950 # Repeated calls should leave the config clean-ish
4952 function set_theme()
4954 CDIR="${HOME}/.config/rofi/"
4955 if [ ! -d "${CDIR}" ]
4959 if [ -f "${CDIR}/config" ]
4961 ${SED} -i "/rofi\.theme: .*\.rasi$/d" "${CDIR}/config"
4963 echo "rofi.theme: ${1}" >> "${CDIR}/config"
4967 if [ "$HOUR" -gt "19" ] || [ "$HOUR" -lt "7" ]
4969 feh --bg-scale $HOME/usr/pics/island_night_by_arsenixc-d6cz757.jpg
4970 xrdb -merge $HOME/.Xresources.d/gruvbox-dark.xresources
4971 set_theme "/usr/share/rofi/themes//gruvbox-dark.rasi"
4973 feh --bg-scale $HOME/usr/pics/island_day_by_arsenixc-d6ctqon.jpg
4974 xrdb -merge $HOME/.Xresources.d/gruvbox-light.xresources
4975 set_theme "/usr/share/rofi/themes//gruvbox-light.rasi"
4981 :header-args+: :tangle ~/.config/systemd/user/wp.service
4984 #+begin_src conf :tangle no
4986 Description=wallpaper service
4990 ExecStart=/usr/bin/bash -c %h/.local/bin/wp-auto
4995 :header-args+: :tangle ~/.config/systemd/user/wp.timer
4998 #+begin_src conf :tangle no
5001 Description=wallpaper timer
5009 WantedBy=timers.target
5014 :header-args+: :tangle ~/.local/bin/zathura-sync.sh :shebang "#!/bin/sh"
5020 zathura --synctex-forward "$pos" "$pdffile" || \
5022 zathura -x "emacsclient --eval '(progn (switch-to-buffer (file-name-nondirectory \"%{input}\")) (goto-line %{line}))'" "$pdffile" &
5023 sleep 1; zathura --synctex-forward "$pos" "$pdffile" )
5029 :header-args+: :tangle ~/.local/bin/eat-em :shebang "#!/bin/sh"
5033 # Original Posted at http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921
5034 # [ESC] character in original post removed here.
5036 # ANSI Color -- use these variables to easily have different color
5037 # and format output. Make sure to output the reset sequence after
5038 # colors (f = foreground, b = background), and use the 'off'
5039 # feature for anything you turn on.
5043 esc="$(echo -en '\e')"
5045 blackf="${esc}[30m"; redf="${esc}[31m"; greenf="${esc}[32m"
5046 yellowf="${esc}[33m" bluef="${esc}[34m"; purplef="${esc}[35m"
5047 cyanf="${esc}[36m"; whitef="${esc}[37m"
5049 blackb="${esc}[40m"; redb="${esc}[41m"; greenb="${esc}[42m"
5050 yellowb="${esc}[43m" blueb="${esc}[44m"; purpleb="${esc}[45m"
5051 cyanb="${esc}[46m"; whiteb="${esc}[47m"
5053 boldon="${esc}[1m"; boldoff="${esc}[22m"
5054 italicson="${esc}[3m"; italicsoff="${esc}[23m"
5055 ulon="${esc}[4m"; uloff="${esc}[24m"
5056 invon="${esc}[7m"; invoff="${esc}[27m"
5061 # note in this first use that switching colors doesn't require a reset
5062 # first - the new color overrides the old one.
5070 ${yellowf} ▄███████▄${reset} ${redf} ▄██████▄${reset} ${greenf} ▄██████▄${reset} ${bluef} ▄██████▄${reset} ${purplef} ▄██████▄${reset} ${cyanf} ▄██████▄${reset}
5071 ${yellowf}▄█████████▀▀${reset} ${redf}▄${whitef}█▀█${redf}██${whitef}█▀█${redf}██▄${reset} ${greenf}▄${whitef}█▀█${greenf}██${whitef}█▀█${greenf}██▄${reset} ${bluef}▄${whitef}█▀█${bluef}██${whitef}█▀█${bluef}██▄${reset} ${purplef}▄${whitef}█▀█${purplef}██${whitef}█▀█${purplef}██▄${reset} ${cyanf}▄${whitef}█▀█${cyanf}██${whitef}█▀█${cyanf}██▄${reset}
5072 ${yellowf}███████▀${reset} ${redf}█${whitef}▄▄█${redf}██${whitef}▄▄█${redf}███${reset} ${greenf}█${whitef}▄▄█${greenf}██${whitef}▄▄█${greenf}███${reset} ${bluef}█${whitef}▄▄█${bluef}██${whitef}▄▄█${bluef}███${reset} ${purplef}█${whitef}▄▄█${purplef}██${whitef}▄▄█${purplef}███${reset} ${cyanf}█${whitef}▄▄█${cyanf}██${whitef}▄▄█${cyanf}███${reset}
5073 ${yellowf}███████▄${reset} ${redf}████████████${reset} ${greenf}████████████${reset} ${bluef}████████████${reset} ${purplef}████████████${reset} ${cyanf}████████████${reset}
5074 ${yellowf}▀█████████▄▄${reset} ${redf}██▀██▀▀██▀██${reset} ${greenf}██▀██▀▀██▀██${reset} ${bluef}██▀██▀▀██▀██${reset} ${purplef}██▀██▀▀██▀██${reset} ${cyanf}██▀██▀▀██▀██${reset}
5075 ${yellowf} ▀███████▀${reset} ${redf}▀ ▀ ▀ ▀${reset} ${greenf}▀ ▀ ▀ ▀${reset} ${bluef}▀ ▀ ▀ ▀${reset} ${purplef}▀ ▀ ▀ ▀${reset} ${cyanf}▀ ▀ ▀ ▀${reset}
5077 ${boldon}${yellowf} ▄███████▄ ${redf} ▄██████▄ ${greenf} ▄██████▄ ${bluef} ▄██████▄ ${purplef} ▄██████▄ ${cyanf} ▄██████▄${reset}
5078 ${boldon}${yellowf}▄█████████▀▀ ${redf}▄${whitef}█▀█${redf}██${whitef}█▀█${redf}██▄ ${greenf}▄${whitef}█▀█${greenf}██${whitef}█▀█${greenf}██▄ ${bluef}▄${whitef}█▀█${bluef}██${whitef}█▀█${bluef}██▄ ${purplef}▄${whitef}█▀█${purplef}██${whitef}█▀█${purplef}██▄ ${cyanf}▄${whitef}█▀█${cyanf}██${whitef}█▀█${cyanf}██▄${reset}
5079 ${boldon}${yellowf}███████▀ ${redf}█${whitef}▄▄█${redf}██${whitef}▄▄█${redf}███ ${greenf}█${whitef}▄▄█${greenf}██${whitef}▄▄█${greenf}███ ${bluef}█${whitef}▄▄█${bluef}██${whitef}▄▄█${bluef}███ ${purplef}█${whitef}▄▄█${purplef}██${whitef}▄▄█${purplef}███ ${cyanf}█${whitef}▄▄█${cyanf}██${whitef}▄▄█${cyanf}███${reset}
5080 ${boldon}${yellowf}███████▄ ${redf}████████████ ${greenf}████████████ ${bluef}████████████ ${purplef}████████████ ${cyanf}████████████${reset}
5081 ${boldon}${yellowf}▀█████████▄▄ ${redf}██▀██▀▀██▀██ ${greenf}██▀██▀▀██▀██ ${bluef}██▀██▀▀██▀██ ${purplef}██▀██▀▀██▀██ ${cyanf}██▀██▀▀██▀██${reset}
5082 ${boldon}${yellowf} ▀███████▀ ${redf}▀ ▀ ▀ ▀ ${greenf}▀ ▀ ▀ ▀ ${bluef}▀ ▀ ▀ ▀ ${purplef}▀ ▀ ▀ ▀ ${cyanf}▀ ▀ ▀ ▀${reset}
5089 :header-args+: :tangle ~/.local/bin/invade-em :shebang "#!/bin/bash"
5094 # ANSI color scheme script featuring Space Invaders
5096 # Original: http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921
5097 # Modified by lolilolicon
5103 printf -v $j$i %b "\e[${!j}${i}m"
5111 $f1 ▀▄ ▄▀ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4 ▀▄ ▄▀ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst
5112 $f1 ▄█▀███▀█▄ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4 ▄█▀███▀█▄ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst
5113 $f1█▀███████▀█ $f2▀▀███▀▀███▀▀ $f3▀█▀██▀█▀ $f4█▀███████▀█ $f5▀▀███▀▀███▀▀ $f6▀█▀██▀█▀$rst
5114 $f1▀ ▀▄▄ ▄▄▀ ▀ $f2 ▀█▄ ▀▀ ▄█▀ $f3▀▄ ▄▀ $f4▀ ▀▄▄ ▄▄▀ ▀ $f5 ▀█▄ ▀▀ ▄█▀ $f6▀▄ ▄▀$rst
5116 $bld$f1▄ ▀▄ ▄▀ ▄ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4▄ ▀▄ ▄▀ ▄ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst
5117 $bld$f1█▄█▀███▀█▄█ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4█▄█▀███▀█▄█ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst
5118 $bld$f1▀█████████▀ $f2▀▀▀██▀▀██▀▀▀ $f3▀▀█▀▀█▀▀ $f4▀█████████▀ $f5▀▀▀██▀▀██▀▀▀ $f6▀▀█▀▀█▀▀$rst
5119 $bld$f1 ▄▀ ▀▄ $f2▄▄▀▀ ▀▀ ▀▀▄▄ $f3▄▀▄▀▀▄▀▄ $f4 ▄▀ ▀▄ $f5▄▄▀▀ ▀▀ ▀▀▄▄ $f6▄▀▄▀▀▄▀▄$rst