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