[rc/libinput] migrate my libinput xorg configuration
[~bandali/configs] / rc.org
1 #+title: rc.org
2 #+property: header-args :comments link :mkdirp yes :results silent
3
4 * About
5
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=.
9
10 Note: This file is best viewed inside Emacs with org mode.
11
12 * Configs
13
14 This section contains the configuration files (dotfiles) of various
15 programs I use.
16
17 ** [[https://github.com/afewmail/afew][afew]]
18 :PROPERTIES:
19 :header-args+: :tangle ~/.config/afew/config
20 :END:
21
22 #+begin_quote
23 an initial tagging script for notmuch mail
24 #+end_quote
25
26 #+begin_src conf
27 # This is the default filter chain
28 [SpamFilter]
29 #[ClassifyingFilter]
30 [KillThreadsFilter]
31 #[ListMailsFilter]
32 [ArchiveSentMailsFilter]
33 sent_tag = sent
34 [InboxFilter]
35
36 #[Filter.1]
37 #query = 'folder:amin/lists/.haskell-cafe'
38 #tags = +lists;+lists/haskell-cafe
39 #message = lists/haskell-cafe
40
41 #[Filter.2]
42 #query = 'folder:amin/lists/.haskell-weekly'
43 #tags = +lists;+lists/haskell-weekly
44 #message = lists/haskell-weekly
45
46 #[Filter.3]
47 #query = 'folder:amin/lists/.hackernewsletter'
48 #tags = +lists;+lists/hackernewsletter
49 #message = lists/hackernewsletter
50
51
52 #[FolderNameFilter]
53 #folder_blacklist = Inbox
54 #maildir_separator = /.
55 #folder_transforms = Drafts:draft Junk:spam Trash:deleted Sent:sent Archive:archive lists/haskell-cafe:lists/haskell-cafe
56 #+end_src
57
58 ** bspwm
59
60 *** bspwmrc
61 :PROPERTIES:
62 :header-args+: :tangle ~/.config/bspwm/bspwmrc :shebang "#!/bin/sh"
63 :END:
64
65 #+begin_src sh
66 sxhkd &
67 sh ~/.fehbg &
68 xfce4-panel -d &
69 #compton &
70 sleep 0.5 && pasystray --notify=all &
71
72 bspc monitor -d I II III IV V VI VII VIII IX X
73 #bspc monitor eDP-1 -d I II III IV V
74 #bspc monitor HDMI-1 -d VI VII VIII IX X
75
76 #bspc config border_width 2
77 #bspc config window_gap 8
78 bspc config window_gap 0
79
80 bspc config bottom_padding 26
81
82 bspc config split_ratio 0.52
83 bspc config borderless_monocle true
84 bspc config gapless_monocle true
85 bspc config click_to_focus button1
86 bspc config directional_focus_tightness low
87
88 bspc rule -a Firefox desktop='^1' follow=on
89 bspc rule -a Nightly desktop='^1' follow=on
90 bspc rule -a Emacs desktop='^2' state=tiled follow=on
91 #bspc rule -a Chromium desktop='^4' follow=on
92 bspc rule -a URxvt state=floating
93 bspc rule -a URxvt:tiled state=tiled
94 bspc rule -a Connman-gtk state=floating
95 bspc rule -a Xfce4-panel state=floating
96 bspc rule -a TelegramDesktop state=floating
97 bspc rule -a Ec state=floating
98 bspc rule -a Pavucontrol state=floating
99 bspc rule -a Eog state=floating
100 bspc rule -a Seahorse state=floating
101 bspc rule -a mpv state=floating
102 bspc rule -a Evince state=floating
103 bspc rule -a Meld state=floating
104 bspc rule -a Autokey-gtk state=floating
105 bspc rule -a Mousepad state=floating
106 bspc rule -a Wrapper-1.0 state=floating
107 bspc rule -a File-roller state=floating
108 bspc rule -a Gnome-disks state=floating
109 bspc rule -a Termite state=floating
110 bspc rule -a Termite:tiled state=tiled
111 bspc rule -a Thunderbird:Calendar state=floating
112 bspc rule -a Audacity state=floating
113 bspc rule -a Proof state=floating # pvs x-show-proof
114 bspc rule -a Nm-connection-editor state=floating
115 bspc rule -a Wire state=floating
116 bspc rule -a discord state=floating
117 bspc rule -a X2goclient state=floating
118 bspc rule -a SimpleScreenRecorder state=floating
119 bspc rule -a Gimp state=floating
120 bspc rule -a Wrapper-2.0 state=floating
121 bspc rule -a Zathura state=tiled
122 #+end_src
123
124 *** sxhkdrc
125 :PROPERTIES:
126 :header-args+: :tangle ~/.config/sxhkd/sxhkdrc
127 :END:
128
129 #+begin_src conf
130 #
131 # wm independent hotkeys
132 #
133
134 # terminal emulator
135 super + {_,shift} + Return
136 urxvt{_, -name tiled}
137
138 #super + {_,shift} + Return
139 # termite{_, --name=tiled}
140
141 # program launcher
142 super + space
143 rofi -show run -display-run '> ' -display-window ' 🗔 '
144
145 super + alt + space
146 xfce4-popup-whiskermenu
147
148 # window finder
149 super + backslash
150 rofi -show window -display-run '> ' -display-window ' 🗔 '
151
152 # password manager
153 alt + space
154 rofi-pass
155
156 # firefox
157 #super + r
158 # firefox
159
160 # chromium
161 #super + c
162 # chromium -incognito
163
164 # emacs
165 super + e
166 emacs
167
168 # make sxhkd reload its configuration files:
169 super + Escape
170 pkill -USR1 -x sxhkd
171
172 # volume {up,down}
173 XF86Audio{Raise,Lower}Volume
174 pamixer --allow-boost --{in,de}crease 5
175
176 # mute
177 XF86AudioMute
178 pamixer --toggle-mute
179
180 # playback control
181 XF86Audio{Play,Prev,Next}
182 mpc {toggle,prev,next}
183
184 # lock the screen
185 super + shift + q
186 light-locker-command -l
187
188 # Toggle keyboard layout
189 super + F7
190 toggle-layout
191
192 # Toggle Xfce presentation mode
193 XF86LaunchB
194 toggle-presentation-mode
195
196 # monitor brightness
197 XF86MonBrightness{Up,Down}
198 light -{A,U} 5
199
200 super + apostrophe
201 rofi-light
202
203 # keyboard brightness
204 #XF86KbdBrightness{Up,Down}
205 # kbdlight {up,down}
206
207 #
208 # bspwm hotkeys
209 #
210
211 # quit bspwm normally
212 super + alt + Escape
213 bspc quit
214
215 # close and kill
216 super + {w,q}
217 bspc node -{c,k}
218
219 # alternate between the tiled and monocle layout
220 super + m
221 bspc desktop -l next
222
223 # send the newest marked node to the newest preselected node
224 super + y
225 bspc node newest.marked.local -n newest.!automatic.local
226
227 # swap the current node and the biggest node
228 super + g
229 bspc node -s biggest
230
231 #
232 # state/flags
233 #
234
235 # set the window state
236 super + {t,shift + t,s,f}
237 bspc node -t {tiled,pseudo_tiled,floating,fullscreen}
238
239 # set the node flags
240 super + ctrl + {m,x,y,z}
241 bspc node -g {marked,locked,sticky,private}
242
243 #
244 # focus/swap
245 #
246
247 # focus the node in the given direction
248 super + {_,shift + }{h,j,k,l}
249 bspc node -{f,s} {west,south,north,east}
250
251 # focus the node for the given path jump
252 super + {p,b,comma,period}
253 bspc node -f @{parent,brother,first,second}
254
255 # focus the next/previous node in the current desktop
256 super + {_,shift + }c
257 bspc node -f {next,prev}.local
258
259 # focus the next/previous desktop in the current monitor
260 super + bracket{left,right}
261 bspc desktop -f {prev,next}.local
262
263 # send to next/prev desktop
264 super + shift + bracket{left,right}
265 bspc node -d {prev,next} --follow
266
267 # focus the last node/desktop
268 super + {grave,Tab}
269 bspc {node,desktop} -f last
270
271 # focus the older or newer node in the focus history
272 super + {o,i}
273 bspc wm -h off; \
274 bspc node {older,newer} -f; \
275 bspc wm -h on
276
277 # focus or send to the given desktop
278 super + {_,shift + }{1-9,0}
279 bspc {desktop -f,node -d} '^{1-9,10}'
280
281 #
282 # preselect
283 #
284
285 # preselect the direction
286 super + ctrl + {h,j,k,l}
287 bspc node -p {west,south,north,east}
288
289 # preselect the ratio
290 super + ctrl + {1-9}
291 bspc node -o 0.{1-9}
292
293 # cancel the preselection for the focused node
294 super + ctrl + space
295 bspc node -p cancel
296
297 # cancel the preselection for the focused desktop
298 super + ctrl + shift + space
299 bspc query -N -d | xargs -I id -n 1 bspc node id -p cancel
300
301 #
302 # move/resize
303 #
304
305 # expand a window by moving one of its side outward
306 super + alt + {h,j,k,l}
307 bspc node -z {left -20 0,bottom 0 20,top 0 -20,right 20 0}
308
309 # contract a window by moving one of its side inward
310 super + alt + shift + {h,j,k,l}
311 bspc node -z {right -20 0,top 0 20,bottom 0 -20,left 20 0}
312
313 # move a floating window
314 super + {Left,Down,Up,Right}
315 bspc node -v {-20 0,0 20,0 -20,20 0}
316
317 #alt + bracket{left,right}
318 # xdotool key --clearmodifiers ctrl+Page_{Up,Down}
319 #+end_src
320
321 ** compton
322 :PROPERTIES:
323 :header-args+: :tangle ~/.config/compton.conf
324 :END:
325
326 #+begin_src conf
327 # Shadow
328 shadow = false; # Enabled client-side shadows on windows.
329 no-dock-shadow = true; # Avoid drawing shadows on dock/panel windows.
330 no-dnd-shadow = true; # Don't draw shadows on DND windows.
331 clear-shadow = true; # Zero the part of the shadow's mask behind the
332 # window. Fix some weirdness with ARGB windows.
333 shadow-radius = 5; # The blur radius for shadows. (default 12)
334 shadow-offset-x = -5; # The left offset for shadows. (default -15)
335 shadow-offset-y = -5; # The top offset for shadows. (default -15)
336 # shadow-opacity = 0.7; # The translucency for shadows. (default .75)
337 # shadow-red = 0.0; # Red color value of shadow. (0.0 - 1.0, defaults to 0)
338 # shadow-green = 0.0; # Green color value of shadow. (0.0 - 1.0, defaults to 0)
339 # shadow-blue = 0.0; # Blue color value of shadow. (0.0 - 1.0, defaults to 0)
340 shadow-exclude = [ "n:e:Notification", "class_g = 'Chromium'", "class_g = 'Dmenu'", "class_g = 'Firefox' && argb" ]; # Exclude conditions for shadows.
341 # shadow-exclude = "n:e:Notification";
342 #shadow-exclude = [ "_GTK_FRAME_EXTENTS@:c" ] # Fix dual shadow on some gtk3 powered applications
343 shadow-ignore-shaped = true; # Avoid drawing shadow on all shaped windows
344 # (see also: --detect-rounded-corners)
345
346 # Opacity
347 menu-opacity = 1.0; # The opacity for menus. (default 1.0)
348 #inactive-opacity = 0.9; # Default opacity of inactive windows. (0.0 - 1.0)
349 # active-opacity = 0.8; # Default opacity for active windows. (0.0 - 1.0)
350 frame-opacity = 1.0; # Opacity of window titlebars and borders. (0.1 - 1.0)
351 # inactive-opacity-override = true; # Let inactive opacity set by 'inactive-opacity' overrides
352 # value of _NET_WM_OPACITY. Bad choice.
353 alpha-step = 0.06; # XRender backend: Step size for alpha pictures. Increasing
354 # it may result in less X resource usage,
355 # Yet fading may look bad.
356 #inactive-dim = 0.5; # Dim inactive windows. (0.0 - 1.0)
357 #inactive-dim-fixed = true; # Do not let dimness adjust based on window opacity.
358 # blur-background = true; # Blur background of transparent windows.
359 # Bad performance with X Render backend.
360 # GLX backend is preferred.
361 # blur-background-frame = true; # Blur background of opaque windows with transparent
362 # frames as well.
363 blur-background-fixed = true; # Do not let blur radius adjust based on window opacity.
364 blur-background-exclude = [ "window_type = 'dock'", "window_type = 'desktop'" ];
365 # Exclude conditions for background blur.
366
367 # Fading
368 fading = false; # Fade windows during opacity changes.
369 fade-delta = 3; # The time between steps in a fade in milliseconds. (default 10).
370 fade-in-step = 0.03; # Opacity change between steps while fading in. (default 0.028).
371 fade-out-step = 0.03; # Opacity change between steps while fading out. (default 0.03).
372 # no-fading-openclose = true; # Avoid fade windows in/out when opening/closing.
373 fade-exclude = [ ]; # Exclude conditions for fading.
374
375 # Other
376 backend = "glx" # Backend to use: "xrender" or "glx". GLX backend is typically
377 # much faster but depends on a sane driver.
378 mark-wmwin-focused = true; # Try to detect WM windows and mark them as active.
379 mark-ovredir-focused = true; # Mark all non-WM but override-redirect windows active (e.g. menus).
380 use-ewmh-active-win = true; # Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused
381 # instead of using FocusIn/Out events. Usually more reliable but
382 # depends on a EWMH-compliant WM.
383 detect-rounded-corners = false; # Detect rounded corners and treat them as rectangular when --shadow-ignore- shaped is on.
384 detect-client-opacity = true; # Detect _NET_WM_OPACITY on client windows, useful for window
385 # managers not passing _NET_WM_OPACITY of client windows to frame
386 # windows.
387 refresh-rate = 0; # For --sw-opti: Specify refresh rate of the screen. 0 for auto.
388 vsync = "drm"; # "none", "drm", "opengl", "opengl-oml", "opengl-swc", "opengl-mswc"
389 # See man page for more details.
390 dbe = false; # Enable DBE painting mode. Rarely needed.
391 paint-on-overlay = true; # Painting on X Composite overlay window. Recommended.
392 sw-opti = false; # Limit compton to repaint at most once every 1 / refresh_rate.
393 # Incompatible with certain VSync methods.
394 unredir-if-possible = false; # Unredirect all windows if a full-screen opaque window is
395 # detected, to maximize performance for full-screen windows.
396 focus-exclude = [ ]; # A list of conditions of windows that should always be considered
397 # focused.
398 detect-transient = true; # Use WM_TRANSIENT_FOR to group windows, and consider windows in
399 # the same group focused at the same time.
400 detect-client-leader = true; # Use WM_CLIENT_LEADER to group windows.
401 invert-color-include = [ ]; # Conditions for windows to be painted with inverted color.
402
403 # GLX backend # GLX backend fine-tune options. See man page for more info.
404 glx-no-stencil = true; # Recommended.
405 glx-copy-from-front = false; # Useful with --glx-swap-method,
406 # glx-use-copysubbuffermesa = true; # Recommended if it works. Breaks VSync.
407 # glx-no-rebind-pixmap = true; # Recommended if it works.
408 glx-no-rebind-pixmap = true; # Recommended if it works.
409 #glx-swap-method = "4"; # See man page.
410 glx-swap-method = "4"; # See man page.
411
412 # Window type settings
413 wintypes:
414 {
415 tooltip = { fade = true; shadow = false; opacity = 1; focus = true; };
416 menu = { shadow = false; };
417 dropdown_menu = { shadow = false; };
418 popup_menu = { shadow = false; };
419 utility = { shadow = false; };
420 # fade: Fade the particular type of windows.
421 # shadow: Give those windows shadow
422 # opacity: Default opacity for the type of windows.
423 # focus: Whether to always consider windows of this type focused.
424 };
425 #+end_src
426
427 ** Dunst
428 :PROPERTIES:
429 :header-args+: :tangle ~/.config/dunst/dunstrc
430 :END:
431
432 #+begin_src conf
433 [global]
434 #font = Ubuntu Mono 10.5
435 font = Inconsolata 11
436
437 # Path to default icons.
438 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/
439
440 icon_position = left
441 # <b>bold</b>
442 # <i>italic</i>
443 # <s>strikethrough<s/>
444 # <u>underline</u>
445 markup = full
446 # The format of the message. Possible variables are:
447 # %a appname
448 # %s summary
449 # %b body
450 # %i iconname (including its path)
451 # %I iconname (without its path)
452 # %p progress value if set ([ 0%] to [100%]) or nothing
453 # Markup is allowed
454 format = "<b>%s</b>\n%b"
455 # Sort messages by urgency
456 sort = yes
457 # Show how many messages are currently hidden (because of geometry)
458 indicate_hiddenl= no
459 # Alignment of message text.
460 # Possible values are "left", "center" and "right"
461 alignment = center
462 # The frequency with wich text that is longer than the notification
463 # window allows bounces back and forth.
464 # This option conflicts with 'word_wrap'.
465 # Set to 0 to disable
466 bounce_freq = 3
467 # show age of message if message is older than show_age_threshold seconds.
468 # set to -1 to disable
469 show_age_threshold = -1
470 # split notifications into multiple lines if they don't fit into geometry
471 word_wrap = yes
472 # ignore newlines '\n' in notifications
473 ignore_newline = no
474 # The geometry of the message window.
475 # geometry [{width}]x{height}][+/-{x}+/-{y}]
476 # The height is measured in number of notifications everything else in pixels. If the width
477 # is omitted but the height is given ("-geometry x2"), the message window
478 # expands over the whole screen (dmenu-like). If width is 0,
479 # the window expands to the longest message displayed.
480 # A positive x is measured from the left, a negative from the
481 # right side of the screen. Y is measured from the top and down respectevly.
482 # The width can be negative. In this case the actual width is the
483 # screen width minus the width defined in within the geometry option.
484 #geometry = "410x12-12+12"
485 #geometry = "0x0-30-30"
486 geometry = "260x12-30-30"
487 # The transparency of the window. range: [0; 100]
488 # This option will only work if a compositing windowmanager is present (e.g. xcompmgr, compiz, etc..)
489 transparency = 0
490 # Don't remove messages, if the user is idle (no mouse or keyboard input)
491 # for longer than idle_threshold seconds.
492 # Set to 0 to disable.
493 idle_threshold = 120
494 # Which monitor should the notifications be displayed on.
495 monitor = 0
496 # Display notification on focused monitor. Possible modes are:
497 # mouse: follow mouse pointer
498 # keyboard: follow window with keyboard focus
499 # none: don't follow anything
500 #
501 # "keyboard" needs a windowmanager that exports the _NET_ACTIVE_WINDOW property.
502 # This should be the case for almost all modern windowmanagers.
503 #
504 # If this option is set to mouse or keyboard, the monitor option will be
505 # ignored.
506 follow = keyboard
507 # should a notification popped up from history be sticky or
508 # timeout as if it would normally do.
509 sticky_history = yes
510 # The height of a single line. If the height is smaller than the font height,
511 # it will get raised to the font height.
512 # This adds empty space above and under the text.
513 line_height = 0
514
515 show_indicators = yes
516
517 # Draw a line of 'separatpr_height' pixel height between two notifications.
518 # Set to 0 to disable
519 separator_height = 3
520 # padding between text and separator
521 padding = 8
522 # horizontal padding
523 horizontal_padding = 8
524 # Define a color for the separator.
525 # possible values are:
526 # * auto: dunst tries to find a color fitting to the background
527 # * foreground: use the same color as the foreground
528 # * frame: use the same color as the frame.
529 # * anything else will be interpreted as a X color
530 separator_color = foreground
531 # print a notification on startup
532 # This is mainly for error detection, since dbus (re-)starts dunst
533 # automatically after a crash.
534 startup_notification = false
535 # dmenu path
536 #dmenu = /usr/bin/dmenu -p dunst:
537 dmenu = /usr/bin/rofi -dmenu -p dunst:
538 # browser for opening urls in context menu
539 browser = /usr/bin/firefox -new-tab
540 [frame]
541 width = 0
542 color = "#377222"
543 [shortcuts]
544 # shortcuts are specified as [modifier+][modifier+]...key
545 # available modifiers are 'ctrl', 'mod1' (the alt-key), 'mod2', 'mod3'
546 # and 'mod4' (windows-key)
547 # xev might be helpful to find names for keys
548 # close notification
549 close = ctrl+space
550 # close all notifications
551 close_all = ctrl+shift+space
552 # redisplay last message(s)
553 # On the US keyboard layout 'grave' is normally above TAB and left of '1'.
554 history = ctrl+shift+h
555 # context menu
556 context = ctrl+shift+period
557 [urgency_low]
558 # IMPORTANT: colors have to be defined in quotation marks.
559 # Otherwise the '#' and following would be interpreted as a comment.
560 background = "#1d2a30"
561 foreground = "#71c2af"
562 timeout = 3
563 [urgency_normal]
564 background = "#1d2a30"
565 foreground = "#71c2af"
566 timeout = 0
567 [urgency_critical]
568 background = "#1d2a30"
569 foreground = "#ff9982"
570 timeout = 0
571
572 # Every section that isn't one of the above is interpreted as a rules
573 # to override settings for certain messages.
574 # Messages can be matched by 'appname', 'summary', 'body' or 'icon'
575 # and you can override the 'timeout', 'urgency', 'foreground', 'background'
576 # and 'format'.
577 # Shell-like globbing will get expanded.
578 #
579 # SCRIPTING
580 # you can specify a script that gets run when the rule matches by setting
581 # the 'script' option.
582 # The script will be called as follows:
583 # script appname summary body icon urgency
584 # where urgency can be "LOW", "NORMAL" or "CRITICAL".
585 #
586 # NOTE: if you don't want a notification to be displayed, set the format to ""
587 # NOTE: It might be helpful to run dunst -print in a terminal in order to find
588 # fitting options for rules.
589 #[espeak]
590 # summary = "*"
591 # script = dunst_espeak.sh
592 #[script-test]
593 # summary = "*script*"
594 # script = dunst_test.sh
595 #[ignore]
596 ## This notification will not be displayed
597 # summary = "foobar"
598 # format = ""
599 #[signed_on]
600 # appname = Pidgin
601 # summary = "*signed on*"
602 # urgency = low
603 #
604 #[signed_off]
605 # appname = Pidgin
606 # summary = *signed off*
607 # urgency = low
608 #
609 #[says]
610 # appname = Pidgin
611 # summary = *says*
612 # urgency = critical
613 #
614 #[twitter]
615 # appname = Pidgin
616 # summary = *twitter.com*
617 # urgency = normal
618 #
619 [xfpm-backlight]
620 summary = *Brightness*
621 urgency = low
622 #+end_src
623
624 ** Fontconfig
625 :PROPERTIES:
626 :header-args+: :tangle ~/.config/fontconfig/fonts.conf
627 :END:
628
629 #+begin_src xml
630 <?xml version="1.0"?>
631 <!DOCTYPE fontconfig SYSTEM "fonts.dtd">
632 <fontconfig>
633 <match target="font">
634 <edit mode="assign" name="rgba">
635 <const>rgb</const>
636 </edit>
637 </match>
638 <match target="font">
639 <edit mode="assign" name="hinting">
640 <bool>true</bool>
641 </edit>
642 </match>
643 <match target="font">
644 <edit mode="assign" name="hintstyle">
645 <const>hintslight</const>
646 </edit>
647 </match>
648 <match target="font">
649 <edit mode="assign" name="antialias">
650 <bool>true</bool>
651 </edit>
652 </match>
653 <match target="font">
654 <edit mode="assign" name="lcdfilter">
655 <const>lcddefault</const>
656 </edit>
657 </match>
658 <dir>~/.fonts</dir>
659
660 <!-- Use Liberation Sans for Helvetica (instead of Nimbus Sans) -->
661 <alias binding="same">
662 <family>Helvetica</family>
663 <accept>
664 <family>Liberation Sans</family>
665 </accept>
666 </alias>
667 </fontconfig>
668 #+end_src
669
670 ** Git
671
672 *** gitconfig
673 :PROPERTIES:
674 :header-args+: :tangle ~/.gitconfig
675 :END:
676
677 **** user
678 #+begin_src conf
679 [user]
680 name = Amin Bandali
681 email = amin@aminb.org
682 # signingkey = 4E05246AB0BF7FFB
683 #+end_src
684
685 **** signing
686 #+begin_src conf
687 # [commit]
688 # gpgsign = true
689 # [format]
690 # signoff = true
691 #+end_src
692
693 **** core
694 #+begin_src conf
695 [core]
696 autocrlf = input # CRLF -> LF on commit
697 editor = emacsclient -t
698 excludesfile = ~/.gitignore_global
699 pager = "less"
700 #+end_src
701
702 **** gpg
703 #+begin_src conf
704 [gpg]
705 program = gpg2
706 #+end_src
707
708 **** alias
709 #+begin_src conf
710 [alias]
711 git = !exec git # handle nested git calls, e.g. git git status
712 aliases = config --get-regexp '^alias\\.'
713 a = add
714 s = status
715 sl = status --long
716 c = checkout
717 cb = checkout -b
718 b = branch
719 r = rebase
720 p = pull
721 pr = pull --rebase
722 ps = push
723 psf = push --force
724 #+end_src
725
726 **** color
727 #+begin_src conf
728 [color]
729 ui = auto
730 [color "status"]
731 added = green bold
732 changed = red bold
733 untracked = red bold
734 [color "branch"]
735 current = green bold
736 remote = magenta bold
737 [color "diff"]
738 new = green bold
739 old = red bold
740 #+end_src
741
742 **** status
743 #+begin_src conf
744 [status]
745 # showUntrackedFiles = all
746 short=true
747 branch=true
748 #+end_src
749
750 **** github
751 #+begin_src conf
752 [github]
753 user = aminb
754 #+end_src
755
756 *** gitignore
757 :PROPERTIES:
758 :header-args+: :tangle ~/.gitignore_global
759 :END:
760
761 #+begin_src conf
762 *.orig
763 *.py[co]
764 *.sublime-workspace
765 *~
766 .DS_Store
767 *.elc
768 *-autoloads.el
769 #+end_src
770
771 ** Latexmk
772 :PROPERTIES:
773 :header-args+: :tangle ~/.latexmkrc
774 :END:
775
776 #+begin_src conf
777 $pdf_previewer = "start zathura %O %S";
778 $clean_ext = "aux out";
779
780 # $pdf_update_method = 4;
781 # $pdf_update_command = "zathura %O %S";
782
783 # Synctex allows one to jump to from the PDF in Zathura to the source in Emacs
784 # by Ctrl+click in the PDF.
785 # Tell latexmk to use Zathura as a previewer, and run emacsclient as the Synctex
786 # editor.
787 # $pdf_previewer = 'exec zathura --synctex-forward -x \'emacsclient --no-wait +%{line} %{input}\' %O %S';
788 #+end_src
789
790 ** libinput
791
792 Improve XPS 15 9560's touchpad experience.
793
794 #+begin_src conf :tangle (when (and (eq system-type 'gnu/linux) (string= (system-name) "plasma")) "/sudo::/etc/X11/xorg.conf.d/30-touchpad.conf")
795 Section "InputClass"
796 Identifier "libinput touchpad catchall"
797 Driver "libinput"
798 MatchIsTouchpad "on"
799 Option "ClickMethod" "clickfinger"
800 Option "NaturalScrolling" "true"
801 Option "Tapping" "on"
802 Option "TappingButtonMap" "lrm"
803 EndSection
804 #+end_src
805
806 ** getmail
807
808 *** getmailrc
809 :PROPERTIES:
810 :header-args+: :tangle ~/.getmail/getmailrc
811 :END:
812
813 #+begin_src conf
814 [retriever]
815 type = SimplePOP3SSLRetriever
816 server = fencepost.gnu.org
817 username = aminb
818 password_command = ("gpg2", "--no-tty", "-q", "-d", "~/.passwd/gnu.gpg")
819 port = 995
820 use_apop = True
821
822 [destination]
823 type = Maildir
824 path = ~/mail/gnu/Inbox/
825
826 [options]
827 delete = True
828 #+end_src
829
830 *** getmail.service
831 :PROPERTIES:
832 :header-args+: :tangle ~/.config/systemd/user/getmail.service
833 :END:
834
835 #+begin_src conf :tangle no
836 [Unit]
837 Description=getmail service
838
839 [Service]
840 Type=oneshot
841 ExecStart=/usr/bin/getmail
842 StandardOutput=syslog
843 StandardError=syslog
844 #+end_src
845
846 *** getmail.timer
847 :PROPERTIES:
848 :header-args+: :tangle ~/.config/systemd/user/getmail.timer
849 :END:
850
851 #+begin_src conf :tangle no
852 [Unit]
853 Description=getmail timer
854
855 [Timer]
856 OnCalendar=*:0/30
857 Persistent=true
858 Unit=getmail.service
859
860 [Install]
861 WantedBy=timers.target
862 #+end_src
863
864 ** GnuPG
865 :PROPERTIES:
866 :header-args+: :tangle ~/.gnupg/gpg-agent.conf
867 :END:
868
869 #+begin_src conf
870 default-cache-ttl 43200
871 max-cache-ttl 43200
872
873 default-cache-ttl-ssh 10800
874 max-cache-ttl-ssh 10800
875
876 # pinentry-program /usr/bin/pinentry-qt
877 #+end_src
878
879 ** GTK
880
881 *** gtk-2.0
882 :PROPERTIES:
883 :header-args+: :tangle ~/.gtkrc-2.0
884 :END:
885
886 #+begin_src conf
887 gtk-theme-name="Greybird"
888 gtk-icon-theme-name="Paper"
889 gtk-font-name="Ubuntu 10"
890 gtk-menu-images=0
891 # gtk-key-theme-name = "Emacs"
892 #+end_src
893
894 *** gtk-3.0
895 :PROPERTIES:
896 :header-args+: :tangle ~/.config/gtk-3.0/settings.ini
897 :END:
898
899 #+begin_src conf :tangle no
900 [Settings]
901 gtk-icon-theme-name = Paper
902 # gtk-theme-name = Adwaita
903
904 gtk-theme-name = Greybird
905 # gtk-theme-name = Arc-Darker
906 # gtk-theme-name = Numix-ArchBlue
907
908 gtk-font-name = Ubuntu 10
909 # gtk-key-theme-name = Emacs
910 #+end_src
911
912 ** isync
913
914 *** mbsyncrc
915 :PROPERTIES:
916 :header-args+: :tangle ~/.mbsyncrc
917 :END:
918
919 #+begin_src conf
920 # Global defaults
921 CopyArrivalDate yes
922
923 ######
924 IMAPAccount amin
925 Host nix.aminb.org
926 User amin@aminb.org
927 PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/amin.gpg"
928 SSLType IMAPS
929
930 IMAPStore amin-remote
931 Account amin
932
933 MaildirStore amin-local
934 Path ~/mail/amin/
935 Inbox ~/mail/amin/Inbox
936 SubFolders Verbatim
937
938 Channel amin
939 Master :amin-remote:
940 Slave :amin-local:
941 Patterns * !dovecot*
942 Create Both
943 SyncState *
944
945 ######
946 IMAPAccount uwaterloo
947 Host connect.uwaterloo.ca
948 User abandali
949 PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/uwaterloo.gpg"
950 SSLType IMAPS
951
952 IMAPStore uwaterloo-remote
953 Account uwaterloo
954
955 MaildirStore uwaterloo-local
956 Path ~/mail/uwaterloo/
957 Inbox ~/mail/uwaterloo/Inbox
958 SubFolders Verbatim
959
960 Channel uwaterloo
961 Master :uwaterloo-remote:
962 Slave :uwaterloo-local:
963 Patterns * !dovecot*
964 Create Both
965 SyncState *
966 #+end_src
967
968 *** mbsync.service
969 :PROPERTIES:
970 :header-args+: :tangle ~/.config/systemd/user/mbsync.service
971 :END:
972
973 #+begin_src conf :tangle no
974 [Unit]
975 Description=mbsync service
976
977 [Service]
978 Type=oneshot
979 ExecStart=/usr/bin/mbsync -Va
980 StandardOutput=syslog
981 StandardError=syslog
982 #+end_src
983
984 *** mbsync.timer
985 :PROPERTIES:
986 :header-args+: :tangle ~/.config/systemd/user/mbsync.timer
987 :END:
988
989 #+begin_src conf :tangle no
990 [Unit]
991 Description=mbsync timer
992
993 [Timer]
994 OnCalendar=*:0/15
995 Persistent=true
996 Unit=mbsync.service
997
998 [Install]
999 WantedBy=timers.target
1000 #+end_src
1001
1002 ** mpd
1003 :PROPERTIES:
1004 :header-args+: :tangle ~/.config/mpd/mpd.conf
1005 :END:
1006
1007 #+begin_src conf
1008 # An example configuration file for MPD.
1009 # Read the user manual for documentation: http://www.musicpd.org/doc/user/
1010
1011
1012 # Files and directories #######################################################
1013 #
1014 # This setting controls the top directory which MPD will search to discover the
1015 # available audio files and add them to the daemon's online database. This
1016 # setting defaults to the XDG directory, otherwise the music directory will be
1017 # be disabled and audio files will only be accepted over ipc socket (using
1018 # file:// protocol) or streaming files over an accepted protocol.
1019 #
1020 music_directory "~/usr/music"
1021 #
1022 # This setting sets the MPD internal playlist directory. The purpose of this
1023 # directory is storage for playlists created by MPD. The server will use
1024 # playlist files not created by the server but only if they are in the MPD
1025 # format. This setting defaults to playlist saving being disabled.
1026 #
1027 playlist_directory "~/.mpd/playlists"
1028 #
1029 # This setting sets the location of the MPD database. This file is used to
1030 # load the database at server start up and store the database while the
1031 # server is not up. This setting defaults to disabled which will allow
1032 # MPD to accept files over ipc socket (using file:// protocol) or streaming
1033 # files over an accepted protocol.
1034 #
1035 db_file "~/.mpd/database"
1036 #
1037 # These settings are the locations for the daemon log files for the daemon.
1038 # These logs are great for troubleshooting, depending on your log_level
1039 # settings.
1040 #
1041 # The special value "syslog" makes MPD use the local syslog daemon. This
1042 # setting defaults to logging to syslog, otherwise logging is disabled.
1043 #
1044 log_file "~/.mpd/log"
1045 #
1046 # This setting sets the location of the file which stores the process ID
1047 # for use of mpd --kill and some init scripts. This setting is disabled by
1048 # default and the pid file will not be stored.
1049 #
1050 pid_file "~/.mpd/pid"
1051 #
1052 # This setting sets the location of the file which contains information about
1053 # most variables to get MPD back into the same general shape it was in before
1054 # it was brought down. This setting is disabled by default and the server
1055 # state will be reset on server start up.
1056 #
1057 state_file "~/.mpd/state"
1058 #
1059 # The location of the sticker database. This is a database which
1060 # manages dynamic information attached to songs.
1061 #
1062 sticker_file "~/.mpd/sticker.sql"
1063 #
1064 ###############################################################################
1065
1066
1067 # General music daemon options ################################################
1068 #
1069 # This setting specifies the user that MPD will run as. MPD should never run as
1070 # root and you may use this setting to make MPD change its user ID after
1071 # initialization. This setting is disabled by default and MPD is run as the
1072 # current user.
1073 #
1074 #user "nobody"
1075 #
1076 # This setting specifies the group that MPD will run as. If not specified
1077 # primary group of user specified with "user" setting will be used (if set).
1078 # This is useful if MPD needs to be a member of group such as "audio" to
1079 # have permission to use sound card.
1080 #
1081 #group "nogroup"
1082 #
1083 # This setting sets the address for the daemon to listen on. Careful attention
1084 # should be paid if this is assigned to anything other then the default, any.
1085 # This setting can deny access to control of the daemon. Not effective if
1086 # systemd socket activiation is in use.
1087 #
1088 # For network
1089 #bind_to_address "any"
1090 #
1091 # And for Unix Socket
1092 #bind_to_address "~/.mpd/socket"
1093 #
1094 # This setting is the TCP port that is desired for the daemon to get assigned
1095 # to.
1096 #
1097 #port "6600"
1098 #
1099 # This setting controls the type of information which is logged. Available
1100 # setting arguments are "default", "secure" or "verbose". The "verbose" setting
1101 # argument is recommended for troubleshooting, though can quickly stretch
1102 # available resources on limited hardware storage.
1103 #
1104 #log_level "default"
1105 #
1106 # If you have a problem with your MP3s ending abruptly it is recommended that
1107 # you set this argument to "no" to attempt to fix the problem. If this solves
1108 # the problem, it is highly recommended to fix the MP3 files with vbrfix
1109 # (available from <http://www.willwap.co.uk/Programs/vbrfix.php>), at which
1110 # point gapless MP3 playback can be enabled.
1111 #
1112 #gapless_mp3_playback "yes"
1113 #
1114 # Setting "restore_paused" to "yes" puts MPD into pause mode instead
1115 # of starting playback after startup.
1116 #
1117 #restore_paused "no"
1118 #
1119 # This setting enables MPD to create playlists in a format usable by other
1120 # music players.
1121 #
1122 #save_absolute_paths_in_playlists "no"
1123 #
1124 # This setting defines a list of tag types that will be extracted during the
1125 # audio file discovery process. The complete list of possible values can be
1126 # found in the user manual.
1127 #metadata_to_use "artist,album,title,track,name,genre,date,composer,performer,disc"
1128 #
1129 # This setting enables automatic update of MPD's database when files in
1130 # music_directory are changed.
1131 #
1132 #auto_update "yes"
1133 #
1134 # Limit the depth of the directories being watched, 0 means only watch
1135 # the music directory itself. There is no limit by default.
1136 #
1137 #auto_update_depth "3"
1138 #
1139 ###############################################################################
1140
1141
1142 # Symbolic link behavior ######################################################
1143 #
1144 # If this setting is set to "yes", MPD will discover audio files by following
1145 # symbolic links outside of the configured music_directory.
1146 #
1147 #follow_outside_symlinks "yes"
1148 #
1149 # If this setting is set to "yes", MPD will discover audio files by following
1150 # symbolic links inside of the configured music_directory.
1151 #
1152 #follow_inside_symlinks "yes"
1153 #
1154 ###############################################################################
1155
1156
1157 # Zeroconf / Avahi Service Discovery ##########################################
1158 #
1159 # If this setting is set to "yes", service information will be published with
1160 # Zeroconf / Avahi.
1161 #
1162 #zeroconf_enabled "yes"
1163 #
1164 # The argument to this setting will be the Zeroconf / Avahi unique name for
1165 # this MPD server on the network.
1166 #
1167 #zeroconf_name "Music Player"
1168 #
1169 ###############################################################################
1170
1171
1172 # Permissions #################################################################
1173 #
1174 # If this setting is set, MPD will require password authorization. The password
1175 # setting can be specified multiple times for different password profiles.
1176 #
1177 #password "password@read,add,control,admin"
1178 #
1179 # This setting specifies the permissions a user has who has not yet logged in.
1180 #
1181 #default_permissions "read,add,control,admin"
1182 #
1183 ###############################################################################
1184
1185
1186 # Database #######################################################################
1187 #
1188
1189 #database {
1190 # plugin "proxy"
1191 # host "other.mpd.host"
1192 # port "6600"
1193 #}
1194
1195 # Input #######################################################################
1196 #
1197
1198 input {
1199 plugin "curl"
1200 # proxy "proxy.isp.com:8080"
1201 # proxy_user "user"
1202 # proxy_password "password"
1203 }
1204
1205 #
1206 ###############################################################################
1207
1208 # Audio Output ################################################################
1209 #
1210
1211 audio_output {
1212 type "pulse"
1213 name "pulse audio"
1214 }
1215
1216 audio_output {
1217 type "fifo"
1218 name "my_fifo"
1219 path "/tmp/mpd.fifo"
1220 format "44100:16:2"
1221 }
1222
1223 # MPD supports various audio output types, as well as playing through multiple
1224 # audio outputs at the same time, through multiple audio_output settings
1225 # blocks. Setting this block is optional, though the server will only attempt
1226 # autodetection for one sound card.
1227 #
1228 # An example of an ALSA output:
1229 #
1230 #audio_output {
1231 # type "alsa"
1232 # name "My ALSA Device"
1233 ## device "hw:0,0" # optional
1234 ## mixer_type "hardware" # optional
1235 ## mixer_device "default" # optional
1236 ## mixer_control "PCM" # optional
1237 ## mixer_index "0" # optional
1238 #}
1239 #
1240 # An example of an OSS output:
1241 #
1242 #audio_output {
1243 # type "oss"
1244 # name "My OSS Device"
1245 ## device "/dev/dsp" # optional
1246 ## mixer_type "hardware" # optional
1247 ## mixer_device "/dev/mixer" # optional
1248 ## mixer_control "PCM" # optional
1249 #}
1250 #
1251 # An example of a shout output (for streaming to Icecast):
1252 #
1253 #audio_output {
1254 # type "shout"
1255 # encoder "vorbis" # optional
1256 # name "My Shout Stream"
1257 # host "localhost"
1258 # port "8000"
1259 # mount "/mpd.ogg"
1260 # password "hackme"
1261 # quality "5.0"
1262 # bitrate "128"
1263 # format "44100:16:1"
1264 ## protocol "icecast2" # optional
1265 ## user "source" # optional
1266 ## description "My Stream Description" # optional
1267 ## url "http://example.com" # optional
1268 ## genre "jazz" # optional
1269 ## public "no" # optional
1270 ## timeout "2" # optional
1271 ## mixer_type "software" # optional
1272 #}
1273 #
1274 # An example of a recorder output:
1275 #
1276 #audio_output {
1277 # type "recorder"
1278 # name "My recorder"
1279 # encoder "vorbis" # optional, vorbis or lame
1280 # path "/var/lib/mpd/recorder/mpd.ogg"
1281 ## quality "5.0" # do not define if bitrate is defined
1282 # bitrate "128" # do not define if quality is defined
1283 # format "44100:16:1"
1284 #}
1285 #
1286 # An example of a httpd output (built-in HTTP streaming server):
1287 #
1288 #audio_output {
1289 # type "httpd"
1290 # name "My HTTP Stream"
1291 # encoder "vorbis" # optional, vorbis or lame
1292 # port "8000"
1293 # bind_to_address "0.0.0.0" # optional, IPv4 or IPv6
1294 ## quality "5.0" # do not define if bitrate is defined
1295 # bitrate "128" # do not define if quality is defined
1296 # format "44100:16:1"
1297 # max_clients "0" # optional 0=no limit
1298 #}
1299 #
1300 # An example of a pulseaudio output (streaming to a remote pulseaudio server)
1301 #
1302 #audio_output {
1303 # type "pulse"
1304 # name "My Pulse Output"
1305 ## server "remote_server" # optional
1306 ## sink "remote_server_sink" # optional
1307 #}
1308 #
1309 # An example of a winmm output (Windows multimedia API).
1310 #
1311 #audio_output {
1312 # type "winmm"
1313 # name "My WinMM output"
1314 ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
1315 # or
1316 ## device "0" # optional
1317 ## mixer_type "hardware" # optional
1318 #}
1319 #
1320 # An example of an openal output.
1321 #
1322 #audio_output {
1323 # type "openal"
1324 # name "My OpenAL output"
1325 ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
1326 #}
1327 #
1328 # An example of an sndio output.
1329 #
1330 #audio_output {
1331 # type "sndio"
1332 # name "sndio output"
1333 # mixer_type "software"
1334 #}
1335 #
1336 # An example of an OS X output:
1337 #
1338 #audio_output {
1339 # type "osx"
1340 # name "My OS X Device"
1341 ## device "Built-in Output" # optional
1342 ## channel_map "-1,-1,0,1" # optional
1343 #}
1344 #
1345 ## Example "pipe" output:
1346 #
1347 #audio_output {
1348 # type "pipe"
1349 # name "my pipe"
1350 # command "aplay -f cd 2>/dev/null"
1351 ## Or if you're want to use AudioCompress
1352 # command "AudioCompress -m | aplay -f cd 2>/dev/null"
1353 ## Or to send raw PCM stream through PCM:
1354 # command "nc example.org 8765"
1355 # format "44100:16:2"
1356 #}
1357 #
1358 ## An example of a null output (for no audio output):
1359 #
1360 #audio_output {
1361 # type "null"
1362 # name "My Null Output"
1363 # mixer_type "none" # optional
1364 #}
1365 #
1366 ###############################################################################
1367
1368
1369 # Normalization automatic volume adjustments ##################################
1370 #
1371 # This setting specifies the type of ReplayGain to use. This setting can have
1372 # the argument "off", "album", "track" or "auto". "auto" is a special mode that
1373 # chooses between "track" and "album" depending on the current state of
1374 # random playback. If random playback is enabled then "track" mode is used.
1375 # See <http://www.replaygain.org> for more details about ReplayGain.
1376 # This setting is off by default.
1377 #
1378 #replaygain "album"
1379 #
1380 # This setting sets the pre-amp used for files that have ReplayGain tags. By
1381 # default this setting is disabled.
1382 #
1383 #replaygain_preamp "0"
1384 #
1385 # This setting sets the pre-amp used for files that do NOT have ReplayGain tags.
1386 # By default this setting is disabled.
1387 #
1388 #replaygain_missing_preamp "0"
1389 #
1390 # This setting enables or disables ReplayGain limiting.
1391 # MPD calculates actual amplification based on the ReplayGain tags
1392 # and replaygain_preamp / replaygain_missing_preamp setting.
1393 # If replaygain_limit is enabled MPD will never amplify audio signal
1394 # above its original level. If replaygain_limit is disabled such amplification
1395 # might occur. By default this setting is enabled.
1396 #
1397 #replaygain_limit "yes"
1398 #
1399 # This setting enables on-the-fly normalization volume adjustment. This will
1400 # result in the volume of all playing audio to be adjusted so the output has
1401 # equal "loudness". This setting is disabled by default.
1402 #
1403 #volume_normalization "no"
1404 #
1405 ###############################################################################
1406
1407 # Character Encoding ##########################################################
1408 #
1409 # If file or directory names do not display correctly for your locale then you
1410 # may need to modify this setting.
1411 #
1412 #filesystem_charset "UTF-8"
1413 #
1414 ###############################################################################
1415 #+end_src
1416
1417 ** msmtp
1418 :PROPERTIES:
1419 :header-args+: :tangle ~/.msmtprc
1420 :END:
1421
1422 #+begin_src conf
1423 # Set default values for all following accounts.
1424 defaults
1425 port 587
1426 tls on
1427 auth on
1428 #tls_trust_file /etc/ssl/certs/ca-certificates.crt
1429 logfile ~/.msmtp.log
1430
1431 # aminb
1432 account aminb
1433 host nix.aminb.org
1434 tls_fingerprint BB:98:B3:02:83:B0:E0:C3:49:3E:C2:B2:A8:60:62:78:03:B3:5D:B3:BD:B8:0A:39:BB:E4:B0:66:D1:CF:D1:6B
1435 tls_starttls on
1436 from amin@aminb.org
1437 user amin@aminb.org
1438 passwordeval gpg2 --no-tty -q -d ~/.passwd/amin.gpg
1439
1440 # gnu
1441 account gnu
1442 host fencepost.gnu.org
1443 tls_fingerprint 94:0E:37:EB:EA:44:5A:4B:B6:6F:16:3D:6C:7E:7E:44:2D:93:61:C1:FE:82:A8:29:5E:3C:12:4E:2D:BE:0E:2C
1444 tls_starttls on
1445 from aminb@gnu.org
1446 user aminb
1447 passwordeval gpg2 --no-tty -q -d ~/.passwd/gnu.gpg
1448
1449 # uwaterloo
1450 account uwaterloo
1451 host connect.uwaterloo.ca
1452 tls_starttls on
1453 from abandali@uwaterloo.ca
1454 user abandali
1455 passwordeval gpg2 --no-tty -q -d ~/.passwd/uwaterloo.gpg
1456 tls_trust_file /etc/ssl/certs/ca-certificates.crt
1457
1458 # uwaterloo (friendly address)
1459 account uwaterloo-friendly : uwaterloo
1460 from amin.bandali@uwaterloo.ca
1461
1462 # Set a default account
1463 account default : aminb
1464 #+end_src
1465
1466 ** ncmpcpp
1467
1468 *** config
1469 :PROPERTIES:
1470 :header-args+: :tangle ~/.ncmpcpp/config
1471 :END:
1472
1473 #+begin_src conf :tangle no
1474 ##############################################################
1475 ## This is the example configuration file. Copy it to ##
1476 ## $HOME/.ncmpcpp/config or $XDG_CONFIG_HOME/ncmpcpp/config ##
1477 ## and set up your preferences. ##
1478 ##############################################################
1479 #
1480 ##### directories ######
1481 ##
1482 ## Directory for storing ncmpcpp related files.
1483 ## Changing it is useful if you want to store
1484 ## everything somewhere else and provide command
1485 ## line setting for alternative location to config
1486 ## file which defines that while launching ncmpcpp.
1487 ##
1488 #
1489 ncmpcpp_directory = ~/.ncmpcpp
1490 #
1491 ##
1492 ## Directory for storing downloaded lyrics. It
1493 ## defaults to ~/.lyrics since other MPD clients
1494 ## (eg. ncmpc) also use that location.
1495 ##
1496 #
1497 #lyrics_directory = ~/.lyrics
1498 #
1499 ##### connection settings #####
1500 #
1501 #mpd_host = localhost
1502 #
1503 #mpd_port = 6600
1504 #
1505 #mpd_connection_timeout = 5
1506 #
1507 ## Needed for tag editor and file operations to work.
1508 ##
1509 mpd_music_dir = ~/usr/music
1510 #
1511 #mpd_crossfade_time = 5
1512 #
1513 ##### music visualizer #####
1514 ##
1515 ## Note: In order to make music visualizer work you'll
1516 ## need to use mpd fifo output, whose format parameter
1517 ## has to be set to 44100:16:1 for mono visualization
1518 ## or 44100:16:2 for stereo visualization. Example
1519 ## configuration (it has to be put into mpd.conf):
1520 ##
1521 ## audio_output {
1522 ## type "fifo"
1523 ## name "Visualizer feed"
1524 ## path "/tmp/mpd.fifo"
1525 ## format "44100:16:2"
1526 ## }
1527 ##
1528 #
1529 visualizer_fifo_path = /tmp/mpd.fifo
1530 #
1531 ##
1532 ## Note: Below parameter is needed for ncmpcpp
1533 ## to determine which output provides data for
1534 ## visualizer and thus allow syncing between
1535 ## visualization and sound as currently there
1536 ## are some problems with it.
1537 ##
1538 #
1539 visualizer_output_name = my fifo
1540 #
1541 ##
1542 ## If you set format to 44100:16:2, make it 'yes'.
1543 ##
1544 visualizer_in_stereo = yes
1545 #
1546 ##
1547 ## Multiply received samples by given value. Very
1548 ## useful for proper visualization of quiet music.
1549 ##
1550 #visualizer_sample_multiplier = 1
1551 #
1552 ##
1553 ## Note: Below parameter defines how often ncmpcpp
1554 ## has to "synchronize" visualizer and audio outputs.
1555 ## 30 seconds is optimal value, but if you experience
1556 ## synchronization problems, set it to lower value.
1557 ## Keep in mind that sane values start with >=10.
1558 ##
1559 #
1560 visualizer_sync_interval = 30
1561 #
1562 ##
1563 ## Note: To enable spectrum frequency visualization
1564 ## you need to compile ncmpcpp with fftw3 support.
1565 ##
1566 #
1567 ## Available values: spectrum, wave, wave_filled, ellipse.
1568 ##
1569 visualizer_type = spectrum
1570 #
1571 #visualizer_look = ●▮
1572 visualizer_look = "●•"
1573 #
1574 #visualizer_color = blue, cyan, green, yellow, magenta, red
1575 #
1576 ## Alternative subset of 256 colors for terminals that support it.
1577 ##
1578 #visualizer_color = 41, 83, 119, 155, 185, 215, 209, 203, 197, 161
1579 #
1580 ##### system encoding #####
1581 ##
1582 ## ncmpcpp should detect your charset encoding
1583 ## but if it failed to do so, you can specify
1584 ## charset encoding you are using here.
1585 ##
1586 ## Note: You can see whether your ncmpcpp build
1587 ## supports charset detection by checking output
1588 ## of `ncmpcpp --version`.
1589 ##
1590 ## Note: Since MPD uses UTF-8 by default, setting
1591 ## this option makes sense only if your encoding
1592 ## is different.
1593 ##
1594 #
1595 #system_encoding = ""
1596 #
1597 ##### delays #####
1598 #
1599 ## Time of inactivity (in seconds) after playlist
1600 ## highlighting will be disabled (0 = always on).
1601 ##
1602 #playlist_disable_highlight_delay = 5
1603 #
1604 ## Defines how long messages are supposed to be visible.
1605 ##
1606 #message_delay_time = 5
1607 #
1608 ##### song format #####
1609 ##
1610 ## For a song format you can use:
1611 ##
1612 ## %l - length
1613 ## %f - filename
1614 ## %D - directory
1615 ## %a - artist
1616 ## %A - album artist
1617 ## %t - title
1618 ## %b - album
1619 ## %y - date
1620 ## %n - track number (01/12 -> 01)
1621 ## %N - full track info (01/12 -> 01/12)
1622 ## %g - genre
1623 ## %c - composer
1624 ## %p - performer
1625 ## %d - disc
1626 ## %C - comment
1627 ## %P - priority
1628 ## $R - begin right alignment
1629 ##
1630 ## If you want to make sure that a part of the format is displayed
1631 ## only when certain tags are present, you can archieve it by
1632 ## grouping them with brackets, e.g. '{%a - %t}' will be evaluated
1633 ## to 'ARTIST - TITLE' if both tags are present or '' otherwise.
1634 ## It is also possible to define a list of alternatives by providing
1635 ## several groups and separating them with '|', e.g. '{%t}|{%f}'
1636 ## will be evaluated to 'TITLE' or 'FILENAME' if the former is not
1637 ## present.
1638 ##
1639 ## Note: If you want to set limit on maximal length of a tag, just
1640 ## put the appropriate number between % and character that defines
1641 ## tag type, e.g. to make album take max. 20 terminal cells, use '%20b'.
1642 ##
1643 ## In addition, formats support markers used for text attributes.
1644 ## They are followed by character '$'. After that you can put:
1645 ##
1646 ## - 0 - default window color (discards all other colors)
1647 ## - 1 - black
1648 ## - 2 - red
1649 ## - 3 - green
1650 ## - 4 - yellow
1651 ## - 5 - blue
1652 ## - 6 - magenta
1653 ## - 7 - cyan
1654 ## - 8 - white
1655 ## - 9 - end of current color
1656 ## - b - bold text
1657 ## - u - underline text
1658 ## - r - reverse colors
1659 ## - a - use alternative character set
1660 ##
1661 ## If you don't want to use a non-color attribute anymore, just put it
1662 ## again, but this time insert character '/' between '$' and attribute
1663 ## character, e.g. {$b%t$/b}|{$r%f$/r} will display bolded title tag
1664 ## or filename with reversed colors.
1665 ##
1666 ## If you want to use 256 colors and/or background colors in formats
1667 ## (the naming scheme is described below in section about color
1668 ## definitions), it can be done with the syntax $(COLOR), e.g. to set
1669 ## the artist tag to one of the non-standard colors and make it have
1670 ## yellow background, you need to write $(197_yellow)%a$(end). Note
1671 ## that for standard colors this is interchangable with attributes
1672 ## listed above.
1673 ##
1674 ## Note: colors can be nested.
1675 ##
1676 #
1677 #song_list_format = {%a - }{%t}|{$8%f$9}$R{$3(%l)$9}
1678 #
1679 #song_status_format = {{%a{ "%b"{ (%y)}} - }{%t}}|{%f}
1680 #
1681 #song_library_format = {%n - }{%t}|{%f}
1682 #
1683 #
1684 #alternative_header_first_line_format = $b$1$aqqu$/a$9 {%t}|{%f} $1$atqq$/a$9$/b
1685 #
1686 #alternative_header_second_line_format = {{$4$b%a$/b$9}{ - $7%b$9}{ ($4%y$9)}}|{%D}
1687 #
1688 #now_playing_prefix = $b
1689 #
1690 #now_playing_suffix = $/b
1691 #
1692 #browser_playlist_prefix = "$2playlist$9 "
1693 #
1694 #selected_item_prefix = $6
1695 #
1696 #selected_item_suffix = $9
1697 #
1698 #modified_item_prefix = $3> $9
1699 #
1700 ##
1701 ## Note: attributes are not supported for the following variables.
1702 ##
1703 #song_window_title_format = {%a - }{%t}|{%f}
1704 ##
1705 ## Note: Below variables are used for sorting songs in browser.
1706 ## The sort mode determines how songs are sorted, and can be used
1707 ## in combination with a sort format to specify a custom sorting format.
1708 ## Available values for browser_sort_mode are "name", "mtime", "format"
1709 ## and "noop".
1710 ##
1711 #
1712 #browser_sort_mode = name
1713 #
1714 #browser_sort_format = {%a - }{%t}|{%f} {(%l)}
1715 #
1716 ##### columns settings #####
1717 ##
1718 ## syntax of song columns list format is "column column etc."
1719 ##
1720 ## - syntax for each column is:
1721 ##
1722 ## (width of the column)[color of the column]{displayed tag}
1723 ##
1724 ## Note: Width is by default in %, if you want a column to
1725 ## have fixed size, add 'f' after the value, e.g. (10)[white]{a}
1726 ## will be the column that take 10% of screen (so the real width
1727 ## will depend on actual screen size), whereas (10f)[white]{a}
1728 ## will take 10 terminal cells, no matter how wide the screen is.
1729 ##
1730 ## - color is optional (if you want the default one,
1731 ## leave the field empty).
1732 ##
1733 ## Note: You can give a column additional attributes by putting appropriate
1734 ## character after displayed tag character. Available attributes are:
1735 ##
1736 ## - r - column will be right aligned
1737 ## - E - if tag is empty, empty tag marker won't be displayed
1738 ##
1739 ## You can also:
1740 ##
1741 ## - give a column custom name by putting it after attributes,
1742 ## separated with character ':', e.g. {lr:Length} gives you
1743 ## right aligned column of lengths named "Length".
1744 ##
1745 ## - define sequence of tags, that have to be displayed in case
1746 ## predecessor is empty in a way similar to the one in classic
1747 ## song format, i.e. using '|' character, e.g. {a|c|p:Owner}
1748 ## creates column named "Owner" that tries to display artist
1749 ## tag and then composer and performer if previous ones are
1750 ## not available.
1751 ##
1752 #
1753 #song_columns_list_format = (20)[]{a} (6f)[green]{NE} (50)[white]{t|f:Title} (20)[cyan]{b} (7f)[magenta]{l}
1754 #
1755 ##### various settings #####
1756 #
1757 ##
1758 ## Note: Custom command that will be executed each
1759 ## time song changes. Useful for notifications etc.
1760 ##
1761 #execute_on_song_change = ""
1762 #
1763 #playlist_show_mpd_host = no
1764 #
1765 #playlist_show_remaining_time = no
1766 #
1767 #playlist_shorten_total_times = no
1768 #
1769 #playlist_separate_albums = no
1770 #
1771 ##
1772 ## Note: Possible display modes: classic, columns.
1773 ##
1774 #playlist_display_mode = columns
1775 #
1776 #browser_display_mode = classic
1777 #
1778 #search_engine_display_mode = classic
1779 #
1780 #playlist_editor_display_mode = classic
1781 #
1782 #discard_colors_if_item_is_selected = yes
1783 #
1784 #incremental_seeking = yes
1785 #
1786 #seek_time = 1
1787 #
1788 #volume_change_step = 2
1789 #
1790 #autocenter_mode = no
1791 #
1792 #centered_cursor = no
1793 #
1794 ##
1795 ## Note: You can specify third character which will
1796 ## be used to build 'empty' part of progressbar.
1797 ##
1798 #progressbar_look = =>
1799 progressbar_look = "─╼╶"
1800 #progressbar_look = "─⊙╶"
1801 #
1802 #progressbar_boldness = yes
1803 #
1804 ## Available values: database, playlist.
1805 ##
1806 #default_place_to_search_in = database
1807 #
1808 ## Available values: classic, alternative.
1809 ##
1810 #user_interface = classic
1811 #
1812 #data_fetching_delay = yes
1813 #
1814 ## Available values: artist, album_artist, date, genre, composer, performer.
1815 ##
1816 #media_library_primary_tag = artist
1817 #
1818 ## Available values: wrapped, normal.
1819 ##
1820 #default_find_mode = wrapped
1821 #
1822 #default_tag_editor_pattern = %n - %t
1823 #
1824 #header_visibility = yes
1825 #
1826 #statusbar_visibility = yes
1827 #
1828 #titles_visibility = yes
1829 #
1830 #header_text_scrolling = yes
1831 #
1832 #cyclic_scrolling = no
1833 #
1834 #lines_scrolled = 2
1835 #
1836 #follow_now_playing_lyrics = no
1837 #
1838 #fetch_lyrics_for_current_song_in_background = no
1839 #
1840 #store_lyrics_in_song_dir = no
1841 #
1842 #generate_win32_compatible_filenames = yes
1843 #
1844 #allow_for_physical_item_deletion = no
1845 #
1846 ##
1847 ## Note: If you set this variable, ncmpcpp will try to
1848 ## get info from last.fm in language you set and if it
1849 ## fails, it will fall back to english. Otherwise it will
1850 ## use english the first time.
1851 ##
1852 ## Note: Language has to be expressed as an ISO 639 alpha-2 code.
1853 ##
1854 #lastfm_preferred_language = en
1855 #
1856 #show_hidden_files_in_local_browser = no
1857 #
1858 ##
1859 ## How shall screen switcher work?
1860 ##
1861 ## - "previous" - switch between the current and previous screen.
1862 ## - "screen1,...,screenN" - switch between given sequence of screens.
1863 ##
1864 ## Screens available for use: help, playlist, browser, search_engine,
1865 ## media_library, playlist_editor, tag_editor, outputs, visualizer, clock.
1866 ##
1867 #screen_switcher_mode = playlist, browser
1868 #
1869 ##
1870 ## Note: You can define startup screen
1871 ## by choosing screen from the list above.
1872 ##
1873 #startup_screen = playlist
1874 #
1875 ##
1876 ## Note: You can define startup slave screen
1877 ## by choosing screen from the list above or
1878 ## an empty value for no slave screen.
1879 ##
1880 #startup_slave_screen = ""
1881 #
1882 #startup_slave_screen_focus = no
1883 #
1884 ##
1885 ## Default width of locked screen (in %).
1886 ## Acceptable values are from 20 to 80.
1887 ##
1888 #
1889 #locked_screen_width_part = 50
1890 #
1891 #ask_for_locked_screen_width_part = yes
1892 #
1893 #jump_to_now_playing_song_at_start = yes
1894 #
1895 #ask_before_clearing_playlists = yes
1896 #
1897 #clock_display_seconds = no
1898 #
1899 #display_volume_level = yes
1900 #
1901 #display_bitrate = no
1902 #
1903 #display_remaining_time = no
1904 #
1905 ## Available values: none, basic, extended, perl.
1906 ##
1907 #regular_expressions = perl
1908 #
1909 ##
1910 ## Note: If below is enabled, ncmpcpp will ignore leading
1911 ## "The" word while sorting items in browser, tags in
1912 ## media library, etc.
1913 ##
1914 #ignore_leading_the = no
1915 #
1916 #block_search_constraints_change_if_items_found = yes
1917 #
1918 #mouse_support = yes
1919 #
1920 #mouse_list_scroll_whole_page = yes
1921 #
1922 #empty_tag_marker = <empty>
1923 #
1924 #tags_separator = " | "
1925 #
1926 #tag_editor_extended_numeration = no
1927 #
1928 #media_library_sort_by_mtime = no
1929 #
1930 #enable_window_title = yes
1931 #
1932 ##
1933 ## Note: You can choose default search mode for search
1934 ## engine. Available modes are:
1935 ##
1936 ## - 1 - use mpd built-in searching (no regexes, pattern matching)
1937 ## - 2 - use ncmpcpp searching (pattern matching with support for regexes,
1938 ## but if your mpd is on a remote machine, downloading big database
1939 ## to process it can take a while
1940 ## - 3 - match only exact values (this mode uses mpd function for searching
1941 ## in database and local one for searching in current playlist)
1942 ##
1943 #
1944 #search_engine_default_search_mode = 1
1945 #
1946 #external_editor = nano
1947 #
1948 ## Note: set to yes if external editor is a console application.
1949 ##
1950 #use_console_editor = yes
1951 #
1952 ##### colors definitions #####
1953 ##
1954 ## It is possible to set a background color by setting a color
1955 ## value "<foreground>_<background>", e.g. red_black will set
1956 ## foregound color to red and background color to black.
1957 ##
1958 ## In addition, for terminals that support 256 colors it
1959 ## is possible to set one of them by using a number in range
1960 ## [1, 256] instead of color name, e.g. numerical value
1961 ## corresponding to red_black is 2_1. To find out if the
1962 ## terminal supports 256 colors, run ncmpcpp and check out
1963 ## the bottom of the help screen for list of available colors
1964 ## and their numerical values.
1965 ##
1966 ## Note: due to technical limitations of ncurses, if 256 colors
1967 ## are used, it is possible to either use only the colors with
1968 ## default background color, or all pairs from 1_1 up to 254_127,
1969 ## depending on the ncurses version used.
1970 ##
1971 #
1972 #colors_enabled = yes
1973 #
1974 #empty_tag_color = cyan
1975 #
1976 #header_window_color = default
1977 #
1978 #volume_color = default
1979 #
1980 #state_line_color = default
1981 #
1982 #state_flags_color = default
1983 #
1984 #main_window_color = yellow
1985 #
1986 #color1 = white
1987 #
1988 #color2 = green
1989 #
1990 #main_window_highlight_color = yellow
1991 #
1992 #progressbar_color = black
1993 #
1994 #progressbar_elapsed_color = green
1995 #
1996 #statusbar_color = default
1997 #
1998 #alternative_ui_separator_color = black
1999 #
2000 #active_column_color = red
2001 #
2002 #window_border_color = green
2003 #
2004 #active_window_border = red
2005 #
2006 #+end_src
2007
2008 *** bindings
2009 :PROPERTIES:
2010 :header-args+: :tangle ~/.ncmpcpp/bindings
2011 :END:
2012
2013 #+begin_src conf :tangle no
2014 def_key "j"
2015 scroll_down
2016 def_key "k"
2017 scroll_up
2018
2019 def_key "ctrl-u"
2020 page_up
2021 def_key "ctrl-d"
2022 page_down
2023
2024 def_key "h"
2025 previous_column
2026 def_key "l"
2027 next_column
2028
2029 def_key "."
2030 show_lyrics
2031
2032 def_key "n"
2033 next_found_item
2034 def_key "N"
2035 previous_found_item
2036
2037 def_key "J"
2038 move_sort_order_down
2039 def_key "K"
2040 move_sort_order_up
2041 #+end_src
2042
2043 ** notmuch
2044
2045 *** notmuch-config
2046 :PROPERTIES:
2047 :header-args+: :tangle ~/.notmuch-config
2048 :END:
2049
2050 #+begin_src conf
2051 # .notmuch-config - Configuration file for the notmuch mail system
2052 #
2053 # For more information about notmuch, see https://notmuchmail.org
2054
2055 # Database configuration
2056 #
2057 # The only value supported here is 'path' which should be the top-level
2058 # directory where your mail currently exists and to where mail will be
2059 # delivered in the future. Files should be individual email messages.
2060 # Notmuch will store its database within a sub-directory of the path
2061 # configured here named ".notmuch".
2062 #
2063 [database]
2064 path=/home/amin/mail
2065
2066 # User configuration
2067 #
2068 # Here is where you can let notmuch know how you would like to be
2069 # addressed. Valid settings are
2070 #
2071 # name Your full name.
2072 # primary_email Your primary email address.
2073 # other_email A list (separated by ';') of other email addresses
2074 # at which you receive email.
2075 #
2076 # Notmuch will use the various email addresses configured here when
2077 # formatting replies. It will avoid including your own addresses in the
2078 # recipient list of replies, and will set the From address based on the
2079 # address to which the original email was addressed.
2080 #
2081 [user]
2082 name=Amin Bandali
2083 primary_email=amin@aminb.org
2084 other_email=amin.bandali@uwaterloo.ca;mbandali@uwaterloo.ca;aminb@gnu.org;
2085
2086 # Configuration for "notmuch new"
2087 #
2088 # The following options are supported here:
2089 #
2090 # tags A list (separated by ';') of the tags that will be
2091 # added to all messages incorporated by "notmuch new".
2092 #
2093 # ignore A list (separated by ';') of file and directory names
2094 # that will not be searched for messages by "notmuch new".
2095 #
2096 # NOTE: *Every* file/directory that goes by one of those
2097 # names will be ignored, independent of its depth/location
2098 # in the mail store.
2099 #
2100 [new]
2101 tags=new;
2102 #tags=unread;inbox;
2103 ignore=.uidvalidity;.mbsyncstate
2104
2105 # Search configuration
2106 #
2107 # The following option is supported here:
2108 #
2109 # exclude_tags
2110 # A ;-separated list of tags that will be excluded from
2111 # search results by default. Using an excluded tag in a
2112 # query will override that exclusion.
2113 #
2114 [search]
2115 exclude_tags=deleted;spam;
2116
2117 # Maildir compatibility configuration
2118 #
2119 # The following option is supported here:
2120 #
2121 # synchronize_flags Valid values are true and false.
2122 #
2123 # If true, then the following maildir flags (in message filenames)
2124 # will be synchronized with the corresponding notmuch tags:
2125 #
2126 # Flag Tag
2127 # ---- -------
2128 # D draft
2129 # F flagged
2130 # P passed
2131 # R replied
2132 # S unread (added when 'S' flag is not present)
2133 #
2134 # The "notmuch new" command will notice flag changes in filenames
2135 # and update tags, while the "notmuch tag" and "notmuch restore"
2136 # commands will notice tag changes and update flags in filenames
2137 #
2138 [maildir]
2139 synchronize_flags=true
2140
2141 # Cryptography related configuration
2142 #
2143 # The following option is supported here:
2144 #
2145 # gpg_path
2146 # binary name or full path to invoke gpg.
2147 #
2148 [crypto]
2149 gpg_path=gpg
2150 #+end_src
2151
2152 *** post-new hook
2153 :PROPERTIES:
2154 :header-args+: :tangle ~/mail/.notmuch/hooks/post-new :shebang "#!/bin/sh"
2155 :END:
2156
2157 #+begin_src sh
2158 afew -tn
2159
2160 # apply tags to lists
2161 notmuch tag +lists +lists/deepspec -- folder:amin/lists/deepspec
2162 notmuch tag +lists +lists/haskell-cafe -- folder:amin/lists/haskell-cafe
2163 notmuch tag +lists +lists/haskell-weekly -- folder:amin/lists/haskell-weekly
2164 notmuch tag +lists +lists/hackernewsletter -- folder:amin/lists/hackernewsletter
2165 notmuch tag +lists +lists/notmuch -- folder:amin/lists/notmuch
2166 notmuch tag +lists +lists/info-gnu-emacs -- folder:amin/lists/info-gnu-emacs
2167 notmuch tag +lists +lists/help-gnu-emacs -- folder:amin/lists/help-gnu-emacs
2168 notmuch tag +lists +lists/emacs-devel -- folder:amin/lists/emacs-devel
2169 #+end_src
2170
2171 *** notmuch.service
2172 :PROPERTIES:
2173 :header-args+: :tangle ~/.config/systemd/user/notmuch.service
2174 :END:
2175
2176 #+begin_src conf :tangle no
2177 [Unit]
2178 Description=notmuch service
2179
2180 [Service]
2181 Type=oneshot
2182 ExecStart=/usr/bin/notmuch new
2183 StandardOutput=syslog
2184 StandardError=syslog
2185 #+end_src
2186
2187 *** notmuch.timer
2188 :PROPERTIES:
2189 :header-args+: :tangle ~/.config/systemd/user/notmuch.timer
2190 :END:
2191
2192 #+begin_src conf :tangle no
2193 [Unit]
2194 Description=notmuch timer
2195
2196 [Timer]
2197 OnCalendar=*:0/5
2198 Persistent=true
2199 Unit=notmuch.service
2200
2201 [Install]
2202 WantedBy=timers.target
2203 #+end_src
2204
2205 ** offlineimap
2206
2207 *** offlineimaprc
2208 :PROPERTIES:
2209 :header-args+: :tangle ~/.offlineimaprc
2210 :END:
2211
2212 #+begin_src conf :tangle no
2213 [general]
2214 pythonfile = ~/.offlineimap.py
2215 accounts = Gmail, aminb
2216 maxsyncaccounts = 3
2217
2218 [Account Gmail]
2219 localrepository = GmailL
2220 remoterepository = GmailR
2221
2222 [Account aminb]
2223 localrepository = aminbL
2224 remoterepository = aminbR
2225
2226 [Repository GmailL]
2227 type = Maildir
2228 localfolders = ~/Maildir/Gmail
2229
2230 [Repository GmailR]
2231 type = IMAP
2232 remotehost = imap.gmail.com
2233 remoteusereval = mailuser("gmail")
2234 remotepasseval = mailpasswd("gmail")
2235 sslcacertfile = /etc/ssl/certs/ca-certificates.crt
2236 ssl = yes
2237 folderfilter = lambda foldername: foldername not in '[Gmail]/All Mail'
2238 maxconnections = 1
2239 realdelete = no
2240
2241 [Repository aminbL]
2242 type = Maildir
2243 localfolders = ~/Maildir/aminb
2244
2245 [Repository aminbR]
2246 type = IMAP
2247 remotehost = mail.aminb.org
2248 remoteusereval = mailuser("aminb")
2249 remotepasseval = mailpasswd("aminb")
2250 sslcacertfile = /etc/ssl/certs/ca-certificates.crt
2251 ssl = yes
2252 folderfilter = lambda foldername: foldername not in 'dovecot.sieve'
2253 maxconnections = 1
2254 realdelete = no
2255 #+end_src
2256
2257 *** offlineimap.py
2258 :PROPERTIES:
2259 :header-args+: :tangle ~/.offlineimap.py
2260 :END:
2261
2262 #+begin_src python :tangle no
2263 import os
2264 import subprocess
2265
2266 def mailpasswd(acct):
2267 acct = os.path.basename(acct)
2268 path = "/home/amin/.passwd/%s.gpg" % acct
2269 args = ["gpg", "--use-agent", "--quiet", "--batch", "-d", path]
2270 try:
2271 return subprocess.check_output(args).strip()
2272 except subprocess.CalledProcessError:
2273 return ""
2274
2275 def mailuser(acct):
2276 acct = os.path.basename(acct)
2277 path = "/home/amin/.passwd/%s" % acct
2278 args = ["cat", path]
2279 try:
2280 return subprocess.check_output(args).strip()
2281 except subprocess.CalledProcessError:
2282 return ""
2283
2284 def prime_gpg_agent():
2285 ret = False
2286 i = 1
2287 while not ret:
2288 ret = (mailpasswd("prime") == "prime")
2289 if i > 2:
2290 from offlineimap.ui import getglobalui
2291 sys.stderr.write("Error reading in passwords. Terminating.\n")
2292 getglobalui().terminate()
2293 i += 1
2294 return ret
2295
2296 prime_gpg_agent()
2297 #+end_src
2298
2299 ** polybar
2300
2301 *** config
2302 :PROPERTIES:
2303 :header-args+: :tangle ~/.config/polybar/config
2304 :END:
2305
2306 #+begin_src conf :tangle no
2307 ;=====================================================
2308 ;
2309 ; To learn more about how to configure Polybar
2310 ; go to https://github.com/jaagr/polybar
2311 ;
2312 ; The README contains alot of information
2313 ;
2314 ;=====================================================
2315
2316 [colors]
2317 ;background = ${xrdb:color0:#222}
2318 background = #222
2319 background-alt = #444
2320 ;foreground = ${xrdb:color7:#222}
2321 foreground = #eee
2322 foreground-alt = #888
2323 primary = #ffb52a
2324 secondary = #e60053
2325 alert = #bd2c40
2326
2327 [bar/main]
2328 ;monitor = ${env:MONITOR:HDMI-1}
2329 width = 100%
2330 height = 27
2331 ;offset-x = 1%
2332 ;offset-y = 1%
2333 radius = 3.0
2334 fixed-center = true
2335
2336 background = ${colors.background}
2337 foreground = ${colors.foreground}
2338
2339 line-size = 3
2340 line-color = #f00
2341
2342 border-size = 4
2343 border-color = #00000000
2344
2345 padding-left = 0
2346 padding-right = 2
2347
2348 module-margin-left = 2
2349 module-margin-right = 2
2350
2351 font-0 = Ubuntu:fontformat=truetype:antialias=true:pixelsize=9;1
2352 font-1 = unifont:fontformat=truetype:size=8:antialias=false;0
2353 font-2 = Wuncon Siji:pixelsize=10;1
2354 font-3 = FontAwesome:pixelsize=10;1
2355
2356 modules-left = bspwm xwindow
2357 modules-center =
2358 modules-right = volume filesystem mail xkeyboard memory cpu temperature date powermenu
2359
2360 tray-position = right
2361 tray-padding = 1
2362 ;tray-transparent = true
2363 ;tray-background = #0063ff
2364 tray-maxsize = 18
2365
2366 wm-restack = bspwm
2367
2368 ;override-redirect = true
2369
2370 scroll-up = bspwm-desknext
2371 scroll-down = bspwm-deskprev
2372
2373 [module/xwindow]
2374 type = internal/xwindow
2375 label = %title:0:50:...%
2376
2377 [module/xkeyboard]
2378 type = internal/xkeyboard
2379 blacklist-0 = num lock
2380
2381 format-prefix = " "
2382 format-prefix-foreground = ${colors.foreground-alt}
2383 format-prefix-underline = ${colors.secondary}
2384
2385 label-layout = %layout%
2386 label-layout-underline = ${colors.secondary}
2387
2388 label-indicator-padding = 2
2389 label-indicator-margin = 1
2390 label-indicator-background = ${colors.secondary}
2391 label-indicator-underline = ${colors.secondary}
2392
2393 [module/filesystem]
2394 type = internal/fs
2395 interval = 25
2396
2397 mount-0 = /
2398
2399 label-mounted = %{F#0a81f5}%mountpoint%%{F-}: %percentage_used%%
2400 label-unmounted = %mountpoint% not mounted
2401 label-unmounted-foreground = ${colors.foreground-alt}
2402
2403 [module/bspwm]
2404 type = internal/bspwm
2405
2406 label-focused = %index%
2407 label-focused-background = ${colors.background-alt}
2408 label-focused-underline= ${colors.primary}
2409 label-focused-padding = 2
2410
2411 label-occupied = %index%
2412 label-occupied-padding = 2
2413
2414 label-urgent = %index%!
2415 label-urgent-background = ${colors.alert}
2416 label-urgent-padding = 2
2417
2418 label-empty = %index%
2419 label-empty-foreground = ${colors.foreground-alt}
2420 label-empty-padding = 2
2421
2422 [module/i3]
2423 type = internal/i3
2424 format = <label-state> <label-mode>
2425 index-sort = true
2426 wrapping-scroll = false
2427
2428 ; Only show workspaces on the same output as the bar
2429 ;pin-workspaces = true
2430
2431 label-mode-padding = 2
2432 label-mode-foreground = #000
2433 label-mode-background = ${colors.primary}
2434
2435 ; focused = Active workspace on focused monitor
2436 label-focused = %index%
2437 label-focused-background = ${module/bspwm.label-focused-background}
2438 label-focused-underline = ${module/bspwm.label-focused-underline}
2439 label-focused-padding = ${module/bspwm.label-focused-padding}
2440
2441 ; unfocused = Inactive workspace on any monitor
2442 label-unfocused = %index%
2443 label-unfocused-padding = ${module/bspwm.label-occupied-padding}
2444
2445 ; visible = Active workspace on unfocused monitor
2446 label-visible = %index%
2447 label-visible-background = ${self.label-focused-background}
2448 label-visible-underline = ${self.label-focused-underline}
2449 label-visible-padding = ${self.label-focused-padding}
2450
2451 ; urgent = Workspace with urgency hint set
2452 label-urgent = %index%
2453 label-urgent-background = ${module/bspwm.label-urgent-background}
2454 label-urgent-padding = ${module/bspwm.label-urgent-padding}
2455
2456 [module/mpd]
2457 type = internal/mpd
2458 format-online = <label-song> <icon-prev> <icon-stop> <toggle> <icon-next>
2459
2460 icon-prev = 
2461 icon-stop = 
2462 icon-play = 
2463 icon-pause = 
2464 icon-next = 
2465
2466 label-song-maxlen = 25
2467 label-song-ellipsis = true
2468
2469 [module/xbacklight]
2470 type = internal/xbacklight
2471
2472 format = <label> <bar>
2473 label = BL
2474
2475 bar-width = 10
2476 bar-indicator = |
2477 bar-indicator-foreground = #ff
2478 bar-indicator-font = 2
2479 bar-fill = ─
2480 bar-fill-font = 2
2481 bar-fill-foreground = #9f78e1
2482 bar-empty = ─
2483 bar-empty-font = 2
2484 bar-empty-foreground = ${colors.foreground-alt}
2485
2486 [module/backlight-acpi]
2487 inherit = module/xbacklight
2488 type = internal/backlight
2489 ;card = intel_backlight
2490 card = mba6x_backlight
2491
2492 [module/cpu]
2493 type = internal/cpu
2494 interval = 2
2495 format-prefix = " "
2496 format-prefix-foreground = ${colors.foreground-alt}
2497 format-underline = #f90000
2498 label = %percentage%%
2499
2500 [module/memory]
2501 type = internal/memory
2502 interval = 2
2503 format-prefix = " "
2504 format-prefix-foreground = ${colors.foreground-alt}
2505 format-underline = #4bffdc
2506 label = %percentage_used%%
2507
2508 [module/wlan]
2509 type = internal/network
2510 interface =
2511 interval = 3.0
2512
2513 format-connected = <ramp-signal> <label-connected>
2514 format-connected-underline = #9f78e1
2515 label-connected = %essid%
2516
2517 format-disconnected =
2518 ;format-disconnected = <label-disconnected>
2519 ;format-disconnected-underline = ${self.format-connected-underline}
2520 ;label-disconnected = %ifname% disconnected
2521 ;label-disconnected-foreground = ${colors.foreground-alt}
2522
2523 ramp-signal-0 = 
2524 ramp-signal-1 = 
2525 ramp-signal-2 = 
2526 ramp-signal-3 = 
2527 ramp-signal-4 = 
2528 ramp-signal-foreground = ${colors.foreground-alt}
2529
2530 [module/eth]
2531 type = internal/network
2532 interface =
2533 interval = 3.0
2534
2535 format-connected-underline = #55aa55
2536 format-connected-prefix = " "
2537 format-connected-prefix-foreground = ${colors.foreground-alt}
2538 label-connected = %local_ip%
2539
2540 format-disconnected =
2541 ;format-disconnected = <label-disconnected>
2542 ;format-disconnected-underline = ${self.format-connected-underline}
2543 ;label-disconnected = %ifname% disconnected
2544 ;label-disconnected-foreground = ${colors.foreground-alt}
2545
2546 [module/date]
2547 type = internal/date
2548 interval = 5
2549
2550 date =
2551 date-alt = " %Y-%m-%d"
2552
2553 time = %H:%M
2554 time-alt = %H:%M:%S
2555
2556 format-prefix = 
2557 format-prefix-foreground = ${colors.foreground-alt}
2558 format-underline = #0a6cf5
2559
2560 label = %date% %time%
2561
2562 [module/volume]
2563 type = internal/volume
2564
2565 format-volume = <label-volume> <bar-volume>
2566 label-volume = vol
2567 label-volume-foreground = ${root.foreground}
2568
2569 format-muted-prefix = " "
2570 format-muted-foreground = ${colors.foreground-alt}
2571 label-muted = mute
2572
2573 bar-volume-width = 10
2574 bar-volume-foreground-0 = #55aa55
2575 bar-volume-foreground-1 = #55aa55
2576 bar-volume-foreground-2 = #55aa55
2577 bar-volume-foreground-3 = #55aa55
2578 bar-volume-foreground-4 = #55aa55
2579 bar-volume-foreground-5 = #f5a70a
2580 bar-volume-foreground-6 = #ff5555
2581 bar-volume-gradient = false
2582 bar-volume-indicator = |
2583 bar-volume-indicator-font = 2
2584 bar-volume-fill = ─
2585 bar-volume-fill-font = 2
2586 bar-volume-empty = ─
2587 bar-volume-empty-font = 2
2588 bar-volume-empty-foreground = ${colors.foreground-alt}
2589
2590 [module/battery]
2591 type = internal/battery
2592 battery = BAT0
2593 adapter = ADP1
2594 full-at = 64
2595
2596 format-charging = <animation-charging> <label-charging>
2597 format-charging-underline = #ffb52a
2598
2599 format-discharging = <ramp-capacity> <label-discharging>
2600 format-discharging-underline = ${self.format-charging-underline}
2601
2602 format-full-prefix = " "
2603 format-full-prefix-foreground = ${colors.foreground-alt}
2604 format-full-underline = ${self.format-charging-underline}
2605
2606 ramp-capacity-0 = 
2607 ramp-capacity-1 = 
2608 ramp-capacity-2 = 
2609 ramp-capacity-foreground = ${colors.foreground-alt}
2610
2611 animation-charging-0 = 
2612 animation-charging-1 = 
2613 animation-charging-2 = 
2614 animation-charging-foreground = ${colors.foreground-alt}
2615 animation-charging-framerate = 750
2616
2617 [module/temperature]
2618 type = internal/temperature
2619 thermal-zone = 1
2620 warn-temperature = 66
2621
2622 format = <ramp> <label>
2623 format-underline = #f50a4d
2624 format-warn = <ramp> <label-warn>
2625 format-warn-underline = ${self.format-underline}
2626
2627 label = %temperature%
2628 label-warn = %temperature%
2629 label-warn-foreground = ${colors.secondary}
2630
2631 ramp-0 = 
2632 ramp-1 = 
2633 ramp-2 = 
2634 ramp-foreground = ${colors.foreground-alt}
2635
2636 [module/powermenu]
2637 type = custom/menu
2638
2639 format-spacing = 1
2640
2641 label-open = 
2642 label-open-foreground = ${colors.secondary}
2643 label-close =  cancel
2644 label-close-foreground = ${colors.secondary}
2645 label-separator = |
2646 label-separator-foreground = ${colors.foreground-alt}
2647
2648 menu-0-0 = reboot
2649 menu-0-0-exec = menu-open-1
2650 menu-0-1 = power off
2651 menu-0-1-exec = menu-open-2
2652
2653 menu-1-0 = cancel
2654 menu-1-0-exec = menu-open-0
2655 menu-1-1 = reboot
2656 menu-1-1-exec = sudo reboot
2657
2658 menu-2-0 = power off
2659 menu-2-0-exec = sudo poweroff
2660 menu-2-1 = cancel
2661 menu-2-1-exec = menu-open-0
2662
2663 [module/mail]
2664 type = custom/script
2665 interval = 60
2666 format = <label>
2667 format-prefix = " "
2668 format-prefix-foreground = ${colors.foreground-alt}
2669 format-underline = #0a6cf5
2670 exec = notmuch count tag:unread
2671
2672 [settings]
2673 screenchange-reload = true
2674 ;compositing-background = xor
2675 ;compositing-background = screen
2676 ;compositing-foreground = source
2677 ;compositing-border = over
2678
2679 [global/wm]
2680 margin-top = 0
2681 margin-bottom = 0
2682
2683 ; vim:ft=dosini
2684 #+end_src
2685
2686 *** polybar-launch
2687 :PROPERTIES:
2688 :header-args+: :tangle ~/.local/bin/polybar-launch :shebang "#!/usr/bin/env sh"
2689 :END:
2690
2691 #+begin_src sh :tangle no
2692 # Terminate already running bar instances
2693 killall -q polybar
2694
2695 # Wait until the processes have been shut down
2696 while pgrep -x polybar >/dev/null; do sleep 1; done
2697
2698 # Launch main bar
2699 polybar main &
2700
2701 echo "Bars launched..."
2702 #+end_src
2703
2704 ** PowerTOP
2705 :PROPERTIES:
2706 :header-args+: :tangle "/sudo::/etc/systemd/system/powertop.service"
2707 :END:
2708
2709 #+begin_src conf
2710 [Unit]
2711 Description=Powertop tunings
2712
2713 [Service]
2714 ExecStart=/usr/bin/powertop --auto-tune
2715 RemainAfterExit=true
2716
2717 [Install]
2718 WantedBy=multi-user.target
2719 #+end_src
2720
2721 ** ranger
2722
2723 *** rc.conf
2724 :PROPERTIES:
2725 :header-args+: :tangle ~/.config/ranger/rc.conf
2726 :END:
2727
2728 #+begin_src conf :tangle no
2729 # ===================================================================
2730 # This file contains the default startup commands for ranger.
2731 # To change them, it is recommended to create the file
2732 # ~/.config/ranger/rc.conf and add your custom commands there.
2733 #
2734 # If you copy this whole file there, you may want to set the environment
2735 # variable RANGER_LOAD_DEFAULT_RC to FALSE to avoid loading it twice.
2736 #
2737 # The purpose of this file is mainly to define keybindings and settings.
2738 # For running more complex python code, please create a plugin in "plugins/" or
2739 # a command in "commands.py".
2740 #
2741 # Each line is a command that will be run before the user interface
2742 # is initialized. As a result, you can not use commands which rely
2743 # on the UI such as :delete or :mark.
2744 # ===================================================================
2745
2746 # ===================================================================
2747 # == Options
2748 # ===================================================================
2749
2750 # How many columns are there, and what are their relative widths?
2751 set column_ratios 1,3,4
2752
2753 # Which files should be hidden? (regular expression)
2754 set hidden_filter ^\.|\.(?:pyc|pyo|bak|swp)$|^lost\+found$|^__(py)?cache__$
2755
2756 # Show hidden files? You can toggle this by typing 'zh'
2757 set show_hidden false
2758
2759 # Ask for a confirmation when running the "delete" command?
2760 # Valid values are "always" (default), "never", "multiple"
2761 # With "multiple", ranger will ask only if you delete multiple files at once.
2762 set confirm_on_delete multiple
2763
2764 # Which script is used to generate file previews?
2765 # ranger ships with scope.sh, a script that calls external programs (see
2766 # README for dependencies) to preview images, archives, etc.
2767 set preview_script ~/.config/ranger/scope.sh
2768
2769 # Use the external preview script or display simple plain text previews?
2770 set use_preview_script true
2771
2772 # Open all images in this directory when running certain image viewers
2773 # like feh or sxiv? You can still open selected files by marking them.
2774 set open_all_images true
2775
2776 # Be aware of version control systems and display information.
2777 set vcs_aware false
2778
2779 # State of the three backends git, hg, bzr. The possible states are
2780 # disabled, local (only show local info), enabled (show local and remote
2781 # information).
2782 set vcs_backend_git enabled
2783 set vcs_backend_hg disabled
2784 set vcs_backend_bzr disabled
2785
2786 # Preview images in full color with the external command "w3mimgpreview"?
2787 # This requires the console web browser "w3m" and a supported terminal.
2788 # It has been successfully tested with "xterm" and "urxvt" without tmux.
2789 set preview_images true
2790
2791 # Use a unicode "..." character to mark cut-off filenames?
2792 set unicode_ellipsis false
2793
2794 # Show dotfiles in the bookmark preview box?
2795 set show_hidden_bookmarks true
2796
2797 # Which colorscheme to use? These colorschemes are available by default:
2798 # default, jungle, snow
2799 set colorscheme default
2800
2801 # Preview files on the rightmost column?
2802 # And collapse (shrink) the last column if there is nothing to preview?
2803 set preview_files true
2804 set preview_directories true
2805 set collapse_preview true
2806
2807 # Save the console history on exit?
2808 set save_console_history true
2809
2810 # Draw the status bar on top of the browser window (default: bottom)
2811 set status_bar_on_top false
2812
2813 # Draw a progress bar in the status bar which displays the average state of all
2814 # currently running tasks which support progress bars?
2815 set draw_progress_bar_in_status_bar true
2816
2817 # Draw borders around columns?
2818 set draw_borders true
2819
2820 # Display the directory name in tabs?
2821 set dirname_in_tabs false
2822
2823 # Enable the mouse support?
2824 set mouse_enabled true
2825
2826 # Display the file size in the main column or status bar?
2827 set display_size_in_main_column true
2828 set display_size_in_status_bar true
2829
2830 # Display files tags in all columns or only in main column?
2831 set display_tags_in_all_columns true
2832
2833 # Set a title for the window?
2834 set update_title false
2835
2836 # Set the title to "ranger" in the tmux program?
2837 set update_tmux_title false
2838
2839 # Shorten the title if it gets long? The number defines how many
2840 # directories are displayed at once, 0 turns off this feature.
2841 set shorten_title 3
2842
2843 # Abbreviate $HOME with ~ in the titlebar (first line) of ranger?
2844 set tilde_in_titlebar false
2845
2846 # How many directory-changes or console-commands should be kept in history?
2847 set max_history_size 20
2848 set max_console_history_size 50
2849
2850 # Try to keep so much space between the top/bottom border when scrolling:
2851 set scroll_offset 8
2852
2853 # Flush the input after each key hit? (Noticable when ranger lags)
2854 set flushinput true
2855
2856 # Padding on the right when there's no preview?
2857 # This allows you to click into the space to run the file.
2858 set padding_right true
2859
2860 # Save bookmarks (used with mX and `X) instantly?
2861 # This helps to synchronize bookmarks between multiple ranger
2862 # instances but leads to *slight* performance loss.
2863 # When false, bookmarks are saved when ranger is exited.
2864 set autosave_bookmarks true
2865
2866 # You can display the "real" cumulative size of directories by using the
2867 # command :get_cumulative_size or typing "dc". The size is expensive to
2868 # calculate and will not be updated automatically. You can choose
2869 # to update it automatically though by turning on this option:
2870 set autoupdate_cumulative_size false
2871
2872 # Turning this on makes sense for screen readers:
2873 set show_cursor false
2874
2875 # One of: size, basename, mtime, type
2876 set sort natural
2877
2878 # Additional sorting options
2879 set sort_reverse false
2880 set sort_case_insensitive true
2881 set sort_directories_first true
2882
2883 # Enable this if key combinations with the Alt Key don't work for you.
2884 # (Especially on xterm)
2885 set xterm_alt_key false
2886
2887 # ===================================================================
2888 # == Local Options
2889 # ===================================================================
2890 # You can set local options that only affect a single directory.
2891
2892 # Examples:
2893 # setlocal path=~/downloads sort mtime
2894
2895 # ===================================================================
2896 # == Command Aliases in the Console
2897 # ===================================================================
2898
2899 alias e edit
2900 alias q quit
2901 alias q! quitall
2902 alias qall quitall
2903 alias setl setlocal
2904
2905 alias filter scout -prt
2906 alias find scout -aet
2907 alias mark scout -mr
2908 alias unmark scout -Mr
2909 alias search scout -rs
2910 alias search_inc scout -rts
2911 alias travel scout -aefiklst
2912
2913 # ===================================================================
2914 # == Define keys for the browser
2915 # ===================================================================
2916
2917 # Basic
2918 map Q quit!
2919 map q quit
2920 copymap q ZZ ZQ
2921
2922 map R reload_cwd
2923 map <C-r> reset
2924 map <C-l> redraw_window
2925 map <C-c> abort
2926 map <esc> change_mode normal
2927
2928 map i display_file
2929 map ? help
2930 map W display_log
2931 map w taskview_open
2932 map S shell $SHELL
2933
2934 map : console
2935 map ; console
2936 map ! console shell
2937 map @ console -p6 shell %%s
2938 map # console shell -p
2939 map s console shell
2940 map r chain draw_possible_programs; console open_with
2941 map f console find
2942 map cd console cd
2943
2944 # Tagging / Marking
2945 map t tag_toggle
2946 map ut tag_remove
2947 map "<any> tag_toggle tag=%any
2948 map <Space> mark_files toggle=True
2949 map v mark_files all=True toggle=True
2950 map uv mark_files all=True val=False
2951 map V toggle_visual_mode
2952 map uV toggle_visual_mode reverse=True
2953
2954 # For the nostalgics: Midnight Commander bindings
2955 map <F1> help
2956 map <F3> display_file
2957 map <F4> edit
2958 map <F5> copy
2959 map <F6> cut
2960 map <F7> console mkdir
2961 map <F8> console delete
2962 map <F10> exit
2963
2964 # In case you work on a keyboard with dvorak layout
2965 map <UP> move up=1
2966 map <DOWN> move down=1
2967 map <LEFT> move left=1
2968 map <RIGHT> move right=1
2969 map <HOME> move to=0
2970 map <END> move to=-1
2971 map <PAGEDOWN> move down=1 pages=True
2972 map <PAGEUP> move up=1 pages=True
2973 map <CR> move right=1
2974 map <DELETE> console delete
2975 map <INSERT> console touch
2976
2977 # VIM-like
2978 copymap <UP> k
2979 copymap <DOWN> j
2980 copymap <LEFT> h
2981 copymap <RIGHT> l
2982 copymap <HOME> gg
2983 copymap <END> G
2984 copymap <PAGEDOWN> <C-F>
2985 copymap <PAGEUP> <C-B>
2986
2987 map J move down=0.5 pages=True
2988 map K move up=0.5 pages=True
2989 copymap J <C-D>
2990 copymap K <C-U>
2991
2992 # Jumping around
2993 map H history_go -1
2994 map L history_go 1
2995 map ] move_parent 1
2996 map [ move_parent -1
2997 map } traverse
2998
2999 map gh cd ~
3000 map ge cd /etc
3001 map gu cd /usr
3002 map gd cd /dev
3003 map gl cd -r .
3004 map gL cd -r %f
3005 map go cd /opt
3006 map gv cd /var
3007 map gm cd /media
3008 map gM cd /mnt
3009 map gs cd /srv
3010 map gr cd /
3011 map gR eval fm.cd(ranger.RANGERDIR)
3012 map g/ cd /
3013 map g? cd /usr/share/doc/ranger
3014
3015 # External Programs
3016 map E edit
3017 map du shell -p du --max-depth=1 -h --apparent-size
3018 map dU shell -p du --max-depth=1 -h --apparent-size | sort -rh
3019 map yp shell -d echo -n %d/%f | xsel -i
3020 map yd shell -d echo -n %d | xsel -i
3021 map yn shell -d echo -n %f | xsel -i
3022
3023 # Filesystem Operations
3024 map = chmod
3025
3026 map cw console rename
3027 map A eval fm.open_console('rename ' + fm.thisfile.basename)
3028 map I eval fm.open_console('rename ' + fm.thisfile.basename, position=7)
3029
3030 map pp paste
3031 map po paste overwrite=True
3032 map pl paste_symlink relative=False
3033 map pL paste_symlink relative=True
3034 map phl paste_hardlink
3035 map pht paste_hardlinked_subtree
3036
3037 map dd cut
3038 map ud uncut
3039 map da cut mode=add
3040 map dr cut mode=remove
3041
3042 map yy copy
3043 map uy uncut
3044 map ya copy mode=add
3045 map yr copy mode=remove
3046
3047 # Temporary workarounds
3048 map dgg eval fm.cut(dirarg=dict(to=0), narg=quantifier)
3049 map dG eval fm.cut(dirarg=dict(to=-1), narg=quantifier)
3050 map dj eval fm.cut(dirarg=dict(down=1), narg=quantifier)
3051 map dk eval fm.cut(dirarg=dict(up=1), narg=quantifier)
3052 map ygg eval fm.copy(dirarg=dict(to=0), narg=quantifier)
3053 map yG eval fm.copy(dirarg=dict(to=-1), narg=quantifier)
3054 map yj eval fm.copy(dirarg=dict(down=1), narg=quantifier)
3055 map yk eval fm.copy(dirarg=dict(up=1), narg=quantifier)
3056
3057 # Searching
3058 map / console search
3059 map n search_next
3060 map N search_next forward=False
3061 map ct search_next order=tag
3062 map cs search_next order=size
3063 map ci search_next order=mimetype
3064 map cc search_next order=ctime
3065 map cm search_next order=mtime
3066 map ca search_next order=atime
3067
3068 # Tabs
3069 map <C-n> tab_new ~
3070 map <C-w> tab_close
3071 map <TAB> tab_move 1
3072 map <S-TAB> tab_move -1
3073 map <A-Right> tab_move 1
3074 map <A-Left> tab_move -1
3075 map gt tab_move 1
3076 map gT tab_move -1
3077 map gn tab_new ~
3078 map gc tab_close
3079 map uq tab_restore
3080 map <a-1> tab_open 1
3081 map <a-2> tab_open 2
3082 map <a-3> tab_open 3
3083 map <a-4> tab_open 4
3084 map <a-5> tab_open 5
3085 map <a-6> tab_open 6
3086 map <a-7> tab_open 7
3087 map <a-8> tab_open 8
3088 map <a-9> tab_open 9
3089
3090 # Sorting
3091 map or toggle_option sort_reverse
3092 map os chain set sort=size; set sort_reverse=False
3093 map ob chain set sort=basename; set sort_reverse=False
3094 map on chain set sort=natural; set sort_reverse=False
3095 map om chain set sort=mtime; set sort_reverse=False
3096 map oc chain set sort=ctime; set sort_reverse=False
3097 map oa chain set sort=atime; set sort_reverse=False
3098 map ot chain set sort=type; set sort_reverse=False
3099
3100 map oS chain set sort=size; set sort_reverse=True
3101 map oB chain set sort=basename; set sort_reverse=True
3102 map oN chain set sort=natural; set sort_reverse=True
3103 map oM chain set sort=mtime; set sort_reverse=True
3104 map oC chain set sort=ctime; set sort_reverse=True
3105 map oA chain set sort=atime; set sort_reverse=True
3106 map oT chain set sort=type; set sort_reverse=True
3107
3108 map dc get_cumulative_size
3109
3110 # Settings
3111 map zc toggle_option collapse_preview
3112 map zd toggle_option sort_directories_first
3113 map zh toggle_option show_hidden
3114 map <C-h> toggle_option show_hidden
3115 map zi toggle_option flushinput
3116 map zm toggle_option mouse_enabled
3117 map zp toggle_option preview_files
3118 map zP toggle_option preview_directories
3119 map zs toggle_option sort_case_insensitive
3120 map zu toggle_option autoupdate_cumulative_size
3121 map zv toggle_option use_preview_script
3122 map zf console filter
3123
3124 # Bookmarks
3125 map `<any> enter_bookmark %any
3126 map '<any> enter_bookmark %any
3127 map m<any> set_bookmark %any
3128 map um<any> unset_bookmark %any
3129
3130 map m<bg> draw_bookmarks
3131 copymap m<bg> um<bg> `<bg> '<bg>
3132
3133 # Generate all the chmod bindings with some python help:
3134 eval for arg in "rwxXst": cmd("map +u{0} shell -d chmod u+{0} %s".format(arg))
3135 eval for arg in "rwxXst": cmd("map +g{0} shell -d chmod g+{0} %s".format(arg))
3136 eval for arg in "rwxXst": cmd("map +o{0} shell -d chmod o+{0} %s".format(arg))
3137 eval for arg in "rwxXst": cmd("map +a{0} shell -d chmod a+{0} %s".format(arg))
3138 eval for arg in "rwxXst": cmd("map +{0} shell -d chmod u+{0} %s".format(arg))
3139
3140 eval for arg in "rwxXst": cmd("map -u{0} shell -d chmod u-{0} %s".format(arg))
3141 eval for arg in "rwxXst": cmd("map -g{0} shell -d chmod g-{0} %s".format(arg))
3142 eval for arg in "rwxXst": cmd("map -o{0} shell -d chmod o-{0} %s".format(arg))
3143 eval for arg in "rwxXst": cmd("map -a{0} shell -d chmod a-{0} %s".format(arg))
3144 eval for arg in "rwxXst": cmd("map -{0} shell -d chmod u-{0} %s".format(arg))
3145
3146 # ===================================================================
3147 # == Define keys for the console
3148 # ===================================================================
3149 # Note: Unmapped keys are passed directly to the console.
3150
3151 # Basic
3152 cmap <tab> eval fm.ui.console.tab()
3153 cmap <s-tab> eval fm.ui.console.tab(-1)
3154 cmap <ESC> eval fm.ui.console.close()
3155 cmap <CR> eval fm.ui.console.execute()
3156 cmap <C-l> redraw_window
3157
3158 copycmap <ESC> <C-c>
3159 copycmap <CR> <C-j>
3160
3161 # Move around
3162 cmap <up> eval fm.ui.console.history_move(-1)
3163 cmap <down> eval fm.ui.console.history_move(1)
3164 cmap <left> eval fm.ui.console.move(left=1)
3165 cmap <right> eval fm.ui.console.move(right=1)
3166 cmap <home> eval fm.ui.console.move(right=0, absolute=True)
3167 cmap <end> eval fm.ui.console.move(right=-1, absolute=True)
3168
3169 # Line Editing
3170 cmap <backspace> eval fm.ui.console.delete(-1)
3171 cmap <delete> eval fm.ui.console.delete(0)
3172 cmap <C-w> eval fm.ui.console.delete_word()
3173 cmap <C-k> eval fm.ui.console.delete_rest(1)
3174 cmap <C-u> eval fm.ui.console.delete_rest(-1)
3175 cmap <C-y> eval fm.ui.console.paste()
3176
3177 # And of course the emacs way
3178 copycmap <up> <C-p>
3179 copycmap <down> <C-n>
3180 copycmap <left> <C-b>
3181 copycmap <right> <C-f>
3182 copycmap <home> <C-a>
3183 copycmap <end> <C-e>
3184 copycmap <delete> <C-d>
3185 copycmap <backspace> <C-h>
3186
3187 # Note: There are multiple ways to express backspaces. <backspace> (code 263)
3188 # and <backspace2> (code 127). To be sure, use both.
3189 copycmap <backspace> <backspace2>
3190
3191 # This special expression allows typing in numerals:
3192 cmap <allow_quantifiers> false
3193
3194 # ===================================================================
3195 # == Pager Keybindings
3196 # ===================================================================
3197
3198 # Movement
3199 pmap <down> pager_move down=1
3200 pmap <up> pager_move up=1
3201 pmap <left> pager_move left=4
3202 pmap <right> pager_move right=4
3203 pmap <home> pager_move to=0
3204 pmap <end> pager_move to=-1
3205 pmap <pagedown> pager_move down=1.0 pages=True
3206 pmap <pageup> pager_move up=1.0 pages=True
3207 pmap <C-d> pager_move down=0.5 pages=True
3208 pmap <C-u> pager_move up=0.5 pages=True
3209
3210 copypmap <UP> k <C-p>
3211 copypmap <DOWN> j <C-n> <CR>
3212 copypmap <LEFT> h
3213 copypmap <RIGHT> l
3214 copypmap <HOME> g
3215 copypmap <END> G
3216 copypmap <C-d> d
3217 copypmap <C-u> u
3218 copypmap <PAGEDOWN> n f <C-F> <Space>
3219 copypmap <PAGEUP> p b <C-B>
3220
3221 # Basic
3222 pmap <ESC> pager_close
3223 copypmap <ESC> q Q i <F3>
3224 pmap E edit_file
3225
3226 # ===================================================================
3227 # == Taskview Keybindings
3228 # ===================================================================
3229
3230 # Movement
3231 tmap <up> taskview_move up=1
3232 tmap <down> taskview_move down=1
3233 tmap <home> taskview_move to=0
3234 tmap <end> taskview_move to=-1
3235 tmap <pagedown> taskview_move down=1.0 pages=True
3236 tmap <pageup> taskview_move up=1.0 pages=True
3237 tmap <C-d> taskview_move down=0.5 pages=True
3238 tmap <C-u> taskview_move up=0.5 pages=True
3239
3240 copytmap <UP> k <C-p>
3241 copytmap <DOWN> j <C-n> <CR>
3242 copytmap <HOME> g
3243 copytmap <END> G
3244 copytmap <C-u> u
3245 copytmap <PAGEDOWN> n f <C-F> <Space>
3246 copytmap <PAGEUP> p b <C-B>
3247
3248 # Changing priority and deleting tasks
3249 tmap J eval -q fm.ui.taskview.task_move(-1)
3250 tmap K eval -q fm.ui.taskview.task_move(0)
3251 tmap dd eval -q fm.ui.taskview.task_remove()
3252 tmap <pagedown> eval -q fm.ui.taskview.task_move(-1)
3253 tmap <pageup> eval -q fm.ui.taskview.task_move(0)
3254 tmap <delete> eval -q fm.ui.taskview.task_remove()
3255
3256 # Basic
3257 tmap <ESC> taskview_close
3258 copytmap <ESC> q Q w <C-c>
3259 #+end_src
3260
3261 *** scope.sh
3262 :PROPERTIES:
3263 :header-args+: :tangle ~/.config/ranger/scope.sh :shebang "#!/usr/bin/env sh"
3264 :END:
3265
3266 #+begin_src sh :tangle no
3267 # ranger supports enhanced previews. If the option "use_preview_script"
3268 # is set to True and this file exists, this script will be called and its
3269 # output is displayed in ranger. ANSI color codes are supported.
3270
3271 # NOTES: This script is considered a configuration file. If you upgrade
3272 # ranger, it will be left untouched. (You must update it yourself.)
3273 # Also, ranger disables STDIN here, so interactive scripts won't work properly
3274
3275 # Meanings of exit codes:
3276 # code | meaning | action of ranger
3277 # -----+------------+-------------------------------------------
3278 # 0 | success | success. display stdout as preview
3279 # 1 | no preview | failure. display no preview at all
3280 # 2 | plain text | display the plain content of the file
3281 # 3 | fix width | success. Don't reload when width changes
3282 # 4 | fix height | success. Don't reload when height changes
3283 # 5 | fix both | success. Don't ever reload
3284
3285 # Meaningful aliases for arguments:
3286 path="$1" # Full path of the selected file
3287 width="$2" # Width of the preview pane (number of fitting characters)
3288 height="$3" # Height of the preview pane (number of fitting characters)
3289
3290 maxln=200 # Stop after $maxln lines. Can be used like ls | head -n $maxln
3291
3292 # Find out something about the file:
3293 mimetype=$(file --mime-type -Lb "$path")
3294 extension=${path##*.}
3295
3296 # Functions:
3297 # runs a command and saves its output into $output. Useful if you need
3298 # the return value AND want to use the output in a pipe
3299 try() { output=$(eval '"$@"'); }
3300
3301 # writes the output of the previouosly used "try" command
3302 dump() { echo "$output"; }
3303
3304 # a common post-processing function used after most commands
3305 trim() { head -n "$maxln"; }
3306
3307 # wraps highlight to treat exit code 141 (killed by SIGPIPE) as success
3308 highlight() { command highlight "$@"; test $? = 0 -o $? = 141; }
3309
3310 case "$extension" in
3311 # Archive extensions:
3312 7z|a|ace|alz|arc|arj|bz|bz2|cab|cpio|deb|gz|jar|lha|lz|lzh|lzma|lzo|\
3313 rpm|rz|t7z|tar|tbz|tbz2|tgz|tlz|txz|tZ|tzo|war|xpi|xz|Z|zip)
3314 try als "$path" && { dump | trim; exit 0; }
3315 try acat "$path" && { dump | trim; exit 3; }
3316 try bsdtar -lf "$path" && { dump | trim; exit 0; }
3317 exit 1;;
3318 rar)
3319 try unrar -p- lt "$path" && { dump | trim; exit 0; } || exit 1;;
3320 # PDF documents:
3321 pdf)
3322 try pdftotext -l 10 -nopgbrk -q "$path" - && \
3323 { dump | trim | fmt -s -w $width; exit 0; } || exit 1;;
3324 # BitTorrent Files
3325 torrent)
3326 try transmission-show "$path" && { dump | trim; exit 5; } || exit 1;;
3327 # HTML Pages:
3328 htm|html|xhtml)
3329 try w3m -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3330 try lynx -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3331 try elinks -dump "$path" && { dump | trim | fmt -s -w $width; exit 4; }
3332 ;; # fall back to highlight/cat if the text browsers fail
3333 esac
3334
3335 case "$mimetype" in
3336 # Syntax highlight for text files:
3337 text/* | */xml)
3338 try highlight --out-format=ansi "$path" && { dump | trim; exit 5; } || exit 2;;
3339 # Ascii-previews of images:
3340 image/*)
3341 img2txt --gamma=0.6 --width="$width" "$path" && exit 4 || exit 1;;
3342 # Display information about media files:
3343 video/* | audio/*)
3344 exiftool "$path" && exit 5
3345 # Use sed to remove spaces so the output fits into the narrow window
3346 try mediainfo "$path" && { dump | trim | sed 's/ \+:/: /;'; exit 5; } || exit 1;;
3347 esac
3348
3349 exit 1
3350 #+end_src
3351
3352 ** redshift
3353 :PROPERTIES:
3354 :header-args+: :tangle ~/.config/redshift.conf
3355 :END:
3356
3357 #+begin_src conf
3358 ; Global settings for redshift
3359 [redshift]
3360 ; Set the day and night screen temperatures (Neutral is 6500K)
3361 ;temp-day=5700
3362 ;temp-night=3500
3363
3364 ;temp-day=6500
3365 temp-day=6200
3366 ;temp-night=4800
3367 ;temp-night=5000
3368 ;temp-night=4500
3369 temp-night=4000
3370
3371 ; Enable/Disable a smooth transition between day and night
3372 ; 0 will cause a direct change from day to night screen temperature.
3373 ; 1 will gradually increase or decrease the screen temperature.
3374 transition=1
3375
3376 ; Set the screen brightness. Default is 1.0.
3377 ;brightness=0.9
3378 ; It is also possible to use different settings for day and night
3379 ; since version 1.8.
3380 ;brightness-day=0.7
3381 ;brightness-night=0.4
3382 ; Set the screen gamma (for all colors, or each color channel
3383 ; individually)
3384 ;gamma=0.8
3385 ;gamma=1.0
3386 ;gamma=0.8:0.7:0.8
3387 ; This can also be set individually for day and night since
3388 ; version 1.10.
3389 ;gamma-day=0.8:0.7:0.8
3390 ;gamma-night=0.6
3391
3392 ; Set the location-provider: 'geoclue2' or 'manual'
3393 ; type 'redshift -l list' to see possible values.
3394 ; The location provider settings are in a different section.
3395 ;location-provider=manual
3396 location-provider=geoclue2
3397
3398 ; Set the adjustment-method: 'randr', 'vidmode'
3399 ; type 'redshift -m list' to see all possible values.
3400 ; 'randr' is the preferred method, 'vidmode' is an older API.
3401 ; but works in some cases when 'randr' does not.
3402 ; The adjustment method settings are in a different section.
3403 adjustment-method=randr
3404
3405 ; Configuration of the location-provider:
3406 ; type 'redshift -l PROVIDER:help' to see the settings.
3407 ; ex: 'redshift -l manual:help'
3408 ; Keep in mind that longitudes west of Greenwich (e.g. the Americas)
3409 ; are negative numbers.
3410 ;[manual]
3411 ;lat=48.1
3412 ;lon=11.6
3413
3414 ; Configuration of the adjustment-method
3415 ; type 'redshift -m METHOD:help' to see the settings.
3416 ; ex: 'redshift -m randr:help'
3417 ; In this example, randr is configured to adjust screen 1.
3418 ; Note that the numbering starts from 0, so this is actually the
3419 ; second screen. If this option is not specified, Redshift will try
3420 ; to adjust _all_ screens.
3421 ;[randr]
3422 ;screen=1
3423 #+end_src
3424
3425 ** rofi
3426 :PROPERTIES:
3427 :header-args+: :tangle ~/.config/rofi/config
3428 :END:
3429
3430 #+begin_src conf
3431 rofi.font: Ubuntu Mono 13
3432 ! rofi.font: Inconsolata 16
3433 ! rofi.font: Iosevka 13
3434 ! rofi.font: Source Code Pro 11
3435 rofi.modi: run,window
3436 ! rofi.width: 640
3437 rofi.width: 600
3438 !rofi.location: 2
3439 !rofi.yoffset: 200
3440 rofi.monitor: -1
3441 !rofi.lines: 10
3442
3443 !rofi.theme: /usr/share/rofi/themes//Arc.rasi
3444 !rofi.theme: /usr/share/rofi/themes//Paper.rasi
3445 !rofi.theme: /usr/share/rofi/themes//sidebar.rasi
3446
3447 rofi.theme: /usr/share/rofi/themes//gruvbox-light.rasi
3448 #+end_src
3449
3450 ** rofi-pass
3451 :PROPERTIES:
3452 :header-args+: :tangle ~/.config/rofi-pass/config
3453 :END:
3454
3455 #+begin_src conf
3456 # permanently set alternative root dir
3457 # root=/path/to/root
3458
3459 # rofi command. Make sure to have "$@" as last argument
3460 _rofi () {
3461 #rofi -no-auto-select -kb-accept-entry "!Return" -i -no-levenshtein-sort "$@"
3462 rofi -i -no-auto-select "$@"
3463 }
3464
3465 # xdotool needs the keyboard layout to be set using setxkbmap
3466 # You can do this in your autostart scripts (e.g. xinitrc)
3467
3468 # If for some reason, you cannot do this, you can set the command here.
3469 # and set fix_layout to true
3470 fix_layout=false
3471
3472 layout_cmd () {
3473 setxkbmap us
3474 }
3475
3476 # fields to be used
3477 URL_field='url'
3478 USERNAME_field='user'
3479 AUTOTYPE_field='autotype'
3480
3481 # delay to be used for :delay keyword
3482 delay=2
3483
3484 ## Programs to be used
3485 # Editor
3486 EDITOR='gvim -f'
3487
3488 # Browser
3489 BROWSER='chromium'
3490
3491 ## Misc settings
3492
3493 default_do='menu' # menu, autotype, copyPass, typeUser, typePass, copyUser, copyUrl, viewEntry, typeMenu, actionMenu, copyMenu, openUrl
3494 auto_enter='false'
3495 notify='false'
3496 default_autotype='user :tab pass'
3497
3498 # color of the help messages
3499 # leave empty for autodetection
3500 help_color="#4872FF"
3501
3502 # Clipboard settings
3503 # Possible options: primary, clipboard, both
3504 clip=primary
3505
3506 # Options for generating new password entries
3507 # default_user is also used for password files that have no user field.
3508 default_user=aminb
3509 default_user2=aminban
3510 password_length=30
3511
3512 # Custom Keybindings
3513 #autotype="Alt+1"
3514 autotype="Alt+m"
3515 type_user="Alt+2"
3516 type_pass="Alt+3"
3517 open_url="Alt+4"
3518 copy_name="Alt+u"
3519 copy_url="Alt+l"
3520 copy_pass="Alt+p"
3521 show="Alt+o"
3522 copy_entry="Alt+2"
3523 type_entry="Alt+1"
3524 copy_menu="Alt+c"
3525 action_menu="Alt+a"
3526 type_menu="Alt+t"
3527 help="Alt+h"
3528 switch="Alt+x"
3529 insert_pass="Alt+n"
3530 #+end_src
3531
3532 ** TLP
3533
3534 *** TODO enigma
3535 *** plasma
3536
3537 #+begin_src conf :tangle (when (and (eq system-type 'gnu/linux) (string= (system-name) "plasma")) "/sudo::/etc/default/tlp")
3538 # ------------------------------------------------------------------------------
3539 # tlp - Parameters for power saving
3540 # See full explanation: http://linrunner.de/en/tlp/docs/tlp-configuration.html
3541
3542 # Hint: some features are disabled by default, remove the leading # to enable
3543 # them.
3544
3545 # Set to 0 to disable, 1 to enable TLP.
3546 TLP_ENABLE=1
3547
3548 # Operation mode when no power supply can be detected: AC, BAT.
3549 # Concerns some desktop and embedded hardware only.
3550 TLP_DEFAULT_MODE=AC
3551
3552 # Operation mode select: 0=depend on power source, 1=always use TLP_DEFAULT_MODE
3553 # Hint: use in conjunction with TLP_DEFAULT_MODE=BAT for BAT settings on AC.
3554 TLP_PERSISTENT_DEFAULT=0
3555
3556 # Seconds laptop mode has to wait after the disk goes idle before doing a sync.
3557 # Non-zero value enables, zero disables laptop mode.
3558 DISK_IDLE_SECS_ON_AC=0
3559 DISK_IDLE_SECS_ON_BAT=2
3560
3561 # Dirty page values (timeouts in secs).
3562 MAX_LOST_WORK_SECS_ON_AC=15
3563 MAX_LOST_WORK_SECS_ON_BAT=60
3564
3565 # Hint: CPU parameters below are disabled by default, remove the leading #
3566 # to enable them, otherwise kernel default values are used.
3567
3568 # Select a CPU frequency scaling governor.
3569 # Intel Core i processor with intel_pstate driver:
3570 # powersave(*), performance.
3571 # Older hardware with acpi-cpufreq driver:
3572 # ondemand(*), powersave, performance, conservative, schedutil.
3573 # (*) is recommended.
3574 # Hint: use tlp-stat -p to show the active driver and available governors.
3575 # Important:
3576 # powersave for intel_pstate and ondemand for acpi-cpufreq are power
3577 # efficient for *almost all* workloads and therefore kernel and most
3578 # distributions have chosen them as defaults. If you still want to change,
3579 # you should know what you're doing! You *must* disable your distribution's
3580 # governor settings or conflicts will occur.
3581 #CPU_SCALING_GOVERNOR_ON_AC=powersave
3582 #CPU_SCALING_GOVERNOR_ON_BAT=powersave
3583
3584 # Set the min/max frequency available for the scaling governor.
3585 # Possible values strongly depend on your CPU. For available frequencies see
3586 # the output of tlp-stat -p.
3587 #CPU_SCALING_MIN_FREQ_ON_AC=0
3588 #CPU_SCALING_MAX_FREQ_ON_AC=0
3589 #CPU_SCALING_MIN_FREQ_ON_BAT=0
3590 #CPU_SCALING_MAX_FREQ_ON_BAT=0
3591
3592 # Set energy performance hints (HWP) for Intel P-state governor:
3593 # performance, balance_performance, default, balance_power, power
3594 # Values are given in order of increasing power saving.
3595 # Note: Intel Skylake or newer CPU and Kernel >= 4.10 required.
3596 CPU_HWP_ON_AC=balance_performance
3597 CPU_HWP_ON_BAT=balance_power
3598
3599 # Set Intel P-state performance: 0..100 (%).
3600 # Limit the max/min P-state to control the power dissipation of the CPU.
3601 # Values are stated as a percentage of the available performance.
3602 # Requires an Intel Core i processor with intel_pstate driver.
3603 #CPU_MIN_PERF_ON_AC=0
3604 #CPU_MAX_PERF_ON_AC=100
3605 #CPU_MIN_PERF_ON_BAT=0
3606 #CPU_MAX_PERF_ON_BAT=30
3607
3608 # Set the CPU "turbo boost" feature: 0=disable, 1=allow
3609 # Requires an Intel Core i processor.
3610 # Important:
3611 # - This may conflict with your distribution's governor settings
3612 # - A value of 1 does *not* activate boosting, it just allows it
3613 #CPU_BOOST_ON_AC=1
3614 #CPU_BOOST_ON_BAT=0
3615
3616 # Minimize number of used CPU cores/hyper-threads under light load conditions:
3617 # 0=disable, 1=enable.
3618 SCHED_POWERSAVE_ON_AC=0
3619 SCHED_POWERSAVE_ON_BAT=1
3620
3621 # Kernel NMI Watchdog:
3622 # 0=disable (default, saves power), 1=enable (for kernel debugging only).
3623 NMI_WATCHDOG=0
3624
3625 # Change CPU voltages aka "undervolting" - Kernel with PHC patch required.
3626 # Frequency voltage pairs are written to:
3627 # /sys/devices/system/cpu/cpu0/cpufreq/phc_controls
3628 # CAUTION: only use this, if you thoroughly understand what you are doing!
3629 #PHC_CONTROLS="F:V F:V F:V F:V"
3630
3631 # Set CPU performance versus energy savings policy:
3632 # performance, balance-performance, default, balance-power, power.
3633 # Values are given in order of increasing power saving.
3634 # Requires kernel module msr and x86_energy_perf_policy from linux-tools.
3635 ENERGY_PERF_POLICY_ON_AC=performance
3636 ENERGY_PERF_POLICY_ON_BAT=balance-power
3637
3638 # Disk devices; separate multiple devices with spaces (default: sda).
3639 # Devices can be specified by disk ID also (lookup with: tlp diskid).
3640 DISK_DEVICES="sda sdb"
3641
3642 # Disk advanced power management level: 1..254, 255 (max saving, min, off).
3643 # Levels 1..127 may spin down the disk; 255 allowable on most drives.
3644 # Separate values for multiple disks with spaces. Use the special value 'keep'
3645 # to keep the hardware default for the particular disk.
3646 DISK_APM_LEVEL_ON_AC="254 254"
3647 DISK_APM_LEVEL_ON_BAT="128 128"
3648
3649 # Hard disk spin down timeout:
3650 # 0: spin down disabled
3651 # 1..240: timeouts from 5s to 20min (in units of 5s)
3652 # 241..251: timeouts from 30min to 5.5 hours (in units of 30min)
3653 # See 'man hdparm' for details.
3654 # Separate values for multiple disks with spaces. Use the special value 'keep'
3655 # to keep the hardware default for the particular disk.
3656 #DISK_SPINDOWN_TIMEOUT_ON_AC="0 0"
3657 #DISK_SPINDOWN_TIMEOUT_ON_BAT="0 0"
3658
3659 # Select IO scheduler for the disk devices: cfq, deadline, noop (Default: cfq).
3660 # Separate values for multiple disks with spaces. Use the special value 'keep'
3661 # to keep the kernel default scheduler for the particular disk.
3662 #DISK_IOSCHED="cfq cfq"
3663
3664 # AHCI link power management (ALPM) for disk devices:
3665 # min_power, med_power_with_dipm(*), medium_power, max_performance.
3666 # (*) Kernel >= 4.15 required, then recommended.
3667 # Multiple values separated with spaces are tried sequentially until success.
3668 SATA_LINKPWR_ON_AC="med_power_with_dipm max_performance"
3669 SATA_LINKPWR_ON_BAT="med_power_with_dipm min_power"
3670
3671 # Exclude host devices from AHCI link power management.
3672 # Separate multiple hosts with spaces.
3673 #SATA_LINKPWR_BLACKLIST="host1"
3674
3675 # Runtime Power Management for AHCI host and disks devices:
3676 # on=disable, auto=enable.
3677 # EXPERIMENTAL ** WARNING: auto will most likely cause system lockups/data loss.
3678 #AHCI_RUNTIME_PM_ON_AC=on
3679 #AHCI_RUNTIME_PM_ON_BAT=on
3680
3681 # Seconds of inactivity before disk is suspended.
3682 AHCI_RUNTIME_PM_TIMEOUT=15
3683
3684 # PCI Express Active State Power Management (PCIe ASPM):
3685 # default, performance, powersave.
3686 PCIE_ASPM_ON_AC=performance
3687 PCIE_ASPM_ON_BAT=powersave
3688
3689 # Radeon graphics clock speed (profile method): low, mid, high, auto, default;
3690 # auto = mid on BAT, high on AC; default = use hardware defaults.
3691 RADEON_POWER_PROFILE_ON_AC=high
3692 RADEON_POWER_PROFILE_ON_BAT=low
3693
3694 # Radeon dynamic power management method (DPM): battery, performance.
3695 RADEON_DPM_STATE_ON_AC=performance
3696 RADEON_DPM_STATE_ON_BAT=battery
3697
3698 # Radeon DPM performance level: auto, low, high; auto is recommended.
3699 RADEON_DPM_PERF_LEVEL_ON_AC=auto
3700 RADEON_DPM_PERF_LEVEL_ON_BAT=auto
3701
3702 # WiFi power saving mode: on=enable, off=disable; not supported by all adapters.
3703 WIFI_PWR_ON_AC=off
3704 WIFI_PWR_ON_BAT=on
3705
3706 # Disable wake on LAN: Y/N.
3707 WOL_DISABLE=Y
3708
3709 # Enable audio power saving for Intel HDA, AC97 devices (timeout in secs).
3710 # A value of 0 disables, >=1 enables power saving (recommended: 1).
3711 SOUND_POWER_SAVE_ON_AC=0
3712 SOUND_POWER_SAVE_ON_BAT=0
3713
3714 # Disable controller too (HDA only): Y/N.
3715 SOUND_POWER_SAVE_CONTROLLER=N
3716
3717 # Power off optical drive in UltraBay/MediaBay: 0=disable, 1=enable.
3718 # Drive can be powered on again by releasing (and reinserting) the eject lever
3719 # or by pressing the disc eject button on newer models.
3720 # Note: an UltraBay/MediaBay hard disk is never powered off.
3721 BAY_POWEROFF_ON_AC=0
3722 BAY_POWEROFF_ON_BAT=0
3723 # Optical drive device to power off (default sr0).
3724 BAY_DEVICE="sr0"
3725
3726 # Runtime Power Management for PCI(e) bus devices: on=disable, auto=enable.
3727 RUNTIME_PM_ON_AC=on
3728 RUNTIME_PM_ON_BAT=auto
3729
3730 # Exclude PCI(e) device adresses the following list from Runtime PM
3731 # (separate with spaces). Use lspci to get the adresses (1st column).
3732 #RUNTIME_PM_BLACKLIST="bb:dd.f 11:22.3 44:55.6"
3733 RUNTIME_PM_BLACKLIST="01:00.0"
3734
3735 # Exclude PCI(e) devices assigned to the listed drivers from Runtime PM.
3736 # Default when unconfigured is "amdgpu nouveau nvidia radeon" which
3737 # prevents accidential power-on of dGPU in hybrid graphics setups.
3738 # Use "" to disable the feature completely.
3739 # Separate multiple drivers with spaces.
3740 #RUNTIME_PM_DRIVER_BLACKLIST="amdgpu nouveau nvidia radeon"
3741
3742 # Set to 0 to disable, 1 to enable USB autosuspend feature.
3743 USB_AUTOSUSPEND=1
3744
3745 # Exclude listed devices from USB autosuspend (separate with spaces).
3746 # Use lsusb to get the ids.
3747 # Note: input devices (usbhid) are excluded automatically
3748 #USB_BLACKLIST="1111:2222 3333:4444"
3749
3750 # Bluetooth devices are excluded from USB autosuspend:
3751 # 0=do not exclude, 1=exclude.
3752 USB_BLACKLIST_BTUSB=0
3753
3754 # Phone devices are excluded from USB autosuspend:
3755 # 0=do not exclude, 1=exclude (enable charging).
3756 USB_BLACKLIST_PHONE=0
3757
3758 # Printers are excluded from USB autosuspend:
3759 # 0=do not exclude, 1=exclude.
3760 USB_BLACKLIST_PRINTER=1
3761
3762 # WWAN devices are excluded from USB autosuspend:
3763 # 0=do not exclude, 1=exclude.
3764 USB_BLACKLIST_WWAN=1
3765
3766 # Include listed devices into USB autosuspend even if already excluded
3767 # by the blacklists above (separate with spaces).
3768 # Use lsusb to get the ids.
3769 #USB_WHITELIST="1111:2222 3333:4444"
3770
3771 # Set to 1 to disable autosuspend before shutdown, 0 to do nothing
3772 # (workaround for USB devices that cause shutdown problems).
3773 #USB_AUTOSUSPEND_DISABLE_ON_SHUTDOWN=1
3774
3775 # Restore radio device state (Bluetooth, WiFi, WWAN) from previous shutdown
3776 # on system startup: 0=disable, 1=enable.
3777 # Hint: the parameters DEVICES_TO_DISABLE/ENABLE_ON_STARTUP/SHUTDOWN below
3778 # are ignored when this is enabled!
3779 #RESTORE_DEVICE_STATE_ON_STARTUP=0
3780 RESTORE_DEVICE_STATE_ON_STARTUP=1
3781
3782 # Radio devices to disable on startup: bluetooth, wifi, wwan.
3783 # Separate multiple devices with spaces.
3784 #DEVICES_TO_DISABLE_ON_STARTUP="bluetooth wifi wwan"
3785
3786 # Radio devices to enable on startup: bluetooth, wifi, wwan.
3787 # Separate multiple devices with spaces.
3788 #DEVICES_TO_ENABLE_ON_STARTUP="wifi"
3789
3790 # Radio devices to disable on shutdown: bluetooth, wifi, wwan.
3791 # (workaround for devices that are blocking shutdown).
3792 #DEVICES_TO_DISABLE_ON_SHUTDOWN="bluetooth wifi wwan"
3793
3794 # Radio devices to enable on shutdown: bluetooth, wifi, wwan.
3795 # (to prevent other operating systems from missing radios).
3796 #DEVICES_TO_ENABLE_ON_SHUTDOWN="wwan"
3797
3798 # Radio devices to enable on AC: bluetooth, wifi, wwan.
3799 #DEVICES_TO_ENABLE_ON_AC="bluetooth wifi wwan"
3800
3801 # Radio devices to disable on battery: bluetooth, wifi, wwan.
3802 #DEVICES_TO_DISABLE_ON_BAT="bluetooth wifi wwan"
3803
3804 # Radio devices to disable on battery when not in use (not connected):
3805 # bluetooth, wifi, wwan.
3806 #DEVICES_TO_DISABLE_ON_BAT_NOT_IN_USE="bluetooth wifi wwan"
3807
3808 # Battery charge thresholds (ThinkPad only, tp-smapi or acpi-call kernel module
3809 # required). Charging starts when the remaining capacity falls below the
3810 # START_CHARGE_THRESH value and stops when exceeding the STOP_CHARGE_THRESH value.
3811 # Main / Internal battery (values in %)
3812 #START_CHARGE_THRESH_BAT0=75
3813 #STOP_CHARGE_THRESH_BAT0=80
3814 # Ultrabay / Slice / Replaceable battery (values in %)
3815 #START_CHARGE_THRESH_BAT1=75
3816 #STOP_CHARGE_THRESH_BAT1=80
3817
3818 # Restore charge thresholds when AC is unplugged: 0=disable, 1=enable.
3819 #RESTORE_THRESHOLDS_ON_BAT=1
3820
3821 # ------------------------------------------------------------------------------
3822 # tlp-rdw - Parameters for the radio device wizard
3823 # Possible devices: bluetooth, wifi, wwan.
3824
3825 # Hints:
3826 # - Parameters are disabled by default, remove the leading # to enable them
3827 # - Separate multiple radio devices with spaces
3828
3829 # Radio devices to disable on connect.
3830 #DEVICES_TO_DISABLE_ON_LAN_CONNECT="wifi wwan"
3831 #DEVICES_TO_DISABLE_ON_WIFI_CONNECT="wwan"
3832 #DEVICES_TO_DISABLE_ON_WWAN_CONNECT="wifi"
3833
3834 # Radio devices to enable on disconnect.
3835 #DEVICES_TO_ENABLE_ON_LAN_DISCONNECT="wifi wwan"
3836 #DEVICES_TO_ENABLE_ON_WIFI_DISCONNECT=""
3837 #DEVICES_TO_ENABLE_ON_WWAN_DISCONNECT=""
3838
3839 # Radio devices to enable/disable when docked.
3840 #DEVICES_TO_ENABLE_ON_DOCK=""
3841 #DEVICES_TO_DISABLE_ON_DOCK=""
3842
3843 # Radio devices to enable/disable when undocked.
3844 #DEVICES_TO_ENABLE_ON_UNDOCK="wifi"
3845 #DEVICES_TO_DISABLE_ON_UNDOCK=""
3846 #+end_src
3847
3848 ** X
3849
3850 *** xprofile
3851 :PROPERTIES:
3852 :header-args+: :tangle ~/.xprofile
3853 :END:
3854
3855 =~/.xprofile= is similar in style to =~/.xinitrc=, but on the
3856 contrary, it's automatically sourced by LightDM, my display manager of
3857 choice.
3858
3859 #+begin_src sh
3860 xset -b # disable bell
3861
3862 # setxkbmap -option compose:ralt
3863
3864 setxkbmap -option ctrl:nocaps # turn capslock into control
3865 setxkbmap -option altwin:swap_alt_win # swap alt and super
3866
3867 if [ $(hostname) = "plasma" ]
3868 then
3869 setxkbmap -option ctrl:rctrl_ralt # turn right control into right alt
3870 fi
3871
3872 if [ $(hostname) = "enigma" ]
3873 then
3874 xmodmap -e "keycode 135 = Alt_R" # remap menu key to alt
3875 fi
3876
3877 light -Scrs "intel_backlight" 2
3878
3879 source $HOME/.zprofile
3880
3881 export _JAVA_AWT_WM_NONREPARENTING=1
3882 export _JAVA_OPTIONS='-Dawt.useSystemAAFontSettings=on -Dswing.aatext=true'
3883
3884 # unlock-def-gk.py &
3885
3886 if [ $(hostname) = "plasma" ]
3887 then
3888 bspwm &
3889 elif [ $(hostname) = "enigma" ]
3890 then
3891 emacs -ib 0 &
3892 fi
3893 #+end_src
3894
3895 *** X resources
3896
3897 **** Xresources
3898 :PROPERTIES:
3899 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources")
3900 :END:
3901
3902 #+begin_src conf-xdefaults
3903 #include ".Xresources.d/fonts"
3904 ! #include ".Xresources.d/colors"
3905 #include ".Xresources.d/emacs"
3906 #include ".Xresources.d/rxvt-unicode"
3907 #+end_src
3908
3909 **** Xresources.d
3910
3911 ***** fonts
3912 :PROPERTIES:
3913 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/fonts")
3914 :END:
3915
3916 #+begin_src conf-xdefaults
3917 Xft.lcdfilter: lcddefault
3918 Xft.antialias: true
3919 Xft.autohint: 0
3920 Xft.hinting: true
3921 Xft.hintstyle: hintslight
3922 ! Xft.hintstyle: hintfull
3923 Xft.rgba: rgb
3924 Xft.dpi: 96
3925 #+end_src
3926
3927 ***** colors
3928 :PROPERTIES:
3929 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/colors")
3930 :END:
3931
3932 #+begin_src conf-xdefaults :tangle no
3933 #include "gruvbox-light.xresources"
3934 ! #include "gruvbox-dark.xresources"
3935 #include "gruvbox-urxvt256.xresources"
3936 #+end_src
3937
3938 #+begin_src conf-xdefaults :tangle no
3939 ! -----------------------------------------------------------------------------
3940 ! File: gruvbox-light.xresources
3941 ! Description: Retro groove colorscheme generalized
3942 ! Author: morhetz <morhetz@gmail.com>
3943 ! Source: https://github.com/morhetz/gruvbox-generalized
3944 ! Last Modified: 6 Sep 2014
3945 ! -----------------------------------------------------------------------------
3946
3947 ! hard contrast: *background: #f9f5d7
3948 *background: #fbf1c7
3949 ! soft contrast: *background: #f2e5bc
3950 *foreground: #3c3836
3951 ! Black + DarkGrey
3952 *color0: #fdf4c1
3953 *color8: #928374
3954 ! DarkRed + Red
3955 *color1: #cc241d
3956 *color9: #9d0006
3957 ! DarkGreen + Green
3958 *color2: #98971a
3959 *color10: #79740e
3960 ! DarkYellow + Yellow
3961 *color3: #d79921
3962 *color11: #b57614
3963 ! DarkBlue + Blue
3964 *color4: #458588
3965 *color12: #076678
3966 ! DarkMagenta + Magenta
3967 *color5: #b16286
3968 *color13: #8f3f71
3969 ! DarkCyan + Cyan
3970 *color6: #689d6a
3971 *color14: #427b58
3972 ! LightGrey + White
3973 *color7: #7c6f64
3974 *color15: #3c3836
3975 #+end_src
3976
3977 #+begin_src conf-xdefaults :tangle no
3978 ! -----------------------------------------------------------------------------
3979 ! File: gruvbox-dark.xresources
3980 ! Description: Retro groove colorscheme generalized
3981 ! Author: morhetz <morhetz@gmail.com>
3982 ! Source: https://github.com/morhetz/gruvbox-generalized
3983 ! Last Modified: 6 Sep 2014
3984 ! -----------------------------------------------------------------------------
3985
3986 ! hard contrast: *background: #1d2021
3987 *background: #282828
3988 ! soft contrast: *background: #32302f
3989 *foreground: #ebdbb2
3990 ! Black + DarkGrey
3991 *color0: #282828
3992 *color8: #928374
3993 ! DarkRed + Red
3994 *color1: #cc241d
3995 *color9: #fb4934
3996 ! DarkGreen + Green
3997 *color2: #98971a
3998 *color10: #b8bb26
3999 ! DarkYellow + Yellow
4000 *color3: #d79921
4001 *color11: #fabd2f
4002 ! DarkBlue + Blue
4003 *color4: #458588
4004 *color12: #83a598
4005 ! DarkMagenta + Magenta
4006 *color5: #b16286
4007 *color13: #d3869b
4008 ! DarkCyan + Cyan
4009 *color6: #689d6a
4010 *color14: #8ec07c
4011 ! LightGrey + White
4012 *color7: #a89984
4013 *color15: #ebdbb2
4014 #+end_src
4015
4016 #+begin_src conf-xdefaults :tangle no
4017 ! -----------------------------------------------------------------------------
4018 ! File: gruvbox-urxvt256.xresources
4019 ! Description: Retro groove colorscheme generalized
4020 ! Author: morhetz <morhetz@gmail.com>
4021 ! Source: https://github.com/morhetz/gruvbox-generalized
4022 ! Last Modified: 13 Dec 2013
4023 ! -----------------------------------------------------------------------------
4024
4025 URxvt.color24: #076678
4026 URxvt.color66: #427b58
4027 URxvt.color88: #9d0006
4028 URxvt.color96: #8f3f71
4029 URxvt.color100: #79740e
4030 URxvt.color108: #8ec07c
4031 URxvt.color109: #83a598
4032 URxvt.color130: #af3a03
4033 URxvt.color136: #b57614
4034 URxvt.color142: #b8bb26
4035 URxvt.color167: #fb4934
4036 URxvt.color175: #d3869b
4037 URxvt.color208: #fe8019
4038 URxvt.color214: #fabd2f
4039 URxvt.color223: #ebdbb2
4040 URxvt.color228: #f2e5bc
4041 URxvt.color229: #fbf1c7
4042 URxvt.color230: #f9f5d7
4043 URxvt.color234: #1d2021
4044 URxvt.color235: #282828
4045 URxvt.color236: #32302f
4046 URxvt.color237: #3c3836
4047 URxvt.color239: #504945
4048 URxvt.color241: #665c54
4049 URxvt.color243: #7c6f64
4050 URxvt.color244: #928374
4051 URxvt.color245: #928374
4052 URxvt.color246: #a89984
4053 URxvt.color248: #bdae93
4054 URxvt.color250: #d5c4a1
4055 #+end_src
4056
4057 ***** emacs
4058 :PROPERTIES:
4059 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/emacs")
4060 :END:
4061
4062 #+begin_src conf-xdefaults
4063 Emacs.menuBar: off
4064 Emacs.toolBar: off
4065 Emacs.verticalScrollBars: off
4066 Emacs.cursorBlink: off
4067 Emacs.FontBackend: xft,x
4068 ! Emacs.font: Ubuntu Mono-12
4069 ! Emacs.font: Triplicate T4C-11
4070 ! Emacs.font: Ubuntu Mono-10.5
4071 ! Emacs.font: Ubuntu Mono-12
4072 ! Emacs.font: Iosevka-11
4073
4074 ! Emacs.font: Fira Mono:size=15
4075 ! Emacs.font: DejaVu Sans Mono:size=15
4076 ! Emacs.font: Inconsolata:size=17
4077 ! Emacs.font: Inconsolata:size=16
4078 ! Emacs.font: Inconsolata LGC:size=14
4079 ! Emacs.font: Source Code Pro Medium-10.5
4080 Emacs.font: Ubuntu Mono:size=16
4081 ! Emacs.font: Iosevka:size=16
4082 #+end_src
4083
4084 ***** rxvt-unicode
4085 :PROPERTIES:
4086 :header-args+: :tangle (when (eq system-type 'gnu/linux) "~/.Xresources.d/rxvt-unicode")
4087 :END:
4088
4089 #+begin_src conf-xdefaults
4090 ! Font
4091 URxvt.font: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true
4092 URxvt.boldFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:bold, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:bold
4093 URxvt.italicFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:italic, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:italic
4094 URxvt.bolditalicFont: xft:ubuntu mono:pixelsize=16:antialias=true:hinting=true:bold:italic, xft:dejavu sans mono:pixelsize=15:antialias=true:hinting=true:bolditalic
4095
4096 URxvt.xftAntialias: true
4097 URxvt.letterSpace: 0
4098
4099 URxvt.depth: 0
4100 URxvt.loginShell: true
4101 URxvt.saveLines: 100000
4102 URxvt.internalBorder: 3
4103 URxvt.lineSpace: 0
4104 URxvt.scrollBar: false
4105 URxvt.scrollStyle: rxvt
4106 URxvt*scrollTtyOutput: false
4107 URxvt*scrollWithBuffer: true
4108 URxvt*scrollTtyKeypress: true
4109 URxvt.keysym.Shift-Up: command:\033]720;1\007
4110 URxvt.keysym.Shift-Down: command:\033]721;1\007
4111
4112 URxvt.perl-ext-common: default,clipboard,url-select,keyboard-select
4113 URxvt.perl-ext: bidi
4114 URxvt.bidi.enabled: 1
4115 URxvt.url-select.launcher: firefox
4116 URxvt.url-select.underline: true
4117 URxvt.keysym.M-u: perl:url-select:select_next
4118 URxvt.keysym.M-Escape: perl:keyboard-select:activate
4119 URxvt.keysym.M-s: perl:keyboard-select:search
4120 URxvt.url-launcher: /usr/bin/firefox
4121 URxvt.matcher.button: 1
4122 URxvt.iso14755: false
4123 URxvt.iso14755_53: false
4124 URxvt.keysym.M-c: perl:clipboard:copy
4125 URxvt.keysym.M-v: perl:clipboard:paste
4126 URxvt.keysym.C-A-V: perl:clipboard:paste_escaped
4127 URxvt.keysym.C-Up: font-size:increase
4128 URxvt.keysym.C-Down: font-size:decrease
4129 URxvt.keysym.C-S-Up: font-size:incglobal
4130 URxvt.keysym.C-S-Down: font-size:decglobal
4131 URxvt.keysym.C-equal: font-size:reset
4132 !URxvt.keysym.C-question: font-size:show
4133
4134 URxvt.iconFile: /usr/share/icons/Paper/48x48/apps/utilities-terminal.png
4135
4136 !urxvt*foreground: white
4137 !urxvt*background: black
4138
4139 !*color0: #2E3436
4140 !*color1: #a40000
4141 !*color2: #4E9A06
4142 !*color3: #C4A000
4143 !*color4: #3465A4
4144 !*color5: #75507B
4145 !*color6: #ce5c00
4146 !*color7: #babdb9
4147 !*color8: #555753
4148 !*color9: #EF2929
4149 !*color10: #8AE234
4150 !*color11: #FCE94F
4151 !*color12: #729FCF
4152 !*color13: #AD7FA8
4153 !*color14: #fcaf3e
4154 !*color15: #EEEEEC
4155
4156 !URxvt.foreground: #C8C8C8
4157 !URxvt.background: #FFFFFF
4158
4159 !! black
4160 !*color0: #2E3436
4161 !*color8: #555753
4162 !! red
4163 !*color1: #a40000
4164 !*color9: #EF2929
4165 !! green
4166 !*color2: #4E9A06
4167 !*color10: #8AE234
4168 !! yellow
4169 !*color3: #C4A000
4170 !*color11: #FCE94F
4171 !! blue
4172 !*color4: #3465A4
4173 !*color12: #729FCF
4174 !! purple
4175 !*color5: #75507B
4176 !*color13: #AD7FA8
4177 !! orange (replaces cyan)
4178 !*color6: #ce5c00
4179 !*color14: #fcaf3e
4180 !! white
4181 !*color7: #babdb9
4182 !*color15: #EEEEEC
4183
4184 ! Tango colour theme for rxvt-unicode
4185 URxvt.background: #FFFFFF
4186 URxvt.foreground: #000000
4187
4188 ! Black
4189 URxvt.color0: #2E3436
4190 URxvt.color8: #757773
4191
4192 ! Red
4193 URxvt.color1: #CC0000
4194 URxvt.color9: #EF2929
4195
4196 ! Green
4197 URxvt.color2: #4E9A06
4198 URxvt.color10: #8AE234
4199
4200 ! Yellow
4201 URxvt.color3: #C4A000
4202 URxvt.color11: #FCE94F
4203
4204 ! Blue
4205 URxvt.color4: #3465A4
4206 URxvt.color12: #729FCF
4207
4208 ! Magenta
4209 URxvt.color5: #75507B
4210 URxvt.color13: #AD7FA8
4211
4212 !! Cyan
4213 !URxvt.color6: #06989A
4214 !URxvt.color14: #34E2E2
4215 ! orange (replaces cyan)
4216 *color6: #ce5c00
4217 *color14: #fcaf3e
4218
4219 ! White
4220 URxvt.color7: #D3D7CF
4221 URxvt.color15: #EEEEEC
4222 #+end_src
4223
4224 ** XDG
4225 :PROPERTIES:
4226 :header-args+: :tangle ~/.config/user-dirs.dirs
4227 :END:
4228
4229 #+begin_src conf
4230 XDG_DESKTOP_DIR="$HOME/Desktop"
4231 XDG_DOCUMENTS_DIR="$HOME/usr/docs"
4232 XDG_DOWNLOAD_DIR="$HOME/usr/dls"
4233 XDG_MUSIC_DIR="$HOME/usr/music"
4234 XDG_PICTURES_DIR="$HOME/usr/pics"
4235 XDG_PUBLICSHARE_DIR="$HOME/usr/Public"
4236 XDG_TEMPLATES_DIR="$HOME/usr/Templates"
4237 XDG_VIDEOS_DIR="$HOME/usr/vids"
4238 #+end_src
4239
4240 ** Zathura
4241 :PROPERTIES:
4242 :header-args+: :tangle ~/.config/zathura/zathurarc
4243 :END:
4244
4245 #+begin_src conf
4246 set smooth-scroll true
4247 set selection-clipboard clipboard
4248 set zoom-step 05
4249 set default-bg "#272727"
4250 set statusbar-bg "#272727"
4251 set inputbar-bg "#373737"
4252 #+end_src
4253
4254 ** Zsh
4255
4256 My zsh setup is built on [[https://github.com/zimfw/zimfw][Zim]]. Further, my zshrc references [[https://github.com/junegunn/fzf][fzf]],
4257 [[https://github.com/zsh-users/zsh-autosuggestions][zsh-autosuggestions]], and [[https://github.com/hlissner/zsh-autopair][zsh-autopair]]; so be sure to have them
4258 installed.
4259
4260 *** zimrc
4261 :PROPERTIES:
4262 :header-args+: :tangle ~/.zimrc
4263 :END:
4264
4265 #+begin_src sh
4266
4267
4268 #################
4269 # CORE SETTINGS #
4270 #################
4271
4272 #
4273 # Zim settings
4274 #
4275
4276 # Select what modules you would like enabled.
4277 # The second line of modules may depend on options set by modules in the first
4278 # line. These dependencies are noted on the respective module's README.md.
4279 zmodules=(directory environment git git-info history input ssh utility custom \
4280 syntax-highlighting history-substring-search prompt completion)
4281
4282
4283 ###################
4284 # MODULE SETTINGS #
4285 ###################
4286
4287 #
4288 # Prompt
4289 #
4290
4291 # Set your desired prompt here
4292 zprompt_theme='pure'
4293 #PURE_PROMPT_SYMBOL=λ
4294 #PURE_PROMPT_SYMBOL=δ
4295 PURE_PROMPT_SYMBOL=➜
4296
4297 #
4298 # Completion
4299 #
4300
4301 # set an optional host-specific filename for the completion cache file
4302 # if none is provided, the default '.zcompdump' is used.
4303 #zcompdump_file=".zcompdump-${HOST}-${ZSH_VERSION}"
4304
4305 #
4306 # Utility
4307 #
4308
4309 # Uncomment to enable command correction prompts
4310 # See: http://zsh.sourceforge.net/Doc/Release/Options.html#Input_002fOutput
4311 setopt CORRECT
4312
4313 #
4314 # Environment
4315 #
4316
4317 # Set the string below to the desired terminal title format string.
4318 # The terminal title is redrawn upon directory change, however, variables like
4319 # ${PWD} are only evaluated once. Use prompt expansion strings for dynamic data:
4320 # http://zsh.sourceforge.net/Doc/Release/Prompt-Expansion.html#Simple-Prompt-Escapes
4321 # The example below uses the following format: 'username@host:/current/directory'
4322 ztermtitle='%n@%m:%~'
4323
4324 #
4325 # Input
4326 #
4327
4328 # Uncomment to enable double-dot expansion.
4329 # This appends '../' to your input for each '.' you type after an initial '..'
4330 #zdouble_dot_expand='true'
4331
4332 #
4333 # Syntax-Highlighting
4334 #
4335
4336 # This determines what highlighters will be used with the syntax-highlighting module.
4337 # Documentation of the highlighters can be found here:
4338 # https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters.md
4339 # For (u)rxvt, termite and gnome-terminal users,
4340 # removing the 'cursor' highlighter will fix the disappearing cursor problem
4341 #zhighlighters=(main brackets cursor)
4342 zhighlighters=(main brackets pattern)
4343
4344
4345 #
4346 # SSH
4347 #
4348
4349 # Load these ssh identities with the ssh module
4350 zssh_ids=(id_rsa plasma_id_rsa id_ed25519 id_rsa_aur)
4351
4352
4353 #
4354 # Pacman
4355 #
4356
4357 # Set (optional) pacman front-end.
4358 zpacman_frontend='yay'
4359
4360 # Load any helper scripts as defined here
4361 #zpacman_helper=(aur)
4362 #+end_src
4363
4364 *** zlogin
4365 :PROPERTIES:
4366 :header-args+: :tangle ~/.zlogin
4367 :END:
4368
4369 #+begin_src sh
4370
4371
4372 #
4373 # User configuration sourced by login shells
4374 #
4375
4376 # Initialize zim
4377 [[ -s ${ZIM_HOME}/login_init.zsh ]] && source ${ZIM_HOME}/login_init.zsh
4378 #+end_src
4379
4380 *** zprofile
4381 :PROPERTIES:
4382 :header-args+: :tangle ~/.zprofile
4383 :END:
4384
4385 #+begin_src sh
4386 #PATH="$(ruby -e 'print Gem.user_dir')/bin:$PATH"
4387 #PATH=$HOME/.gem/ruby/2.4.0/bin:$PATH
4388 export PATH=$HOME/.local/bin:$HOME/.cabal/bin:$HOME/.cargo/bin:$HOME/.elan/bin:$PATH
4389 export XDG_CONFIG_HOME=$HOME/.config
4390 export XDG_DATA_HOME=$HOME/.local/share
4391 export XDG_DATA_DIRS=/usr/local/share:/usr/share
4392 export MAILDIR="$HOME/mail"
4393 export CVS_RSH=ssh
4394 #export MATHMODELS=$HOME/src/eiffel/mathmodels
4395 #export RUST_SRC_PATH=~/.multirust/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/src/rust/src
4396 #export PATH=$PATH:$HOME/.rustup/toolchains/nightly-x86_64-unknown-linux-gnu/bin/
4397
4398 # Eiffel2Java stuff
4399 #export JAVA_HOME=/usr/lib/jvm/default
4400 #export CPATH=$CPATH:"$JAVA_HOME/include:$JAVA_HOME/include/linux"
4401 #export LIBRARY_PATH=$LIBRARY_PATH:"$JAVA_HOME/jre/lib/amd64/server"
4402 #export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:"$JAVA_HOME/jre/lib/amd64/server"
4403
4404 #export PATH="$HOME/usr/build/pvs:$PATH"
4405 #export SBCLISP_HOME=/usr/share/sbcl-source
4406 #export PVS_LIBRARY_PATH="$HOME/usr/build/pvs/nasalib"
4407
4408 export MOZ_USE_XINPUT2=1 # precise scrolling in firefox
4409
4410 #export JAVA_HOME=/usr/lib/jvm/java-8-openjdk
4411 #export ANDROID_JACK_VM_ARGS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx4G"
4412
4413 #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
4414 #+end_src
4415
4416 *** zshenv
4417 :PROPERTIES:
4418 :header-args+: :tangle ~/.zshenv
4419 :END:
4420
4421 #+begin_src sh
4422 # Ensure that a non-login, non-interactive shell has a defined environment.
4423 if [[ "$SHLVL" -eq 1 && ! -o LOGIN && -s "${ZDOTDIR:-$HOME}/.zprofile" ]]; then
4424 source "${ZDOTDIR:-$HOME}/.zprofile"
4425 fi
4426 #+end_src
4427
4428 *** zshrc
4429 :PROPERTIES:
4430 :header-args+: :tangle ~/.zshrc
4431 :END:
4432
4433 #+begin_src sh
4434 # Bash-like navigation
4435 #export WORDCHARS='*?_-.[]~=&;!#$%^(){}<>'
4436 #export WORDCHARS='*?-[]~=&;!#$%^(){}<>'
4437 export WORDCHARS='*?[]~=&;!#$%^(){}<>'
4438 #ZLE_SPACE_SUFFIX_CHARS=$'|&'
4439
4440 #disable -r time # disable shell reserved word
4441 #alias time='time -p' # -p for POSIX output
4442
4443 # rehash if last command was pacaur or pacman
4444 # (so that zsh picks up changes in $PATH immediately)
4445 TRAPUSR1() { rehash}; precmd() { [[ $history[$[ HISTCMD -1 ]] == *(pacaur|pacman)* ]] && killall -USR1 zsh }
4446
4447 #
4448 # User configuration sourced by interactive shells
4449 #
4450
4451 # Change default zim location
4452 export ZIM_HOME=${ZDOTDIR:-${HOME}}/.zim
4453
4454 # Start zim
4455 [[ -s ${ZIM_HOME}/init.zsh ]] && source ${ZIM_HOME}/init.zsh
4456
4457 ZSH_HIGHLIGHT_PATTERNS+=('rm -rf *' 'fg=white,bold,bg=red')
4458 #ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=red,bold'
4459
4460 setopt globdots
4461
4462 source ~/.zsh/zsh-autosuggestions/zsh-autosuggestions.zsh
4463 source ~/.zsh/zsh-autopair/autopair.zsh
4464
4465
4466 ### fzf ###
4467
4468 source /usr/share/fzf/key-bindings.zsh
4469 source /usr/share/fzf/completion.zsh
4470
4471 # Accept history selection instead of putting it on
4472 # the command line
4473 fzf-history-widget-accept() {
4474 fzf-history-widget
4475 zle accept-line
4476 }
4477 #zle -N fzf-history-widget-accept
4478 #bindkey '^R' fzf-history-widget-accept
4479
4480 # alt+c preview
4481 export FZF_ALT_C_OPTS="--preview 'tree -C {} | head -200'"
4482
4483 ### fzf ###
4484
4485
4486 # aliases
4487 alias mpv="mpv --ytdl-format mp4"
4488 alias mv="mv -iv"
4489 alias cp="cp -iv"
4490 alias scl=systemctl
4491 alias jcl=journalctl
4492 alias m="mbsync -Va; getmail; notmuch new"
4493 alias best="youtube-dl -f best"
4494 alias ace="mosh amin@ace.aminb.org"
4495 alias nix="ssh amin@aminb.org"
4496
4497 aur() {
4498 cd ~/usr/build
4499 git clone https://aur.archlinux.org/${1}.git
4500 cd ${1}
4501 }
4502
4503 # i-beam cursor
4504 echo -e "\033[5 q"
4505 #echo -e "\033[6 q"
4506 #+end_src
4507
4508 * Scripts
4509
4510 This section contains various useful scripts and the ones used by the
4511 programs above. For instance, =toggle-tablet= for switching to and
4512 from tablet mode on my X220T, =toggle-presentation-mode= for toggling
4513 Xfce's presentation mode which keeps the screen awake, and
4514 =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
4515 exact brightness value.
4516
4517 ** rofi-light
4518 :PROPERTIES:
4519 :header-args+: :tangle ~/.local/bin/rofi-light :shebang "#!/bin/bash"
4520 :END:
4521
4522 #+begin_src bash
4523 cur=$(light -G)
4524 val=$(rofi -dmenu -mesg "light $cur" -p "light -S " -l 0 -width 12)
4525 light -S $val
4526 #+end_src
4527
4528 ** toggle-layout
4529 :PROPERTIES:
4530 :header-args+: :tangle ~/.local/bin/toggle-layout :shebang "#!/bin/bash"
4531 :END:
4532
4533 #+begin_src bash
4534 lang="$(setxkbmap -print | grep xkb_symbols | cut -d'+' -f 2)"
4535
4536 if [ "$lang" = "us" ]; then
4537 setxkbmap ir
4538 else
4539 setxkbmap us
4540 # xmodmap $HOME/.Xmodmap
4541 fi
4542 #+end_src
4543
4544 ** toggle-presentation-mode
4545 :PROPERTIES:
4546 :header-args+: :tangle ~/.local/bin/toggle-presentation-mode :shebang "#!/bin/bash"
4547 :END:
4548
4549 #+begin_src bash
4550 xfconf-query -c xfce4-power-manager -p /xfce4-power-manager/presentation-mode -T
4551 #+end_src
4552
4553 ** unlock-def-gk.py
4554 :PROPERTIES:
4555 :header-args+: :tangle ~/.local/bin/unlock-def-gk.py :shebang "#!/usr/bin/env python2"
4556 :END:
4557
4558 #+begin_src python
4559 import gnomekeyring as gk
4560 # list_item_ids_sync('login')[0] == 1L
4561 gk.unlock_sync('Default_keyring',gk.item_get_info_sync('login',1L).get_secret())
4562 #+end_src
4563
4564 ** wp
4565
4566 My little wallpaper changer script.
4567
4568 *** wp
4569 :PROPERTIES:
4570 :header-args+: :tangle ~/.local/bin/wp :shebang "#!/bin/bash"
4571 :END:
4572
4573 #+begin_src bash :tangle no
4574 export DISPLAY=:0
4575
4576 case "$1" in
4577 "day")
4578 feh --bg-scale $HOME/usr/pics/island_day_by_arsenixc-d6ctqon.jpg
4579 ;;
4580 "night")
4581 feh --bg-scale $HOME/usr/pics/island_night_by_arsenixc-d6cz757.jpg
4582 ;;
4583 *)
4584 echo $"Usage: $0 {day|night}"
4585 exit 1
4586 esac
4587 #+end_src
4588
4589 *** wp-auto
4590 :PROPERTIES:
4591 :header-args+: :tangle ~/.local/bin/wp-auto :shebang "#!/bin/bash"
4592 :END:
4593
4594 #+begin_src bash :tangle no
4595 SED=$(which sed)
4596 ROFI=$(which rofi)
4597
4598 export DISPLAY=:0
4599 HOUR=$(date +%H)
4600
4601 if [ -z "${SED}" ]
4602 then
4603 echo "Did not find 'sed', script cannot continue."
4604 exit 1
4605 fi
4606 if [ -z "${ROFI}" ]
4607 then
4608 echo "Did not find rofi, there is no point to continue."
4609 exit 1
4610 fi
4611
4612 ###
4613 # Create if not exists, then removes #include of .theme file (if present) and add the selected theme to the end.
4614 # Repeated calls should leave the config clean-ish
4615 ###
4616 function set_theme()
4617 {
4618 CDIR="${HOME}/.config/rofi/"
4619 if [ ! -d "${CDIR}" ]
4620 then
4621 mkdir -p ${CDIR}
4622 fi
4623 if [ -f "${CDIR}/config" ]
4624 then
4625 ${SED} -i "/rofi\.theme: .*\.rasi$/d" "${CDIR}/config"
4626 fi
4627 echo "rofi.theme: ${1}" >> "${CDIR}/config"
4628
4629 }
4630
4631 if [ "$HOUR" -gt "19" ] || [ "$HOUR" -lt "7" ]
4632 then
4633 feh --bg-scale $HOME/usr/pics/island_night_by_arsenixc-d6cz757.jpg
4634 xrdb -merge $HOME/.Xresources.d/gruvbox-dark.xresources
4635 set_theme "/usr/share/rofi/themes//gruvbox-dark.rasi"
4636 else
4637 feh --bg-scale $HOME/usr/pics/island_day_by_arsenixc-d6ctqon.jpg
4638 xrdb -merge $HOME/.Xresources.d/gruvbox-light.xresources
4639 set_theme "/usr/share/rofi/themes//gruvbox-light.rasi"
4640 fi
4641 #+end_src
4642
4643 *** wp.service
4644 :PROPERTIES:
4645 :header-args+: :tangle ~/.config/systemd/user/wp.service
4646 :END:
4647
4648 #+begin_src conf :tangle no
4649 [Unit]
4650 Description=wallpaper service
4651
4652 [Service]
4653 Type=oneshot
4654 ExecStart=/usr/bin/bash -c %h/.local/bin/wp-auto
4655 #+end_src
4656
4657 *** wp.timer
4658 :PROPERTIES:
4659 :header-args+: :tangle ~/.config/systemd/user/wp.timer
4660 :END:
4661
4662 #+begin_src conf :tangle no
4663 [Unit]
4664 [Unit]
4665 Description=wallpaper timer
4666
4667 [Timer]
4668 OnCalendar=07,21:00
4669 Unit=wp.service
4670 Persistent=true
4671
4672 [Install]
4673 WantedBy=timers.target
4674 #+end_src
4675
4676 ** zathura-sync.sh
4677 :PROPERTIES:
4678 :header-args+: :tangle ~/.local/bin/zathura-sync.sh :shebang "#!/bin/sh"
4679 :END:
4680
4681 #+begin_src sh
4682 pos="$1"
4683 pdffile="$2"
4684 zathura --synctex-forward "$pos" "$pdffile" || \
4685 (
4686 zathura -x "emacsclient --eval '(progn (switch-to-buffer (file-name-nondirectory \"%{input}\")) (goto-line %{line}))'" "$pdffile" &
4687 sleep 1; zathura --synctex-forward "$pos" "$pdffile" )
4688 #+end_src
4689 ** Fun :)
4690
4691 *** eat-em
4692 :PROPERTIES:
4693 :header-args+: :tangle ~/.local/bin/eat-em :shebang "#!/bin/sh"
4694 :END:
4695
4696 #+begin_src sh
4697 # Original Posted at http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921
4698 # [ESC] character in original post removed here.
4699
4700 # ANSI Color -- use these variables to easily have different color
4701 # and format output. Make sure to output the reset sequence after
4702 # colors (f = foreground, b = background), and use the 'off'
4703 # feature for anything you turn on.
4704
4705 initializeANSI()
4706 {
4707 esc="$(echo -en '\e')"
4708
4709 blackf="${esc}[30m"; redf="${esc}[31m"; greenf="${esc}[32m"
4710 yellowf="${esc}[33m" bluef="${esc}[34m"; purplef="${esc}[35m"
4711 cyanf="${esc}[36m"; whitef="${esc}[37m"
4712
4713 blackb="${esc}[40m"; redb="${esc}[41m"; greenb="${esc}[42m"
4714 yellowb="${esc}[43m" blueb="${esc}[44m"; purpleb="${esc}[45m"
4715 cyanb="${esc}[46m"; whiteb="${esc}[47m"
4716
4717 boldon="${esc}[1m"; boldoff="${esc}[22m"
4718 italicson="${esc}[3m"; italicsoff="${esc}[23m"
4719 ulon="${esc}[4m"; uloff="${esc}[24m"
4720 invon="${esc}[7m"; invoff="${esc}[27m"
4721
4722 reset="${esc}[0m"
4723 }
4724
4725 # note in this first use that switching colors doesn't require a reset
4726 # first - the new color overrides the old one.
4727
4728 #clear
4729
4730 initializeANSI
4731
4732 cat << EOF
4733
4734 ${yellowf} ▄███████▄${reset} ${redf} ▄██████▄${reset} ${greenf} ▄██████▄${reset} ${bluef} ▄██████▄${reset} ${purplef} ▄██████▄${reset} ${cyanf} ▄██████▄${reset}
4735 ${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}
4736 ${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}
4737 ${yellowf}███████▄${reset} ${redf}████████████${reset} ${greenf}████████████${reset} ${bluef}████████████${reset} ${purplef}████████████${reset} ${cyanf}████████████${reset}
4738 ${yellowf}▀█████████▄▄${reset} ${redf}██▀██▀▀██▀██${reset} ${greenf}██▀██▀▀██▀██${reset} ${bluef}██▀██▀▀██▀██${reset} ${purplef}██▀██▀▀██▀██${reset} ${cyanf}██▀██▀▀██▀██${reset}
4739 ${yellowf} ▀███████▀${reset} ${redf}▀ ▀ ▀ ▀${reset} ${greenf}▀ ▀ ▀ ▀${reset} ${bluef}▀ ▀ ▀ ▀${reset} ${purplef}▀ ▀ ▀ ▀${reset} ${cyanf}▀ ▀ ▀ ▀${reset}
4740
4741 ${boldon}${yellowf} ▄███████▄ ${redf} ▄██████▄ ${greenf} ▄██████▄ ${bluef} ▄██████▄ ${purplef} ▄██████▄ ${cyanf} ▄██████▄${reset}
4742 ${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}
4743 ${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}
4744 ${boldon}${yellowf}███████▄ ${redf}████████████ ${greenf}████████████ ${bluef}████████████ ${purplef}████████████ ${cyanf}████████████${reset}
4745 ${boldon}${yellowf}▀█████████▄▄ ${redf}██▀██▀▀██▀██ ${greenf}██▀██▀▀██▀██ ${bluef}██▀██▀▀██▀██ ${purplef}██▀██▀▀██▀██ ${cyanf}██▀██▀▀██▀██${reset}
4746 ${boldon}${yellowf} ▀███████▀ ${redf}▀ ▀ ▀ ▀ ${greenf}▀ ▀ ▀ ▀ ${bluef}▀ ▀ ▀ ▀ ${purplef}▀ ▀ ▀ ▀ ${cyanf}▀ ▀ ▀ ▀${reset}
4747
4748 EOF
4749 #+end_src
4750
4751 *** invade-em
4752 :PROPERTIES:
4753 :header-args+: :tangle ~/.local/bin/invade-em :shebang "#!/bin/bash"
4754 :END:
4755
4756 #+begin_src bash
4757 #
4758 # ANSI color scheme script featuring Space Invaders
4759 #
4760 # Original: http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921
4761 # Modified by lolilolicon
4762 #
4763
4764 f=3 b=4
4765 for j in f b; do
4766 for i in {0..7}; do
4767 printf -v $j$i %b "\e[${!j}${i}m"
4768 done
4769 done
4770 bld=$'\e[1m'
4771 rst=$'\e[0m'
4772
4773 cat << EOF
4774
4775 $f1 ▀▄ ▄▀ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4 ▀▄ ▄▀ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst
4776 $f1 ▄█▀███▀█▄ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4 ▄█▀███▀█▄ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst
4777 $f1█▀███████▀█ $f2▀▀███▀▀███▀▀ $f3▀█▀██▀█▀ $f4█▀███████▀█ $f5▀▀███▀▀███▀▀ $f6▀█▀██▀█▀$rst
4778 $f1▀ ▀▄▄ ▄▄▀ ▀ $f2 ▀█▄ ▀▀ ▄█▀ $f3▀▄ ▄▀ $f4▀ ▀▄▄ ▄▄▀ ▀ $f5 ▀█▄ ▀▀ ▄█▀ $f6▀▄ ▄▀$rst
4779
4780 $bld$f1▄ ▀▄ ▄▀ ▄ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4▄ ▀▄ ▄▀ ▄ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst
4781 $bld$f1█▄█▀███▀█▄█ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4█▄█▀███▀█▄█ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst
4782 $bld$f1▀█████████▀ $f2▀▀▀██▀▀██▀▀▀ $f3▀▀█▀▀█▀▀ $f4▀█████████▀ $f5▀▀▀██▀▀██▀▀▀ $f6▀▀█▀▀█▀▀$rst
4783 $bld$f1 ▄▀ ▀▄ $f2▄▄▀▀ ▀▀ ▀▀▄▄ $f3▄▀▄▀▀▄▀▄ $f4 ▄▀ ▀▄ $f5▄▄▀▀ ▀▀ ▀▀▄▄ $f6▄▀▄▀▀▄▀▄$rst
4784
4785
4786 $f7▌$rst
4787
4788 $f7▌$rst
4789
4790 $f7 ▄█▄ $rst
4791 $f7▄█████████▄$rst
4792 $f7▀▀▀▀▀▀▀▀▀▀▀$rst
4793
4794 EOF
4795 #+end_src