Commit | Line | Data |
---|---|---|
08146d0e AB |
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 | ||
b13e2dc1 AB |
14 | This section contains the configuration files (dotfiles) of various |
15 | programs I use. | |
16 | ||
17 | ** [[https://github.com/afewmail/afew][afew]] | |
18 | :PROPERTIES: | |
19 | :header-args+: :tangle ~/.config/afew/config | |
20 | :END: | |
21 | ||
22 | #+begin_quote | |
23 | an initial tagging script for notmuch mail | |
24 | #+end_quote | |
25 | ||
26 | #+begin_src conf | |
27 | # This is the default filter chain | |
28 | [SpamFilter] | |
29 | #[ClassifyingFilter] | |
30 | [KillThreadsFilter] | |
31 | #[ListMailsFilter] | |
32 | [ArchiveSentMailsFilter] | |
33 | sent_tag = sent | |
34 | [InboxFilter] | |
35 | ||
36 | #[Filter.1] | |
37 | #query = 'folder:amin/lists/.haskell-cafe' | |
38 | #tags = +lists;+lists/haskell-cafe | |
39 | #message = lists/haskell-cafe | |
40 | ||
41 | #[Filter.2] | |
42 | #query = 'folder:amin/lists/.haskell-weekly' | |
43 | #tags = +lists;+lists/haskell-weekly | |
44 | #message = lists/haskell-weekly | |
45 | ||
46 | #[Filter.3] | |
47 | #query = 'folder:amin/lists/.hackernewsletter' | |
48 | #tags = +lists;+lists/hackernewsletter | |
49 | #message = lists/hackernewsletter | |
50 | ||
51 | ||
52 | #[FolderNameFilter] | |
53 | #folder_blacklist = Inbox | |
54 | #maildir_separator = /. | |
55 | #folder_transforms = Drafts:draft Junk:spam Trash:deleted Sent:sent Archive:archive lists/haskell-cafe:lists/haskell-cafe | |
56 | #+end_src | |
57 | ||
58 | ** bspwm | |
59 | ||
60 | *** bspwmrc | |
61 | :PROPERTIES: | |
62 | :header-args+: :tangle ~/.config/bspwm/bspwmrc :shebang "#!/bin/sh" | |
63 | :END: | |
64 | ||
65 | #+begin_src sh | |
66 | sxhkd & | |
67 | sh ~/.fehbg & | |
68 | xfce4-panel -d & | |
69 | #compton & | |
70 | sleep 0.5 && pasystray --notify=all & | |
71 | ||
72 | bspc monitor -d I II III IV V VI VII VIII IX X | |
73 | #bspc monitor eDP-1 -d I II III IV V | |
74 | #bspc monitor HDMI-1 -d VI VII VIII IX X | |
75 | ||
76 | #bspc config border_width 2 | |
77 | #bspc config window_gap 8 | |
78 | bspc config window_gap 0 | |
79 | ||
80 | bspc config bottom_padding 26 | |
81 | ||
82 | bspc config split_ratio 0.52 | |
83 | bspc config borderless_monocle true | |
84 | bspc config gapless_monocle true | |
85 | bspc config click_to_focus button1 | |
86 | bspc config directional_focus_tightness low | |
87 | ||
88 | bspc rule -a Firefox desktop='^1' follow=on | |
89 | bspc rule -a Nightly desktop='^1' follow=on | |
90 | bspc rule -a Emacs desktop='^2' state=tiled follow=on | |
91 | #bspc rule -a Chromium desktop='^4' follow=on | |
92 | bspc rule -a URxvt state=floating | |
93 | bspc rule -a URxvt:tiled state=tiled | |
94 | bspc rule -a Connman-gtk state=floating | |
95 | bspc rule -a Xfce4-panel state=floating | |
96 | bspc rule -a TelegramDesktop state=floating | |
97 | bspc rule -a Ec state=floating | |
98 | bspc rule -a Pavucontrol state=floating | |
99 | bspc rule -a Eog state=floating | |
100 | bspc rule -a Seahorse state=floating | |
101 | bspc rule -a mpv state=floating | |
102 | bspc rule -a Evince state=floating | |
103 | bspc rule -a Meld state=floating | |
104 | bspc rule -a Autokey-gtk state=floating | |
105 | bspc rule -a Mousepad state=floating | |
106 | bspc rule -a Wrapper-1.0 state=floating | |
107 | bspc rule -a File-roller state=floating | |
108 | bspc rule -a Gnome-disks state=floating | |
109 | bspc rule -a Termite state=floating | |
110 | bspc rule -a Termite:tiled state=tiled | |
111 | bspc rule -a Thunderbird:Calendar state=floating | |
112 | bspc rule -a Audacity state=floating | |
113 | bspc rule -a Proof state=floating # pvs x-show-proof | |
114 | bspc rule -a Nm-connection-editor state=floating | |
115 | bspc rule -a Wire state=floating | |
116 | bspc rule -a discord state=floating | |
117 | bspc rule -a X2goclient state=floating | |
118 | bspc rule -a SimpleScreenRecorder state=floating | |
119 | bspc rule -a Gimp state=floating | |
120 | bspc rule -a Wrapper-2.0 state=floating | |
121 | bspc rule -a Zathura state=tiled | |
122 | #+end_src | |
123 | ||
124 | *** sxhkdrc | |
125 | :PROPERTIES: | |
126 | :header-args+: :tangle ~/.config/sxhkd/sxhkdrc | |
127 | :END: | |
128 | ||
129 | #+begin_src conf | |
130 | # | |
131 | # wm independent hotkeys | |
132 | # | |
133 | ||
134 | # terminal emulator | |
135 | super + {_,shift} + Return | |
136 | urxvt{_, -name tiled} | |
137 | ||
138 | #super + {_,shift} + Return | |
139 | # termite{_, --name=tiled} | |
140 | ||
141 | # program launcher | |
142 | super + space | |
143 | rofi -show run -display-run '> ' -display-window ' 🗔 ' | |
144 | ||
145 | super + alt + space | |
146 | xfce4-popup-whiskermenu | |
147 | ||
148 | # window finder | |
149 | super + backslash | |
150 | rofi -show window -display-run '> ' -display-window ' 🗔 ' | |
151 | ||
152 | # password manager | |
153 | alt + space | |
154 | rofi-pass | |
155 | ||
156 | # firefox | |
157 | #super + r | |
158 | # firefox | |
159 | ||
160 | # chromium | |
161 | #super + c | |
162 | # chromium -incognito | |
163 | ||
164 | # emacs | |
165 | super + e | |
166 | emacs | |
167 | ||
168 | # make sxhkd reload its configuration files: | |
169 | super + Escape | |
170 | pkill -USR1 -x sxhkd | |
171 | ||
172 | # volume {up,down} | |
173 | XF86Audio{Raise,Lower}Volume | |
174 | pamixer --allow-boost --{in,de}crease 5 | |
175 | ||
176 | # mute | |
177 | XF86AudioMute | |
178 | pamixer --toggle-mute | |
179 | ||
180 | # playback control | |
181 | XF86Audio{Play,Prev,Next} | |
182 | mpc {toggle,prev,next} | |
183 | ||
184 | # lock the screen | |
185 | super + shift + q | |
186 | light-locker-command -l | |
187 | ||
188 | # Toggle keyboard layout | |
189 | super + F7 | |
190 | toggle-layout | |
191 | ||
192 | # Toggle Xfce presentation mode | |
193 | XF86LaunchB | |
194 | toggle-presentation-mode | |
195 | ||
196 | # monitor brightness | |
197 | XF86MonBrightness{Up,Down} | |
198 | light -{A,U} 5 | |
199 | ||
200 | super + apostrophe | |
201 | rofi-light | |
202 | ||
203 | # keyboard brightness | |
204 | #XF86KbdBrightness{Up,Down} | |
205 | # kbdlight {up,down} | |
206 | ||
207 | # | |
208 | # bspwm hotkeys | |
209 | # | |
210 | ||
211 | # quit bspwm normally | |
212 | super + alt + Escape | |
213 | bspc quit | |
214 | ||
215 | # close and kill | |
216 | super + {w,q} | |
217 | bspc node -{c,k} | |
218 | ||
219 | # alternate between the tiled and monocle layout | |
220 | super + m | |
221 | bspc desktop -l next | |
222 | ||
223 | # send the newest marked node to the newest preselected node | |
224 | super + y | |
225 | bspc node newest.marked.local -n newest.!automatic.local | |
226 | ||
227 | # swap the current node and the biggest node | |
228 | super + g | |
229 | bspc node -s biggest | |
230 | ||
231 | # | |
232 | # state/flags | |
233 | # | |
234 | ||
235 | # set the window state | |
236 | super + {t,shift + t,s,f} | |
237 | bspc node -t {tiled,pseudo_tiled,floating,fullscreen} | |
238 | ||
239 | # set the node flags | |
240 | super + ctrl + {m,x,y,z} | |
241 | bspc node -g {marked,locked,sticky,private} | |
242 | ||
243 | # | |
244 | # focus/swap | |
245 | # | |
246 | ||
247 | # focus the node in the given direction | |
248 | super + {_,shift + }{h,j,k,l} | |
249 | bspc node -{f,s} {west,south,north,east} | |
250 | ||
251 | # focus the node for the given path jump | |
252 | super + {p,b,comma,period} | |
253 | bspc node -f @{parent,brother,first,second} | |
254 | ||
255 | # focus the next/previous node in the current desktop | |
256 | super + {_,shift + }c | |
257 | bspc node -f {next,prev}.local | |
258 | ||
259 | # focus the next/previous desktop in the current monitor | |
260 | super + bracket{left,right} | |
261 | bspc desktop -f {prev,next}.local | |
262 | ||
263 | # send to next/prev desktop | |
264 | super + shift + bracket{left,right} | |
265 | bspc node -d {prev,next} --follow | |
266 | ||
267 | # focus the last node/desktop | |
268 | super + {grave,Tab} | |
269 | bspc {node,desktop} -f last | |
270 | ||
271 | # focus the older or newer node in the focus history | |
272 | super + {o,i} | |
273 | bspc wm -h off; \ | |
274 | bspc node {older,newer} -f; \ | |
275 | bspc wm -h on | |
276 | ||
277 | # focus or send to the given desktop | |
278 | super + {_,shift + }{1-9,0} | |
279 | bspc {desktop -f,node -d} '^{1-9,10}' | |
280 | ||
281 | # | |
282 | # preselect | |
283 | # | |
284 | ||
285 | # preselect the direction | |
286 | super + ctrl + {h,j,k,l} | |
287 | bspc node -p {west,south,north,east} | |
288 | ||
289 | # preselect the ratio | |
290 | super + ctrl + {1-9} | |
291 | bspc node -o 0.{1-9} | |
292 | ||
293 | # cancel the preselection for the focused node | |
294 | super + ctrl + space | |
295 | bspc node -p cancel | |
296 | ||
297 | # cancel the preselection for the focused desktop | |
298 | super + ctrl + shift + space | |
299 | bspc query -N -d | xargs -I id -n 1 bspc node id -p cancel | |
300 | ||
301 | # | |
302 | # move/resize | |
303 | # | |
304 | ||
305 | # expand a window by moving one of its side outward | |
306 | super + alt + {h,j,k,l} | |
307 | bspc node -z {left -20 0,bottom 0 20,top 0 -20,right 20 0} | |
308 | ||
309 | # contract a window by moving one of its side inward | |
310 | super + alt + shift + {h,j,k,l} | |
311 | bspc node -z {right -20 0,top 0 20,bottom 0 -20,left 20 0} | |
312 | ||
313 | # move a floating window | |
314 | super + {Left,Down,Up,Right} | |
315 | bspc node -v {-20 0,0 20,0 -20,20 0} | |
316 | ||
317 | #alt + bracket{left,right} | |
318 | # xdotool key --clearmodifiers ctrl+Page_{Up,Down} | |
319 | #+end_src | |
320 | ||
321 | ** compton | |
322 | :PROPERTIES: | |
323 | :header-args+: :tangle ~/.config/compton.conf | |
324 | :END: | |
325 | ||
326 | #+begin_src conf | |
327 | # Shadow | |
328 | shadow = false; # Enabled client-side shadows on windows. | |
329 | no-dock-shadow = true; # Avoid drawing shadows on dock/panel windows. | |
330 | no-dnd-shadow = true; # Don't draw shadows on DND windows. | |
331 | clear-shadow = true; # Zero the part of the shadow's mask behind the | |
332 | # window. Fix some weirdness with ARGB windows. | |
333 | shadow-radius = 5; # The blur radius for shadows. (default 12) | |
334 | shadow-offset-x = -5; # The left offset for shadows. (default -15) | |
335 | shadow-offset-y = -5; # The top offset for shadows. (default -15) | |
336 | # shadow-opacity = 0.7; # The translucency for shadows. (default .75) | |
337 | # shadow-red = 0.0; # Red color value of shadow. (0.0 - 1.0, defaults to 0) | |
338 | # shadow-green = 0.0; # Green color value of shadow. (0.0 - 1.0, defaults to 0) | |
339 | # shadow-blue = 0.0; # Blue color value of shadow. (0.0 - 1.0, defaults to 0) | |
340 | shadow-exclude = [ "n:e:Notification", "class_g = 'Chromium'", "class_g = 'Dmenu'", "class_g = 'Firefox' && argb" ]; # Exclude conditions for shadows. | |
341 | # shadow-exclude = "n:e:Notification"; | |
342 | #shadow-exclude = [ "_GTK_FRAME_EXTENTS@:c" ] # Fix dual shadow on some gtk3 powered applications | |
343 | shadow-ignore-shaped = true; # Avoid drawing shadow on all shaped windows | |
344 | # (see also: --detect-rounded-corners) | |
345 | ||
346 | # Opacity | |
347 | menu-opacity = 1.0; # The opacity for menus. (default 1.0) | |
348 | #inactive-opacity = 0.9; # Default opacity of inactive windows. (0.0 - 1.0) | |
349 | # active-opacity = 0.8; # Default opacity for active windows. (0.0 - 1.0) | |
350 | frame-opacity = 1.0; # Opacity of window titlebars and borders. (0.1 - 1.0) | |
351 | # inactive-opacity-override = true; # Let inactive opacity set by 'inactive-opacity' overrides | |
352 | # value of _NET_WM_OPACITY. Bad choice. | |
353 | alpha-step = 0.06; # XRender backend: Step size for alpha pictures. Increasing | |
354 | # it may result in less X resource usage, | |
355 | # Yet fading may look bad. | |
356 | #inactive-dim = 0.5; # Dim inactive windows. (0.0 - 1.0) | |
357 | #inactive-dim-fixed = true; # Do not let dimness adjust based on window opacity. | |
358 | # blur-background = true; # Blur background of transparent windows. | |
359 | # Bad performance with X Render backend. | |
360 | # GLX backend is preferred. | |
361 | # blur-background-frame = true; # Blur background of opaque windows with transparent | |
362 | # frames as well. | |
363 | blur-background-fixed = true; # Do not let blur radius adjust based on window opacity. | |
364 | blur-background-exclude = [ "window_type = 'dock'", "window_type = 'desktop'" ]; | |
365 | # Exclude conditions for background blur. | |
366 | ||
367 | # Fading | |
368 | fading = false; # Fade windows during opacity changes. | |
369 | fade-delta = 3; # The time between steps in a fade in milliseconds. (default 10). | |
370 | fade-in-step = 0.03; # Opacity change between steps while fading in. (default 0.028). | |
371 | fade-out-step = 0.03; # Opacity change between steps while fading out. (default 0.03). | |
372 | # no-fading-openclose = true; # Avoid fade windows in/out when opening/closing. | |
373 | fade-exclude = [ ]; # Exclude conditions for fading. | |
374 | ||
375 | # Other | |
376 | backend = "glx" # Backend to use: "xrender" or "glx". GLX backend is typically | |
377 | # much faster but depends on a sane driver. | |
378 | mark-wmwin-focused = true; # Try to detect WM windows and mark them as active. | |
379 | mark-ovredir-focused = true; # Mark all non-WM but override-redirect windows active (e.g. menus). | |
380 | use-ewmh-active-win = true; # Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused | |
381 | # instead of using FocusIn/Out events. Usually more reliable but | |
382 | # depends on a EWMH-compliant WM. | |
383 | detect-rounded-corners = false; # Detect rounded corners and treat them as rectangular when --shadow-ignore- shaped is on. | |
384 | detect-client-opacity = true; # Detect _NET_WM_OPACITY on client windows, useful for window | |
385 | # managers not passing _NET_WM_OPACITY of client windows to frame | |
386 | # windows. | |
387 | refresh-rate = 0; # For --sw-opti: Specify refresh rate of the screen. 0 for auto. | |
388 | vsync = "drm"; # "none", "drm", "opengl", "opengl-oml", "opengl-swc", "opengl-mswc" | |
389 | # See man page for more details. | |
390 | dbe = false; # Enable DBE painting mode. Rarely needed. | |
391 | paint-on-overlay = true; # Painting on X Composite overlay window. Recommended. | |
392 | sw-opti = false; # Limit compton to repaint at most once every 1 / refresh_rate. | |
393 | # Incompatible with certain VSync methods. | |
394 | unredir-if-possible = false; # Unredirect all windows if a full-screen opaque window is | |
395 | # detected, to maximize performance for full-screen windows. | |
396 | focus-exclude = [ ]; # A list of conditions of windows that should always be considered | |
397 | # focused. | |
398 | detect-transient = true; # Use WM_TRANSIENT_FOR to group windows, and consider windows in | |
399 | # the same group focused at the same time. | |
400 | detect-client-leader = true; # Use WM_CLIENT_LEADER to group windows. | |
401 | invert-color-include = [ ]; # Conditions for windows to be painted with inverted color. | |
402 | ||
403 | # GLX backend # GLX backend fine-tune options. See man page for more info. | |
404 | glx-no-stencil = true; # Recommended. | |
405 | glx-copy-from-front = false; # Useful with --glx-swap-method, | |
406 | # glx-use-copysubbuffermesa = true; # Recommended if it works. Breaks VSync. | |
407 | # glx-no-rebind-pixmap = true; # Recommended if it works. | |
408 | glx-no-rebind-pixmap = true; # Recommended if it works. | |
409 | #glx-swap-method = "4"; # See man page. | |
410 | glx-swap-method = "4"; # See man page. | |
411 | ||
412 | # Window type settings | |
413 | wintypes: | |
414 | { | |
415 | tooltip = { fade = true; shadow = false; opacity = 1; focus = true; }; | |
416 | menu = { shadow = false; }; | |
417 | dropdown_menu = { shadow = false; }; | |
418 | popup_menu = { shadow = false; }; | |
419 | utility = { shadow = false; }; | |
420 | # fade: Fade the particular type of windows. | |
421 | # shadow: Give those windows shadow | |
422 | # opacity: Default opacity for the type of windows. | |
423 | # focus: Whether to always consider windows of this type focused. | |
424 | }; | |
425 | #+end_src | |
426 | ||
05ab13aa AB |
427 | ** Dunst |
428 | :PROPERTIES: | |
429 | :header-args+: :tangle ~/.config/dunst/dunstrc | |
430 | :END: | |
431 | ||
432 | #+begin_src conf | |
433 | [global] | |
434 | #font = Ubuntu Mono 10.5 | |
435 | font = Inconsolata 11 | |
436 | ||
437 | # Path to default icons. | |
438 | icon_folders = /usr/share/icons/Moka/16x16/status/:/usr/share/icons/Moka/16x16/devices/:/usr/share/icons/Faba-Mono/16x16/status/:/usr/share/icons/Faba-Mono/16x16/devices/:/usr/share/icons/Moka/16x16/actions/:/usr/share/icons/Moka/16x16/categories/:/usr/share/icons/Moka/16x16/mimetypes/:/usr/share/icons/Moka/16x16/apps/:/usr/share/icons/Moka/16x16/places/:/usr/share/icons/Paper/16x16/status/ | |
439 | ||
440 | icon_position = left | |
441 | # <b>bold</b> | |
442 | # <i>italic</i> | |
443 | # <s>strikethrough<s/> | |
444 | # <u>underline</u> | |
445 | markup = full | |
446 | # The format of the message. Possible variables are: | |
447 | # %a appname | |
448 | # %s summary | |
449 | # %b body | |
450 | # %i iconname (including its path) | |
451 | # %I iconname (without its path) | |
452 | # %p progress value if set ([ 0%] to [100%]) or nothing | |
453 | # Markup is allowed | |
454 | format = "<b>%s</b>\n%b" | |
455 | # Sort messages by urgency | |
456 | sort = yes | |
457 | # Show how many messages are currently hidden (because of geometry) | |
458 | indicate_hiddenl= no | |
459 | # Alignment of message text. | |
460 | # Possible values are "left", "center" and "right" | |
461 | alignment = center | |
462 | # The frequency with wich text that is longer than the notification | |
463 | # window allows bounces back and forth. | |
464 | # This option conflicts with 'word_wrap'. | |
465 | # Set to 0 to disable | |
466 | bounce_freq = 3 | |
467 | # show age of message if message is older than show_age_threshold seconds. | |
468 | # set to -1 to disable | |
469 | show_age_threshold = -1 | |
470 | # split notifications into multiple lines if they don't fit into geometry | |
471 | word_wrap = yes | |
472 | # ignore newlines '\n' in notifications | |
473 | ignore_newline = no | |
474 | # The geometry of the message window. | |
475 | # geometry [{width}]x{height}][+/-{x}+/-{y}] | |
476 | # The height is measured in number of notifications everything else in pixels. If the width | |
477 | # is omitted but the height is given ("-geometry x2"), the message window | |
478 | # expands over the whole screen (dmenu-like). If width is 0, | |
479 | # the window expands to the longest message displayed. | |
480 | # A positive x is measured from the left, a negative from the | |
481 | # right side of the screen. Y is measured from the top and down respectevly. | |
482 | # The width can be negative. In this case the actual width is the | |
483 | # screen width minus the width defined in within the geometry option. | |
484 | #geometry = "410x12-12+12" | |
485 | #geometry = "0x0-30-30" | |
486 | geometry = "260x12-30-30" | |
487 | # The transparency of the window. range: [0; 100] | |
488 | # This option will only work if a compositing windowmanager is present (e.g. xcompmgr, compiz, etc..) | |
489 | transparency = 0 | |
490 | # Don't remove messages, if the user is idle (no mouse or keyboard input) | |
491 | # for longer than idle_threshold seconds. | |
492 | # Set to 0 to disable. | |
493 | idle_threshold = 120 | |
494 | # Which monitor should the notifications be displayed on. | |
495 | monitor = 0 | |
496 | # Display notification on focused monitor. Possible modes are: | |
497 | # mouse: follow mouse pointer | |
498 | # keyboard: follow window with keyboard focus | |
499 | # none: don't follow anything | |
500 | # | |
501 | # "keyboard" needs a windowmanager that exports the _NET_ACTIVE_WINDOW property. | |
502 | # This should be the case for almost all modern windowmanagers. | |
503 | # | |
504 | # If this option is set to mouse or keyboard, the monitor option will be | |
505 | # ignored. | |
506 | follow = keyboard | |
507 | # should a notification popped up from history be sticky or | |
508 | # timeout as if it would normally do. | |
509 | sticky_history = yes | |
510 | # The height of a single line. If the height is smaller than the font height, | |
511 | # it will get raised to the font height. | |
512 | # This adds empty space above and under the text. | |
513 | line_height = 0 | |
514 | ||
515 | show_indicators = yes | |
516 | ||
517 | # Draw a line of 'separatpr_height' pixel height between two notifications. | |
518 | # Set to 0 to disable | |
519 | separator_height = 3 | |
520 | # padding between text and separator | |
521 | padding = 8 | |
522 | # horizontal padding | |
523 | horizontal_padding = 8 | |
524 | # Define a color for the separator. | |
525 | # possible values are: | |
526 | # * auto: dunst tries to find a color fitting to the background | |
527 | # * foreground: use the same color as the foreground | |
528 | # * frame: use the same color as the frame. | |
529 | # * anything else will be interpreted as a X color | |
530 | separator_color = foreground | |
531 | # print a notification on startup | |
532 | # This is mainly for error detection, since dbus (re-)starts dunst | |
533 | # automatically after a crash. | |
534 | startup_notification = false | |
535 | # dmenu path | |
536 | #dmenu = /usr/bin/dmenu -p dunst: | |
537 | dmenu = /usr/bin/rofi -dmenu -p dunst: | |
538 | # browser for opening urls in context menu | |
539 | browser = /usr/bin/firefox -new-tab | |
540 | [frame] | |
541 | width = 0 | |
542 | color = "#377222" | |
543 | [shortcuts] | |
544 | # shortcuts are specified as [modifier+][modifier+]...key | |
545 | # available modifiers are 'ctrl', 'mod1' (the alt-key), 'mod2', 'mod3' | |
546 | # and 'mod4' (windows-key) | |
547 | # xev might be helpful to find names for keys | |
548 | # close notification | |
549 | close = ctrl+space | |
550 | # close all notifications | |
551 | close_all = ctrl+shift+space | |
552 | # redisplay last message(s) | |
553 | # On the US keyboard layout 'grave' is normally above TAB and left of '1'. | |
554 | history = ctrl+shift+h | |
555 | # context menu | |
556 | context = ctrl+shift+period | |
557 | [urgency_low] | |
558 | # IMPORTANT: colors have to be defined in quotation marks. | |
559 | # Otherwise the '#' and following would be interpreted as a comment. | |
560 | background = "#1d2a30" | |
561 | foreground = "#71c2af" | |
562 | timeout = 3 | |
563 | [urgency_normal] | |
564 | background = "#1d2a30" | |
565 | foreground = "#71c2af" | |
566 | timeout = 0 | |
567 | [urgency_critical] | |
568 | background = "#1d2a30" | |
569 | foreground = "#ff9982" | |
570 | timeout = 0 | |
571 | ||
572 | # Every section that isn't one of the above is interpreted as a rules | |
573 | # to override settings for certain messages. | |
574 | # Messages can be matched by 'appname', 'summary', 'body' or 'icon' | |
575 | # and you can override the 'timeout', 'urgency', 'foreground', 'background' | |
576 | # and 'format'. | |
577 | # Shell-like globbing will get expanded. | |
578 | # | |
579 | # SCRIPTING | |
580 | # you can specify a script that gets run when the rule matches by setting | |
581 | # the 'script' option. | |
582 | # The script will be called as follows: | |
583 | # script appname summary body icon urgency | |
584 | # where urgency can be "LOW", "NORMAL" or "CRITICAL". | |
585 | # | |
586 | # NOTE: if you don't want a notification to be displayed, set the format to "" | |
587 | # NOTE: It might be helpful to run dunst -print in a terminal in order to find | |
588 | # fitting options for rules. | |
589 | #[espeak] | |
590 | # summary = "*" | |
591 | # script = dunst_espeak.sh | |
592 | #[script-test] | |
593 | # summary = "*script*" | |
594 | # script = dunst_test.sh | |
595 | #[ignore] | |
596 | ## This notification will not be displayed | |
597 | # summary = "foobar" | |
598 | # format = "" | |
599 | #[signed_on] | |
600 | # appname = Pidgin | |
601 | # summary = "*signed on*" | |
602 | # urgency = low | |
603 | # | |
604 | #[signed_off] | |
605 | # appname = Pidgin | |
606 | # summary = *signed off* | |
607 | # urgency = low | |
608 | # | |
609 | #[says] | |
610 | # appname = Pidgin | |
611 | # summary = *says* | |
612 | # urgency = critical | |
613 | # | |
614 | #[twitter] | |
615 | # appname = Pidgin | |
616 | # summary = *twitter.com* | |
617 | # urgency = normal | |
618 | # | |
619 | [xfpm-backlight] | |
620 | summary = *Brightness* | |
621 | urgency = low | |
622 | #+end_src | |
623 | ||
624 | ** Fontconfig | |
625 | :PROPERTIES: | |
626 | :header-args+: :tangle ~/.config/fontconfig/fonts.conf | |
627 | :END: | |
628 | ||
629 | #+begin_src xml | |
630 | <?xml version="1.0"?> | |
631 | <!DOCTYPE fontconfig SYSTEM "fonts.dtd"> | |
632 | <fontconfig> | |
633 | <match target="font"> | |
634 | <edit mode="assign" name="rgba"> | |
635 | <const>rgb</const> | |
636 | </edit> | |
637 | </match> | |
638 | <match target="font"> | |
639 | <edit mode="assign" name="hinting"> | |
640 | <bool>true</bool> | |
641 | </edit> | |
642 | </match> | |
643 | <match target="font"> | |
644 | <edit mode="assign" name="hintstyle"> | |
645 | <const>hintslight</const> | |
646 | </edit> | |
647 | </match> | |
648 | <match target="font"> | |
649 | <edit mode="assign" name="antialias"> | |
650 | <bool>true</bool> | |
651 | </edit> | |
652 | </match> | |
653 | <match target="font"> | |
654 | <edit mode="assign" name="lcdfilter"> | |
655 | <const>lcddefault</const> | |
656 | </edit> | |
657 | </match> | |
658 | <dir>~/.fonts</dir> | |
659 | ||
660 | <!-- Use Liberation Sans for Helvetica (instead of Nimbus Sans) --> | |
661 | <alias binding="same"> | |
662 | <family>Helvetica</family> | |
663 | <accept> | |
664 | <family>Liberation Sans</family> | |
665 | </accept> | |
666 | </alias> | |
667 | </fontconfig> | |
668 | #+end_src | |
669 | ||
58cbbce2 | 670 | ** Git |
08146d0e AB |
671 | |
672 | *** gitconfig | |
673 | :PROPERTIES: | |
674 | :header-args+: :tangle ~/.gitconfig | |
675 | :END: | |
676 | ||
677 | **** user | |
678 | #+begin_src conf | |
679 | [user] | |
680 | name = Amin Bandali | |
681 | email = amin@aminb.org | |
682 | # signingkey = 4E05246AB0BF7FFB | |
683 | #+end_src | |
684 | ||
685 | **** signing | |
686 | #+begin_src conf | |
687 | # [commit] | |
688 | # gpgsign = true | |
689 | # [format] | |
690 | # signoff = true | |
691 | #+end_src | |
692 | ||
693 | **** core | |
694 | #+begin_src conf | |
695 | [core] | |
696 | autocrlf = input # CRLF -> LF on commit | |
697 | editor = emacsclient -t | |
698 | excludesfile = ~/.gitignore_global | |
699 | pager = "less" | |
700 | #+end_src | |
701 | ||
702 | **** gpg | |
703 | #+begin_src conf | |
704 | [gpg] | |
705 | program = gpg2 | |
706 | #+end_src | |
707 | ||
708 | **** alias | |
709 | #+begin_src conf | |
710 | [alias] | |
711 | git = !exec git # handle nested git calls, e.g. git git status | |
712 | aliases = config --get-regexp '^alias\\.' | |
713 | a = add | |
714 | s = status | |
715 | sl = status --long | |
716 | c = checkout | |
717 | cb = checkout -b | |
718 | b = branch | |
719 | r = rebase | |
720 | p = pull | |
721 | pr = pull --rebase | |
722 | ps = push | |
723 | psf = push --force | |
724 | #+end_src | |
725 | ||
726 | **** color | |
727 | #+begin_src conf | |
728 | [color] | |
729 | ui = auto | |
730 | [color "status"] | |
731 | added = green bold | |
732 | changed = red bold | |
733 | untracked = red bold | |
734 | [color "branch"] | |
735 | current = green bold | |
736 | remote = magenta bold | |
737 | [color "diff"] | |
738 | new = green bold | |
739 | old = red bold | |
740 | #+end_src | |
741 | ||
742 | **** status | |
743 | #+begin_src conf | |
744 | [status] | |
745 | # showUntrackedFiles = all | |
746 | short=true | |
747 | branch=true | |
748 | #+end_src | |
749 | ||
750 | **** github | |
751 | #+begin_src conf | |
752 | [github] | |
753 | user = aminb | |
754 | #+end_src | |
755 | ||
756 | *** gitignore | |
757 | :PROPERTIES: | |
758 | :header-args+: :tangle ~/.gitignore_global | |
759 | :END: | |
760 | ||
761 | #+begin_src conf | |
762 | *.orig | |
763 | *.py[co] | |
764 | *.sublime-workspace | |
765 | *~ | |
766 | .DS_Store | |
767 | *.elc | |
768 | *-autoloads.el | |
769 | #+end_src | |
58cbbce2 AB |
770 | |
771 | ** Latexmk | |
772 | :PROPERTIES: | |
773 | :header-args+: :tangle ~/.latexmkrc | |
774 | :END: | |
775 | ||
776 | #+begin_src conf | |
777 | $pdf_previewer = "start zathura %O %S"; | |
778 | $clean_ext = "aux out"; | |
779 | ||
780 | # $pdf_update_method = 4; | |
781 | # $pdf_update_command = "zathura %O %S"; | |
782 | ||
783 | # Synctex allows one to jump to from the PDF in Zathura to the source in Emacs | |
784 | # by Ctrl+click in the PDF. | |
785 | # Tell latexmk to use Zathura as a previewer, and run emacsclient as the Synctex | |
786 | # editor. | |
787 | # $pdf_previewer = 'exec zathura --synctex-forward -x \'emacsclient --no-wait +%{line} %{input}\' %O %S'; | |
788 | #+end_src | |
b13e2dc1 | 789 | |
931a4b06 AB |
790 | ** getmail |
791 | ||
792 | *** getmailrc | |
793 | :PROPERTIES: | |
794 | :header-args+: :tangle ~/.getmail/getmailrc | |
795 | :END: | |
796 | ||
797 | #+begin_src conf | |
798 | [retriever] | |
799 | type = SimplePOP3SSLRetriever | |
800 | server = fencepost.gnu.org | |
801 | username = aminb | |
802 | password_command = ("gpg2", "--no-tty", "-q", "-d", "~/.passwd/gnu.gpg") | |
803 | port = 995 | |
804 | use_apop = True | |
805 | ||
806 | [destination] | |
807 | type = Maildir | |
808 | path = ~/mail/gnu/Inbox/ | |
809 | ||
810 | [options] | |
811 | delete = True | |
812 | #+end_src | |
813 | ||
814 | *** getmail.service | |
815 | :PROPERTIES: | |
816 | :header-args+: :tangle ~/.config/systemd/user/getmail.service | |
817 | :END: | |
818 | ||
819 | #+begin_src conf :tangle no | |
820 | [Unit] | |
821 | Description=getmail service | |
822 | ||
823 | [Service] | |
824 | Type=oneshot | |
825 | ExecStart=/usr/bin/getmail | |
826 | StandardOutput=syslog | |
827 | StandardError=syslog | |
828 | #+end_src | |
829 | ||
830 | *** getmail.timer | |
831 | :PROPERTIES: | |
832 | :header-args+: :tangle ~/.config/systemd/user/getmail.timer | |
833 | :END: | |
834 | ||
835 | #+begin_src conf :tangle no | |
836 | [Unit] | |
837 | Description=getmail timer | |
838 | ||
839 | [Timer] | |
840 | OnCalendar=*:0/30 | |
841 | Persistent=true | |
842 | Unit=getmail.service | |
843 | ||
844 | [Install] | |
845 | WantedBy=timers.target | |
846 | #+end_src | |
847 | ||
848 | ** GnuPG | |
849 | :PROPERTIES: | |
850 | :header-args+: :tangle ~/.gnupg/gpg-agent.conf | |
851 | :END: | |
852 | ||
853 | #+begin_src conf | |
854 | default-cache-ttl 43200 | |
855 | max-cache-ttl 43200 | |
856 | ||
857 | default-cache-ttl-ssh 10800 | |
858 | max-cache-ttl-ssh 10800 | |
859 | ||
860 | # pinentry-program /usr/bin/pinentry-qt | |
861 | #+end_src | |
862 | ||
be76c6db AB |
863 | ** GTK |
864 | ||
865 | *** gtk-2.0 | |
866 | :PROPERTIES: | |
867 | :header-args+: :tangle ~/.gtkrc-2.0 | |
868 | :END: | |
869 | ||
870 | #+begin_src conf | |
871 | gtk-theme-name="Greybird" | |
872 | gtk-icon-theme-name="Paper" | |
873 | gtk-font-name="Ubuntu 10" | |
874 | gtk-menu-images=0 | |
875 | # gtk-key-theme-name = "Emacs" | |
876 | #+end_src | |
877 | ||
878 | *** gtk-3.0 | |
879 | :PROPERTIES: | |
880 | :header-args+: :tangle ~/.config/gtk-3.0/settings.ini | |
881 | :END: | |
882 | ||
883 | #+begin_src conf :tangle no | |
884 | [Settings] | |
885 | gtk-icon-theme-name = Paper | |
886 | # gtk-theme-name = Adwaita | |
887 | ||
888 | gtk-theme-name = Greybird | |
889 | # gtk-theme-name = Arc-Darker | |
890 | # gtk-theme-name = Numix-ArchBlue | |
891 | ||
892 | gtk-font-name = Ubuntu 10 | |
893 | # gtk-key-theme-name = Emacs | |
894 | #+end_src | |
895 | ||
896 | ** isync | |
897 | ||
898 | *** mbsyncrc | |
899 | :PROPERTIES: | |
900 | :header-args+: :tangle ~/.mbsyncrc | |
901 | :END: | |
902 | ||
903 | #+begin_src conf | |
904 | # Global defaults | |
905 | CopyArrivalDate yes | |
906 | ||
907 | ###### | |
908 | IMAPAccount amin | |
909 | Host nix.aminb.org | |
910 | User amin@aminb.org | |
911 | PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/amin.gpg" | |
912 | SSLType IMAPS | |
913 | ||
914 | IMAPStore amin-remote | |
915 | Account amin | |
916 | ||
917 | MaildirStore amin-local | |
918 | Path ~/mail/amin/ | |
919 | Inbox ~/mail/amin/Inbox | |
920 | SubFolders Verbatim | |
921 | ||
922 | Channel amin | |
923 | Master :amin-remote: | |
924 | Slave :amin-local: | |
925 | Patterns * !dovecot* | |
926 | Create Both | |
927 | SyncState * | |
928 | ||
929 | ###### | |
930 | IMAPAccount uwaterloo | |
931 | Host connect.uwaterloo.ca | |
59027673 | 932 | User abandali |
be76c6db AB |
933 | PassCmd "gpg -q --for-your-eyes-only --no-tty -d ~/.passwd/uwaterloo.gpg" |
934 | SSLType IMAPS | |
935 | ||
936 | IMAPStore uwaterloo-remote | |
937 | Account uwaterloo | |
938 | ||
939 | MaildirStore uwaterloo-local | |
940 | Path ~/mail/uwaterloo/ | |
941 | Inbox ~/mail/uwaterloo/Inbox | |
942 | SubFolders Verbatim | |
943 | ||
944 | Channel uwaterloo | |
945 | Master :uwaterloo-remote: | |
946 | Slave :uwaterloo-local: | |
947 | Patterns * !dovecot* | |
948 | Create Both | |
949 | SyncState * | |
950 | #+end_src | |
951 | ||
952 | *** mbsync.service | |
953 | :PROPERTIES: | |
954 | :header-args+: :tangle ~/.config/systemd/user/mbsync.service | |
955 | :END: | |
956 | ||
957 | #+begin_src conf :tangle no | |
958 | [Unit] | |
959 | Description=mbsync service | |
960 | ||
961 | [Service] | |
962 | Type=oneshot | |
963 | ExecStart=/usr/bin/mbsync -Va | |
964 | StandardOutput=syslog | |
965 | StandardError=syslog | |
966 | #+end_src | |
967 | ||
968 | *** mbsync.timer | |
969 | :PROPERTIES: | |
970 | :header-args+: :tangle ~/.config/systemd/user/mbsync.timer | |
971 | :END: | |
972 | ||
973 | #+begin_src conf :tangle no | |
974 | [Unit] | |
975 | Description=mbsync timer | |
976 | ||
977 | [Timer] | |
978 | OnCalendar=*:0/15 | |
979 | Persistent=true | |
980 | Unit=mbsync.service | |
981 | ||
982 | [Install] | |
983 | WantedBy=timers.target | |
984 | #+end_src | |
985 | ||
59027673 AB |
986 | ** mpd |
987 | :PROPERTIES: | |
988 | :header-args+: :tangle ~/.config/mpd/mpd.conf | |
989 | :END: | |
990 | ||
991 | #+begin_src conf | |
992 | # An example configuration file for MPD. | |
993 | # Read the user manual for documentation: http://www.musicpd.org/doc/user/ | |
994 | ||
995 | ||
996 | # Files and directories ####################################################### | |
997 | # | |
998 | # This setting controls the top directory which MPD will search to discover the | |
999 | # available audio files and add them to the daemon's online database. This | |
1000 | # setting defaults to the XDG directory, otherwise the music directory will be | |
1001 | # be disabled and audio files will only be accepted over ipc socket (using | |
1002 | # file:// protocol) or streaming files over an accepted protocol. | |
1003 | # | |
1004 | music_directory "~/usr/music" | |
1005 | # | |
1006 | # This setting sets the MPD internal playlist directory. The purpose of this | |
1007 | # directory is storage for playlists created by MPD. The server will use | |
1008 | # playlist files not created by the server but only if they are in the MPD | |
1009 | # format. This setting defaults to playlist saving being disabled. | |
1010 | # | |
1011 | playlist_directory "~/.mpd/playlists" | |
1012 | # | |
1013 | # This setting sets the location of the MPD database. This file is used to | |
1014 | # load the database at server start up and store the database while the | |
1015 | # server is not up. This setting defaults to disabled which will allow | |
1016 | # MPD to accept files over ipc socket (using file:// protocol) or streaming | |
1017 | # files over an accepted protocol. | |
1018 | # | |
1019 | db_file "~/.mpd/database" | |
1020 | # | |
1021 | # These settings are the locations for the daemon log files for the daemon. | |
1022 | # These logs are great for troubleshooting, depending on your log_level | |
1023 | # settings. | |
1024 | # | |
1025 | # The special value "syslog" makes MPD use the local syslog daemon. This | |
1026 | # setting defaults to logging to syslog, otherwise logging is disabled. | |
1027 | # | |
1028 | log_file "~/.mpd/log" | |
1029 | # | |
1030 | # This setting sets the location of the file which stores the process ID | |
1031 | # for use of mpd --kill and some init scripts. This setting is disabled by | |
1032 | # default and the pid file will not be stored. | |
1033 | # | |
1034 | pid_file "~/.mpd/pid" | |
1035 | # | |
1036 | # This setting sets the location of the file which contains information about | |
1037 | # most variables to get MPD back into the same general shape it was in before | |
1038 | # it was brought down. This setting is disabled by default and the server | |
1039 | # state will be reset on server start up. | |
1040 | # | |
1041 | state_file "~/.mpd/state" | |
1042 | # | |
1043 | # The location of the sticker database. This is a database which | |
1044 | # manages dynamic information attached to songs. | |
1045 | # | |
1046 | sticker_file "~/.mpd/sticker.sql" | |
1047 | # | |
1048 | ############################################################################### | |
1049 | ||
1050 | ||
1051 | # General music daemon options ################################################ | |
1052 | # | |
1053 | # This setting specifies the user that MPD will run as. MPD should never run as | |
1054 | # root and you may use this setting to make MPD change its user ID after | |
1055 | # initialization. This setting is disabled by default and MPD is run as the | |
1056 | # current user. | |
1057 | # | |
1058 | #user "nobody" | |
1059 | # | |
1060 | # This setting specifies the group that MPD will run as. If not specified | |
1061 | # primary group of user specified with "user" setting will be used (if set). | |
1062 | # This is useful if MPD needs to be a member of group such as "audio" to | |
1063 | # have permission to use sound card. | |
1064 | # | |
1065 | #group "nogroup" | |
1066 | # | |
1067 | # This setting sets the address for the daemon to listen on. Careful attention | |
1068 | # should be paid if this is assigned to anything other then the default, any. | |
1069 | # This setting can deny access to control of the daemon. Not effective if | |
1070 | # systemd socket activiation is in use. | |
1071 | # | |
1072 | # For network | |
1073 | #bind_to_address "any" | |
1074 | # | |
1075 | # And for Unix Socket | |
1076 | #bind_to_address "~/.mpd/socket" | |
1077 | # | |
1078 | # This setting is the TCP port that is desired for the daemon to get assigned | |
1079 | # to. | |
1080 | # | |
1081 | #port "6600" | |
1082 | # | |
1083 | # This setting controls the type of information which is logged. Available | |
1084 | # setting arguments are "default", "secure" or "verbose". The "verbose" setting | |
1085 | # argument is recommended for troubleshooting, though can quickly stretch | |
1086 | # available resources on limited hardware storage. | |
1087 | # | |
1088 | #log_level "default" | |
1089 | # | |
1090 | # If you have a problem with your MP3s ending abruptly it is recommended that | |
1091 | # you set this argument to "no" to attempt to fix the problem. If this solves | |
1092 | # the problem, it is highly recommended to fix the MP3 files with vbrfix | |
1093 | # (available from <http://www.willwap.co.uk/Programs/vbrfix.php>), at which | |
1094 | # point gapless MP3 playback can be enabled. | |
1095 | # | |
1096 | #gapless_mp3_playback "yes" | |
1097 | # | |
1098 | # Setting "restore_paused" to "yes" puts MPD into pause mode instead | |
1099 | # of starting playback after startup. | |
1100 | # | |
1101 | #restore_paused "no" | |
1102 | # | |
1103 | # This setting enables MPD to create playlists in a format usable by other | |
1104 | # music players. | |
1105 | # | |
1106 | #save_absolute_paths_in_playlists "no" | |
1107 | # | |
1108 | # This setting defines a list of tag types that will be extracted during the | |
1109 | # audio file discovery process. The complete list of possible values can be | |
1110 | # found in the user manual. | |
1111 | #metadata_to_use "artist,album,title,track,name,genre,date,composer,performer,disc" | |
1112 | # | |
1113 | # This setting enables automatic update of MPD's database when files in | |
1114 | # music_directory are changed. | |
1115 | # | |
1116 | #auto_update "yes" | |
1117 | # | |
1118 | # Limit the depth of the directories being watched, 0 means only watch | |
1119 | # the music directory itself. There is no limit by default. | |
1120 | # | |
1121 | #auto_update_depth "3" | |
1122 | # | |
1123 | ############################################################################### | |
1124 | ||
1125 | ||
1126 | # Symbolic link behavior ###################################################### | |
1127 | # | |
1128 | # If this setting is set to "yes", MPD will discover audio files by following | |
1129 | # symbolic links outside of the configured music_directory. | |
1130 | # | |
1131 | #follow_outside_symlinks "yes" | |
1132 | # | |
1133 | # If this setting is set to "yes", MPD will discover audio files by following | |
1134 | # symbolic links inside of the configured music_directory. | |
1135 | # | |
1136 | #follow_inside_symlinks "yes" | |
1137 | # | |
1138 | ############################################################################### | |
1139 | ||
1140 | ||
1141 | # Zeroconf / Avahi Service Discovery ########################################## | |
1142 | # | |
1143 | # If this setting is set to "yes", service information will be published with | |
1144 | # Zeroconf / Avahi. | |
1145 | # | |
1146 | #zeroconf_enabled "yes" | |
1147 | # | |
1148 | # The argument to this setting will be the Zeroconf / Avahi unique name for | |
1149 | # this MPD server on the network. | |
1150 | # | |
1151 | #zeroconf_name "Music Player" | |
1152 | # | |
1153 | ############################################################################### | |
1154 | ||
1155 | ||
1156 | # Permissions ################################################################# | |
1157 | # | |
1158 | # If this setting is set, MPD will require password authorization. The password | |
1159 | # setting can be specified multiple times for different password profiles. | |
1160 | # | |
1161 | #password "password@read,add,control,admin" | |
1162 | # | |
1163 | # This setting specifies the permissions a user has who has not yet logged in. | |
1164 | # | |
1165 | #default_permissions "read,add,control,admin" | |
1166 | # | |
1167 | ############################################################################### | |
1168 | ||
1169 | ||
1170 | # Database ####################################################################### | |
1171 | # | |
1172 | ||
1173 | #database { | |
1174 | # plugin "proxy" | |
1175 | # host "other.mpd.host" | |
1176 | # port "6600" | |
1177 | #} | |
1178 | ||
1179 | # Input ####################################################################### | |
1180 | # | |
1181 | ||
1182 | input { | |
1183 | plugin "curl" | |
1184 | # proxy "proxy.isp.com:8080" | |
1185 | # proxy_user "user" | |
1186 | # proxy_password "password" | |
1187 | } | |
1188 | ||
1189 | # | |
1190 | ############################################################################### | |
1191 | ||
1192 | # Audio Output ################################################################ | |
1193 | # | |
1194 | ||
1195 | audio_output { | |
1196 | type "pulse" | |
1197 | name "pulse audio" | |
1198 | } | |
1199 | ||
1200 | audio_output { | |
1201 | type "fifo" | |
1202 | name "my_fifo" | |
1203 | path "/tmp/mpd.fifo" | |
1204 | format "44100:16:2" | |
1205 | } | |
1206 | ||
1207 | # MPD supports various audio output types, as well as playing through multiple | |
1208 | # audio outputs at the same time, through multiple audio_output settings | |
1209 | # blocks. Setting this block is optional, though the server will only attempt | |
1210 | # autodetection for one sound card. | |
1211 | # | |
1212 | # An example of an ALSA output: | |
1213 | # | |
1214 | #audio_output { | |
1215 | # type "alsa" | |
1216 | # name "My ALSA Device" | |
1217 | ## device "hw:0,0" # optional | |
1218 | ## mixer_type "hardware" # optional | |
1219 | ## mixer_device "default" # optional | |
1220 | ## mixer_control "PCM" # optional | |
1221 | ## mixer_index "0" # optional | |
1222 | #} | |
1223 | # | |
1224 | # An example of an OSS output: | |
1225 | # | |
1226 | #audio_output { | |
1227 | # type "oss" | |
1228 | # name "My OSS Device" | |
1229 | ## device "/dev/dsp" # optional | |
1230 | ## mixer_type "hardware" # optional | |
1231 | ## mixer_device "/dev/mixer" # optional | |
1232 | ## mixer_control "PCM" # optional | |
1233 | #} | |
1234 | # | |
1235 | # An example of a shout output (for streaming to Icecast): | |
1236 | # | |
1237 | #audio_output { | |
1238 | # type "shout" | |
1239 | # encoder "vorbis" # optional | |
1240 | # name "My Shout Stream" | |
1241 | # host "localhost" | |
1242 | # port "8000" | |
1243 | # mount "/mpd.ogg" | |
1244 | # password "hackme" | |
1245 | # quality "5.0" | |
1246 | # bitrate "128" | |
1247 | # format "44100:16:1" | |
1248 | ## protocol "icecast2" # optional | |
1249 | ## user "source" # optional | |
1250 | ## description "My Stream Description" # optional | |
1251 | ## url "http://example.com" # optional | |
1252 | ## genre "jazz" # optional | |
1253 | ## public "no" # optional | |
1254 | ## timeout "2" # optional | |
1255 | ## mixer_type "software" # optional | |
1256 | #} | |
1257 | # | |
1258 | # An example of a recorder output: | |
1259 | # | |
1260 | #audio_output { | |
1261 | # type "recorder" | |
1262 | # name "My recorder" | |
1263 | # encoder "vorbis" # optional, vorbis or lame | |
1264 | # path "/var/lib/mpd/recorder/mpd.ogg" | |
1265 | ## quality "5.0" # do not define if bitrate is defined | |
1266 | # bitrate "128" # do not define if quality is defined | |
1267 | # format "44100:16:1" | |
1268 | #} | |
1269 | # | |
1270 | # An example of a httpd output (built-in HTTP streaming server): | |
1271 | # | |
1272 | #audio_output { | |
1273 | # type "httpd" | |
1274 | # name "My HTTP Stream" | |
1275 | # encoder "vorbis" # optional, vorbis or lame | |
1276 | # port "8000" | |
1277 | # bind_to_address "0.0.0.0" # optional, IPv4 or IPv6 | |
1278 | ## quality "5.0" # do not define if bitrate is defined | |
1279 | # bitrate "128" # do not define if quality is defined | |
1280 | # format "44100:16:1" | |
1281 | # max_clients "0" # optional 0=no limit | |
1282 | #} | |
1283 | # | |
1284 | # An example of a pulseaudio output (streaming to a remote pulseaudio server) | |
1285 | # | |
1286 | #audio_output { | |
1287 | # type "pulse" | |
1288 | # name "My Pulse Output" | |
1289 | ## server "remote_server" # optional | |
1290 | ## sink "remote_server_sink" # optional | |
1291 | #} | |
1292 | # | |
1293 | # An example of a winmm output (Windows multimedia API). | |
1294 | # | |
1295 | #audio_output { | |
1296 | # type "winmm" | |
1297 | # name "My WinMM output" | |
1298 | ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional | |
1299 | # or | |
1300 | ## device "0" # optional | |
1301 | ## mixer_type "hardware" # optional | |
1302 | #} | |
1303 | # | |
1304 | # An example of an openal output. | |
1305 | # | |
1306 | #audio_output { | |
1307 | # type "openal" | |
1308 | # name "My OpenAL output" | |
1309 | ## device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional | |
1310 | #} | |
1311 | # | |
1312 | # An example of an sndio output. | |
1313 | # | |
1314 | #audio_output { | |
1315 | # type "sndio" | |
1316 | # name "sndio output" | |
1317 | # mixer_type "software" | |
1318 | #} | |
1319 | # | |
1320 | # An example of an OS X output: | |
1321 | # | |
1322 | #audio_output { | |
1323 | # type "osx" | |
1324 | # name "My OS X Device" | |
1325 | ## device "Built-in Output" # optional | |
1326 | ## channel_map "-1,-1,0,1" # optional | |
1327 | #} | |
1328 | # | |
1329 | ## Example "pipe" output: | |
1330 | # | |
1331 | #audio_output { | |
1332 | # type "pipe" | |
1333 | # name "my pipe" | |
1334 | # command "aplay -f cd 2>/dev/null" | |
1335 | ## Or if you're want to use AudioCompress | |
1336 | # command "AudioCompress -m | aplay -f cd 2>/dev/null" | |
1337 | ## Or to send raw PCM stream through PCM: | |
1338 | # command "nc example.org 8765" | |
1339 | # format "44100:16:2" | |
1340 | #} | |
1341 | # | |
1342 | ## An example of a null output (for no audio output): | |
1343 | # | |
1344 | #audio_output { | |
1345 | # type "null" | |
1346 | # name "My Null Output" | |
1347 | # mixer_type "none" # optional | |
1348 | #} | |
1349 | # | |
1350 | ############################################################################### | |
1351 | ||
1352 | ||
1353 | # Normalization automatic volume adjustments ################################## | |
1354 | # | |
1355 | # This setting specifies the type of ReplayGain to use. This setting can have | |
1356 | # the argument "off", "album", "track" or "auto". "auto" is a special mode that | |
1357 | # chooses between "track" and "album" depending on the current state of | |
1358 | # random playback. If random playback is enabled then "track" mode is used. | |
1359 | # See <http://www.replaygain.org> for more details about ReplayGain. | |
1360 | # This setting is off by default. | |
1361 | # | |
1362 | #replaygain "album" | |
1363 | # | |
1364 | # This setting sets the pre-amp used for files that have ReplayGain tags. By | |
1365 | # default this setting is disabled. | |
1366 | # | |
1367 | #replaygain_preamp "0" | |
1368 | # | |
1369 | # This setting sets the pre-amp used for files that do NOT have ReplayGain tags. | |
1370 | # By default this setting is disabled. | |
1371 | # | |
1372 | #replaygain_missing_preamp "0" | |
1373 | # | |
1374 | # This setting enables or disables ReplayGain limiting. | |
1375 | # MPD calculates actual amplification based on the ReplayGain tags | |
1376 | # and replaygain_preamp / replaygain_missing_preamp setting. | |
1377 | # If replaygain_limit is enabled MPD will never amplify audio signal | |
1378 | # above its original level. If replaygain_limit is disabled such amplification | |
1379 | # might occur. By default this setting is enabled. | |
1380 | # | |
1381 | #replaygain_limit "yes" | |
1382 | # | |
1383 | # This setting enables on-the-fly normalization volume adjustment. This will | |
1384 | # result in the volume of all playing audio to be adjusted so the output has | |
1385 | # equal "loudness". This setting is disabled by default. | |
1386 | # | |
1387 | #volume_normalization "no" | |
1388 | # | |
1389 | ############################################################################### | |
1390 | ||
1391 | # Character Encoding ########################################################## | |
1392 | # | |
1393 | # If file or directory names do not display correctly for your locale then you | |
1394 | # may need to modify this setting. | |
1395 | # | |
1396 | #filesystem_charset "UTF-8" | |
1397 | # | |
1398 | ############################################################################### | |
1399 | #+end_src | |
1400 | ||
1401 | ** msmtp | |
1402 | :PROPERTIES: | |
1403 | :header-args+: :tangle ~/.msmtprc | |
1404 | :END: | |
1405 | ||
1406 | #+begin_src conf | |
1407 | # Set default values for all following accounts. | |
1408 | defaults | |
1409 | port 587 | |
1410 | tls on | |
1411 | auth on | |
1412 | #tls_trust_file /etc/ssl/certs/ca-certificates.crt | |
1413 | logfile ~/.msmtp.log | |
1414 | ||
1415 | # aminb | |
1416 | account aminb | |
1417 | host nix.aminb.org | |
1418 | 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 | |
1419 | tls_starttls on | |
1420 | from amin@aminb.org | |
1421 | user amin@aminb.org | |
1422 | passwordeval gpg2 --no-tty -q -d ~/.passwd/amin.gpg | |
1423 | ||
1424 | # gnu | |
1425 | account gnu | |
1426 | host fencepost.gnu.org | |
1427 | 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 | |
1428 | tls_starttls on | |
1429 | from aminb@gnu.org | |
1430 | user aminb | |
1431 | passwordeval gpg2 --no-tty -q -d ~/.passwd/gnu.gpg | |
1432 | ||
1433 | # uwaterloo | |
1434 | account uwaterloo | |
1435 | host connect.uwaterloo.ca | |
1436 | tls_starttls on | |
1437 | from abandali@uwaterloo.ca | |
1438 | user abandali | |
1439 | passwordeval gpg2 --no-tty -q -d ~/.passwd/uwaterloo.gpg | |
1440 | tls_trust_file /etc/ssl/certs/ca-certificates.crt | |
1441 | ||
1442 | # uwaterloo (friendly address) | |
1443 | account uwaterloo-friendly : uwaterloo | |
1444 | from amin.bandali@uwaterloo.ca | |
1445 | ||
1446 | # Set a default account | |
1447 | account default : aminb | |
1448 | #+end_src | |
1449 | ||
1450 | ** ncmpcpp | |
1451 | ||
1452 | *** config | |
1453 | :PROPERTIES: | |
1454 | :header-args+: :tangle ~/.ncmpcpp/config | |
1455 | :END: | |
1456 | ||
1457 | #+begin_src conf :tangle no | |
1458 | ############################################################## | |
1459 | ## This is the example configuration file. Copy it to ## | |
1460 | ## $HOME/.ncmpcpp/config or $XDG_CONFIG_HOME/ncmpcpp/config ## | |
1461 | ## and set up your preferences. ## | |
1462 | ############################################################## | |
1463 | # | |
1464 | ##### directories ###### | |
1465 | ## | |
1466 | ## Directory for storing ncmpcpp related files. | |
1467 | ## Changing it is useful if you want to store | |
1468 | ## everything somewhere else and provide command | |
1469 | ## line setting for alternative location to config | |
1470 | ## file which defines that while launching ncmpcpp. | |
1471 | ## | |
1472 | # | |
1473 | ncmpcpp_directory = ~/.ncmpcpp | |
1474 | # | |
1475 | ## | |
1476 | ## Directory for storing downloaded lyrics. It | |
1477 | ## defaults to ~/.lyrics since other MPD clients | |
1478 | ## (eg. ncmpc) also use that location. | |
1479 | ## | |
1480 | # | |
1481 | #lyrics_directory = ~/.lyrics | |
1482 | # | |
1483 | ##### connection settings ##### | |
1484 | # | |
1485 | #mpd_host = localhost | |
1486 | # | |
1487 | #mpd_port = 6600 | |
1488 | # | |
1489 | #mpd_connection_timeout = 5 | |
1490 | # | |
1491 | ## Needed for tag editor and file operations to work. | |
1492 | ## | |
1493 | mpd_music_dir = ~/usr/music | |
1494 | # | |
1495 | #mpd_crossfade_time = 5 | |
1496 | # | |
1497 | ##### music visualizer ##### | |
1498 | ## | |
1499 | ## Note: In order to make music visualizer work you'll | |
1500 | ## need to use mpd fifo output, whose format parameter | |
1501 | ## has to be set to 44100:16:1 for mono visualization | |
1502 | ## or 44100:16:2 for stereo visualization. Example | |
1503 | ## configuration (it has to be put into mpd.conf): | |
1504 | ## | |
1505 | ## audio_output { | |
1506 | ## type "fifo" | |
1507 | ## name "Visualizer feed" | |
1508 | ## path "/tmp/mpd.fifo" | |
1509 | ## format "44100:16:2" | |
1510 | ## } | |
1511 | ## | |
1512 | # | |
1513 | visualizer_fifo_path = /tmp/mpd.fifo | |
1514 | # | |
1515 | ## | |
1516 | ## Note: Below parameter is needed for ncmpcpp | |
1517 | ## to determine which output provides data for | |
1518 | ## visualizer and thus allow syncing between | |
1519 | ## visualization and sound as currently there | |
1520 | ## are some problems with it. | |
1521 | ## | |
1522 | # | |
1523 | visualizer_output_name = my fifo | |
1524 | # | |
1525 | ## | |
1526 | ## If you set format to 44100:16:2, make it 'yes'. | |
1527 | ## | |
1528 | visualizer_in_stereo = yes | |
1529 | # | |
1530 | ## | |
1531 | ## Multiply received samples by given value. Very | |
1532 | ## useful for proper visualization of quiet music. | |
1533 | ## | |
1534 | #visualizer_sample_multiplier = 1 | |
1535 | # | |
1536 | ## | |
1537 | ## Note: Below parameter defines how often ncmpcpp | |
1538 | ## has to "synchronize" visualizer and audio outputs. | |
1539 | ## 30 seconds is optimal value, but if you experience | |
1540 | ## synchronization problems, set it to lower value. | |
1541 | ## Keep in mind that sane values start with >=10. | |
1542 | ## | |
1543 | # | |
1544 | visualizer_sync_interval = 30 | |
1545 | # | |
1546 | ## | |
1547 | ## Note: To enable spectrum frequency visualization | |
1548 | ## you need to compile ncmpcpp with fftw3 support. | |
1549 | ## | |
1550 | # | |
1551 | ## Available values: spectrum, wave, wave_filled, ellipse. | |
1552 | ## | |
1553 | visualizer_type = spectrum | |
1554 | # | |
1555 | #visualizer_look = ●▮ | |
1556 | visualizer_look = "●•" | |
1557 | # | |
1558 | #visualizer_color = blue, cyan, green, yellow, magenta, red | |
1559 | # | |
1560 | ## Alternative subset of 256 colors for terminals that support it. | |
1561 | ## | |
1562 | #visualizer_color = 41, 83, 119, 155, 185, 215, 209, 203, 197, 161 | |
1563 | # | |
1564 | ##### system encoding ##### | |
1565 | ## | |
1566 | ## ncmpcpp should detect your charset encoding | |
1567 | ## but if it failed to do so, you can specify | |
1568 | ## charset encoding you are using here. | |
1569 | ## | |
1570 | ## Note: You can see whether your ncmpcpp build | |
1571 | ## supports charset detection by checking output | |
1572 | ## of `ncmpcpp --version`. | |
1573 | ## | |
1574 | ## Note: Since MPD uses UTF-8 by default, setting | |
1575 | ## this option makes sense only if your encoding | |
1576 | ## is different. | |
1577 | ## | |
1578 | # | |
1579 | #system_encoding = "" | |
1580 | # | |
1581 | ##### delays ##### | |
1582 | # | |
1583 | ## Time of inactivity (in seconds) after playlist | |
1584 | ## highlighting will be disabled (0 = always on). | |
1585 | ## | |
1586 | #playlist_disable_highlight_delay = 5 | |
1587 | # | |
1588 | ## Defines how long messages are supposed to be visible. | |
1589 | ## | |
1590 | #message_delay_time = 5 | |
1591 | # | |
1592 | ##### song format ##### | |
1593 | ## | |
1594 | ## For a song format you can use: | |
1595 | ## | |
1596 | ## %l - length | |
1597 | ## %f - filename | |
1598 | ## %D - directory | |
1599 | ## %a - artist | |
1600 | ## %A - album artist | |
1601 | ## %t - title | |
1602 | ## %b - album | |
1603 | ## %y - date | |
1604 | ## %n - track number (01/12 -> 01) | |
1605 | ## %N - full track info (01/12 -> 01/12) | |
1606 | ## %g - genre | |
1607 | ## %c - composer | |
1608 | ## %p - performer | |
1609 | ## %d - disc | |
1610 | ## %C - comment | |
1611 | ## %P - priority | |
1612 | ## $R - begin right alignment | |
1613 | ## | |
1614 | ## If you want to make sure that a part of the format is displayed | |
1615 | ## only when certain tags are present, you can archieve it by | |
1616 | ## grouping them with brackets, e.g. '{%a - %t}' will be evaluated | |
1617 | ## to 'ARTIST - TITLE' if both tags are present or '' otherwise. | |
1618 | ## It is also possible to define a list of alternatives by providing | |
1619 | ## several groups and separating them with '|', e.g. '{%t}|{%f}' | |
1620 | ## will be evaluated to 'TITLE' or 'FILENAME' if the former is not | |
1621 | ## present. | |
1622 | ## | |
1623 | ## Note: If you want to set limit on maximal length of a tag, just | |
1624 | ## put the appropriate number between % and character that defines | |
1625 | ## tag type, e.g. to make album take max. 20 terminal cells, use '%20b'. | |
1626 | ## | |
1627 | ## In addition, formats support markers used for text attributes. | |
1628 | ## They are followed by character '$'. After that you can put: | |
1629 | ## | |
1630 | ## - 0 - default window color (discards all other colors) | |
1631 | ## - 1 - black | |
1632 | ## - 2 - red | |
1633 | ## - 3 - green | |
1634 | ## - 4 - yellow | |
1635 | ## - 5 - blue | |
1636 | ## - 6 - magenta | |
1637 | ## - 7 - cyan | |
1638 | ## - 8 - white | |
1639 | ## - 9 - end of current color | |
1640 | ## - b - bold text | |
1641 | ## - u - underline text | |
1642 | ## - r - reverse colors | |
1643 | ## - a - use alternative character set | |
1644 | ## | |
1645 | ## If you don't want to use a non-color attribute anymore, just put it | |
1646 | ## again, but this time insert character '/' between '$' and attribute | |
1647 | ## character, e.g. {$b%t$/b}|{$r%f$/r} will display bolded title tag | |
1648 | ## or filename with reversed colors. | |
1649 | ## | |
1650 | ## If you want to use 256 colors and/or background colors in formats | |
1651 | ## (the naming scheme is described below in section about color | |
1652 | ## definitions), it can be done with the syntax $(COLOR), e.g. to set | |
1653 | ## the artist tag to one of the non-standard colors and make it have | |
1654 | ## yellow background, you need to write $(197_yellow)%a$(end). Note | |
1655 | ## that for standard colors this is interchangable with attributes | |
1656 | ## listed above. | |
1657 | ## | |
1658 | ## Note: colors can be nested. | |
1659 | ## | |
1660 | # | |
1661 | #song_list_format = {%a - }{%t}|{$8%f$9}$R{$3(%l)$9} | |
1662 | # | |
1663 | #song_status_format = {{%a{ "%b"{ (%y)}} - }{%t}}|{%f} | |
1664 | # | |
1665 | #song_library_format = {%n - }{%t}|{%f} | |
1666 | # | |
1667 | # | |
1668 | #alternative_header_first_line_format = $b$1$aqqu$/a$9 {%t}|{%f} $1$atqq$/a$9$/b | |
1669 | # | |
1670 | #alternative_header_second_line_format = {{$4$b%a$/b$9}{ - $7%b$9}{ ($4%y$9)}}|{%D} | |
1671 | # | |
1672 | #now_playing_prefix = $b | |
1673 | # | |
1674 | #now_playing_suffix = $/b | |
1675 | # | |
1676 | #browser_playlist_prefix = "$2playlist$9 " | |
1677 | # | |
1678 | #selected_item_prefix = $6 | |
1679 | # | |
1680 | #selected_item_suffix = $9 | |
1681 | # | |
1682 | #modified_item_prefix = $3> $9 | |
1683 | # | |
1684 | ## | |
1685 | ## Note: attributes are not supported for the following variables. | |
1686 | ## | |
1687 | #song_window_title_format = {%a - }{%t}|{%f} | |
1688 | ## | |
1689 | ## Note: Below variables are used for sorting songs in browser. | |
1690 | ## The sort mode determines how songs are sorted, and can be used | |
1691 | ## in combination with a sort format to specify a custom sorting format. | |
1692 | ## Available values for browser_sort_mode are "name", "mtime", "format" | |
1693 | ## and "noop". | |
1694 | ## | |
1695 | # | |
1696 | #browser_sort_mode = name | |
1697 | # | |
1698 | #browser_sort_format = {%a - }{%t}|{%f} {(%l)} | |
1699 | # | |
1700 | ##### columns settings ##### | |
1701 | ## | |
1702 | ## syntax of song columns list format is "column column etc." | |
1703 | ## | |
1704 | ## - syntax for each column is: | |
1705 | ## | |
1706 | ## (width of the column)[color of the column]{displayed tag} | |
1707 | ## | |
1708 | ## Note: Width is by default in %, if you want a column to | |
1709 | ## have fixed size, add 'f' after the value, e.g. (10)[white]{a} | |
1710 | ## will be the column that take 10% of screen (so the real width | |
1711 | ## will depend on actual screen size), whereas (10f)[white]{a} | |
1712 | ## will take 10 terminal cells, no matter how wide the screen is. | |
1713 | ## | |
1714 | ## - color is optional (if you want the default one, | |
1715 | ## leave the field empty). | |
1716 | ## | |
1717 | ## Note: You can give a column additional attributes by putting appropriate | |
1718 | ## character after displayed tag character. Available attributes are: | |
1719 | ## | |
1720 | ## - r - column will be right aligned | |
1721 | ## - E - if tag is empty, empty tag marker won't be displayed | |
1722 | ## | |
1723 | ## You can also: | |
1724 | ## | |
1725 | ## - give a column custom name by putting it after attributes, | |
1726 | ## separated with character ':', e.g. {lr:Length} gives you | |
1727 | ## right aligned column of lengths named "Length". | |
1728 | ## | |
1729 | ## - define sequence of tags, that have to be displayed in case | |
1730 | ## predecessor is empty in a way similar to the one in classic | |
1731 | ## song format, i.e. using '|' character, e.g. {a|c|p:Owner} | |
1732 | ## creates column named "Owner" that tries to display artist | |
1733 | ## tag and then composer and performer if previous ones are | |
1734 | ## not available. | |
1735 | ## | |
1736 | # | |
1737 | #song_columns_list_format = (20)[]{a} (6f)[green]{NE} (50)[white]{t|f:Title} (20)[cyan]{b} (7f)[magenta]{l} | |
1738 | # | |
1739 | ##### various settings ##### | |
1740 | # | |
1741 | ## | |
1742 | ## Note: Custom command that will be executed each | |
1743 | ## time song changes. Useful for notifications etc. | |
1744 | ## | |
1745 | #execute_on_song_change = "" | |
1746 | # | |
1747 | #playlist_show_mpd_host = no | |
1748 | # | |
1749 | #playlist_show_remaining_time = no | |
1750 | # | |
1751 | #playlist_shorten_total_times = no | |
1752 | # | |
1753 | #playlist_separate_albums = no | |
1754 | # | |
1755 | ## | |
1756 | ## Note: Possible display modes: classic, columns. | |
1757 | ## | |
1758 | #playlist_display_mode = columns | |
1759 | # | |
1760 | #browser_display_mode = classic | |
1761 | # | |
1762 | #search_engine_display_mode = classic | |
1763 | # | |
1764 | #playlist_editor_display_mode = classic | |
1765 | # | |
1766 | #discard_colors_if_item_is_selected = yes | |
1767 | # | |
1768 | #incremental_seeking = yes | |
1769 | # | |
1770 | #seek_time = 1 | |
1771 | # | |
1772 | #volume_change_step = 2 | |
1773 | # | |
1774 | #autocenter_mode = no | |
1775 | # | |
1776 | #centered_cursor = no | |
1777 | # | |
1778 | ## | |
1779 | ## Note: You can specify third character which will | |
1780 | ## be used to build 'empty' part of progressbar. | |
1781 | ## | |
1782 | #progressbar_look = => | |
1783 | progressbar_look = "─╼╶" | |
1784 | #progressbar_look = "─⊙╶" | |
1785 | # | |
1786 | #progressbar_boldness = yes | |
1787 | # | |
1788 | ## Available values: database, playlist. | |
1789 | ## | |
1790 | #default_place_to_search_in = database | |
1791 | # | |
1792 | ## Available values: classic, alternative. | |
1793 | ## | |
1794 | #user_interface = classic | |
1795 | # | |
1796 | #data_fetching_delay = yes | |
1797 | # | |
1798 | ## Available values: artist, album_artist, date, genre, composer, performer. | |
1799 | ## | |
1800 | #media_library_primary_tag = artist | |
1801 | # | |
1802 | ## Available values: wrapped, normal. | |
1803 | ## | |
1804 | #default_find_mode = wrapped | |
1805 | # | |
1806 | #default_tag_editor_pattern = %n - %t | |
1807 | # | |
1808 | #header_visibility = yes | |
1809 | # | |
1810 | #statusbar_visibility = yes | |
1811 | # | |
1812 | #titles_visibility = yes | |
1813 | # | |
1814 | #header_text_scrolling = yes | |
1815 | # | |
1816 | #cyclic_scrolling = no | |
1817 | # | |
1818 | #lines_scrolled = 2 | |
1819 | # | |
1820 | #follow_now_playing_lyrics = no | |
1821 | # | |
1822 | #fetch_lyrics_for_current_song_in_background = no | |
1823 | # | |
1824 | #store_lyrics_in_song_dir = no | |
1825 | # | |
1826 | #generate_win32_compatible_filenames = yes | |
1827 | # | |
1828 | #allow_for_physical_item_deletion = no | |
1829 | # | |
1830 | ## | |
1831 | ## Note: If you set this variable, ncmpcpp will try to | |
1832 | ## get info from last.fm in language you set and if it | |
1833 | ## fails, it will fall back to english. Otherwise it will | |
1834 | ## use english the first time. | |
1835 | ## | |
1836 | ## Note: Language has to be expressed as an ISO 639 alpha-2 code. | |
1837 | ## | |
1838 | #lastfm_preferred_language = en | |
1839 | # | |
1840 | #show_hidden_files_in_local_browser = no | |
1841 | # | |
1842 | ## | |
1843 | ## How shall screen switcher work? | |
1844 | ## | |
1845 | ## - "previous" - switch between the current and previous screen. | |
1846 | ## - "screen1,...,screenN" - switch between given sequence of screens. | |
1847 | ## | |
1848 | ## Screens available for use: help, playlist, browser, search_engine, | |
1849 | ## media_library, playlist_editor, tag_editor, outputs, visualizer, clock. | |
1850 | ## | |
1851 | #screen_switcher_mode = playlist, browser | |
1852 | # | |
1853 | ## | |
1854 | ## Note: You can define startup screen | |
1855 | ## by choosing screen from the list above. | |
1856 | ## | |
1857 | #startup_screen = playlist | |
1858 | # | |
1859 | ## | |
1860 | ## Note: You can define startup slave screen | |
1861 | ## by choosing screen from the list above or | |
1862 | ## an empty value for no slave screen. | |
1863 | ## | |
1864 | #startup_slave_screen = "" | |
1865 | # | |
1866 | #startup_slave_screen_focus = no | |
1867 | # | |
1868 | ## | |
1869 | ## Default width of locked screen (in %). | |
1870 | ## Acceptable values are from 20 to 80. | |
1871 | ## | |
1872 | # | |
1873 | #locked_screen_width_part = 50 | |
1874 | # | |
1875 | #ask_for_locked_screen_width_part = yes | |
1876 | # | |
1877 | #jump_to_now_playing_song_at_start = yes | |
1878 | # | |
1879 | #ask_before_clearing_playlists = yes | |
1880 | # | |
1881 | #clock_display_seconds = no | |
1882 | # | |
1883 | #display_volume_level = yes | |
1884 | # | |
1885 | #display_bitrate = no | |
1886 | # | |
1887 | #display_remaining_time = no | |
1888 | # | |
1889 | ## Available values: none, basic, extended, perl. | |
1890 | ## | |
1891 | #regular_expressions = perl | |
1892 | # | |
1893 | ## | |
1894 | ## Note: If below is enabled, ncmpcpp will ignore leading | |
1895 | ## "The" word while sorting items in browser, tags in | |
1896 | ## media library, etc. | |
1897 | ## | |
1898 | #ignore_leading_the = no | |
1899 | # | |
1900 | #block_search_constraints_change_if_items_found = yes | |
1901 | # | |
1902 | #mouse_support = yes | |
1903 | # | |
1904 | #mouse_list_scroll_whole_page = yes | |
1905 | # | |
1906 | #empty_tag_marker = <empty> | |
1907 | # | |
1908 | #tags_separator = " | " | |
1909 | # | |
1910 | #tag_editor_extended_numeration = no | |
1911 | # | |
1912 | #media_library_sort_by_mtime = no | |
1913 | # | |
1914 | #enable_window_title = yes | |
1915 | # | |
1916 | ## | |
1917 | ## Note: You can choose default search mode for search | |
1918 | ## engine. Available modes are: | |
1919 | ## | |
1920 | ## - 1 - use mpd built-in searching (no regexes, pattern matching) | |
1921 | ## - 2 - use ncmpcpp searching (pattern matching with support for regexes, | |
1922 | ## but if your mpd is on a remote machine, downloading big database | |
1923 | ## to process it can take a while | |
1924 | ## - 3 - match only exact values (this mode uses mpd function for searching | |
1925 | ## in database and local one for searching in current playlist) | |
1926 | ## | |
1927 | # | |
1928 | #search_engine_default_search_mode = 1 | |
1929 | # | |
1930 | #external_editor = nano | |
1931 | # | |
1932 | ## Note: set to yes if external editor is a console application. | |
1933 | ## | |
1934 | #use_console_editor = yes | |
1935 | # | |
1936 | ##### colors definitions ##### | |
1937 | ## | |
1938 | ## It is possible to set a background color by setting a color | |
1939 | ## value "<foreground>_<background>", e.g. red_black will set | |
1940 | ## foregound color to red and background color to black. | |
1941 | ## | |
1942 | ## In addition, for terminals that support 256 colors it | |
1943 | ## is possible to set one of them by using a number in range | |
1944 | ## [1, 256] instead of color name, e.g. numerical value | |
1945 | ## corresponding to red_black is 2_1. To find out if the | |
1946 | ## terminal supports 256 colors, run ncmpcpp and check out | |
1947 | ## the bottom of the help screen for list of available colors | |
1948 | ## and their numerical values. | |
1949 | ## | |
1950 | ## Note: due to technical limitations of ncurses, if 256 colors | |
1951 | ## are used, it is possible to either use only the colors with | |
1952 | ## default background color, or all pairs from 1_1 up to 254_127, | |
1953 | ## depending on the ncurses version used. | |
1954 | ## | |
1955 | # | |
1956 | #colors_enabled = yes | |
1957 | # | |
1958 | #empty_tag_color = cyan | |
1959 | # | |
1960 | #header_window_color = default | |
1961 | # | |
1962 | #volume_color = default | |
1963 | # | |
1964 | #state_line_color = default | |
1965 | # | |
1966 | #state_flags_color = default | |
1967 | # | |
1968 | #main_window_color = yellow | |
1969 | # | |
1970 | #color1 = white | |
1971 | # | |
1972 | #color2 = green | |
1973 | # | |
1974 | #main_window_highlight_color = yellow | |
1975 | # | |
1976 | #progressbar_color = black | |
1977 | # | |
1978 | #progressbar_elapsed_color = green | |
1979 | # | |
1980 | #statusbar_color = default | |
1981 | # | |
1982 | #alternative_ui_separator_color = black | |
1983 | # | |
1984 | #active_column_color = red | |
1985 | # | |
1986 | #window_border_color = green | |
1987 | # | |
1988 | #active_window_border = red | |
1989 | # | |
1990 | #+end_src | |
1991 | ||
1992 | *** bindings | |
1993 | :PROPERTIES: | |
1994 | :header-args+: :tangle ~/.ncmpcpp/bindings | |
1995 | :END: | |
1996 | ||
1997 | #+begin_src conf :tangle no | |
1998 | def_key "j" | |
1999 | scroll_down | |
2000 | def_key "k" | |
2001 | scroll_up | |
2002 | ||
2003 | def_key "ctrl-u" | |
2004 | page_up | |
2005 | def_key "ctrl-d" | |
2006 | page_down | |
2007 | ||
2008 | def_key "h" | |
2009 | previous_column | |
2010 | def_key "l" | |
2011 | next_column | |
2012 | ||
2013 | def_key "." | |
2014 | show_lyrics | |
2015 | ||
2016 | def_key "n" | |
2017 | next_found_item | |
2018 | def_key "N" | |
2019 | previous_found_item | |
2020 | ||
2021 | def_key "J" | |
2022 | move_sort_order_down | |
2023 | def_key "K" | |
2024 | move_sort_order_up | |
2025 | #+end_src | |
2026 | ||
b13e2dc1 AB |
2027 | * Scripts |
2028 | ||
2029 | This section contains various useful scripts and the ones used by the | |
2030 | programs above. For instance, =toggle-tablet= for switching to and | |
2031 | from tablet mode on my X220T, =toggle-presentation-mode= for toggling | |
2032 | Xfce's presentation mode which keeps the screen awake, and | |
2033 | =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 | |
2034 | exact brightness value. | |
2035 | ||
2036 | ** rofi-light | |
2037 | :PROPERTIES: | |
2038 | :header-args+: :tangle ~/.local/bin/rofi-light :shebang "#!/bin/bash" | |
2039 | :END: | |
2040 | ||
33c5a5cd | 2041 | #+begin_src bash |
b13e2dc1 AB |
2042 | cur=$(light -G) |
2043 | val=$(rofi -dmenu -mesg "light $cur" -p "light -S " -l 0 -width 8) | |
2044 | light -S $val | |
2045 | #+end_src | |
2046 | ||
2047 | ** toggle-layout | |
2048 | :PROPERTIES: | |
2049 | :header-args+: :tangle ~/.local/bin/toggle-layout :shebang "#!/bin/bash" | |
2050 | :END: | |
2051 | ||
33c5a5cd | 2052 | #+begin_src bash |
b13e2dc1 AB |
2053 | lang="$(setxkbmap -print | grep xkb_symbols | cut -d'+' -f 2)" |
2054 | ||
2055 | if [ "$lang" = "us" ]; then | |
2056 | setxkbmap ir | |
2057 | else | |
2058 | setxkbmap us | |
2059 | # xmodmap $HOME/.Xmodmap | |
2060 | fi | |
2061 | #+end_src | |
2062 | ||
2063 | ** toggle-presentation-mode | |
2064 | :PROPERTIES: | |
2065 | :header-args+: :tangle ~/.local/bin/toggle-presentation-mode :shebang "#!/bin/bash" | |
2066 | :END: | |
2067 | ||
33c5a5cd | 2068 | #+begin_src bash |
b13e2dc1 AB |
2069 | xfconf-query -c xfce4-power-manager -p /xfce4-power-manager/presentation-mode -T |
2070 | #+end_src | |
33c5a5cd AB |
2071 | |
2072 | ** Fun :) | |
2073 | ||
2074 | *** eat-em | |
2075 | :PROPERTIES: | |
2076 | :header-args+: :tangle ~/.local/bin/eat-em :shebang "#!/bin/sh" | |
2077 | :END: | |
2078 | ||
2079 | #+begin_src sh | |
2080 | # Original Posted at http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921 | |
2081 | # [ESC] character in original post removed here. | |
2082 | ||
2083 | # ANSI Color -- use these variables to easily have different color | |
2084 | # and format output. Make sure to output the reset sequence after | |
2085 | # colors (f = foreground, b = background), and use the 'off' | |
2086 | # feature for anything you turn on. | |
2087 | ||
2088 | initializeANSI() | |
2089 | { | |
2090 | esc="$(echo -en '\e')" | |
2091 | ||
2092 | blackf="${esc}[30m"; redf="${esc}[31m"; greenf="${esc}[32m" | |
2093 | yellowf="${esc}[33m" bluef="${esc}[34m"; purplef="${esc}[35m" | |
2094 | cyanf="${esc}[36m"; whitef="${esc}[37m" | |
2095 | ||
2096 | blackb="${esc}[40m"; redb="${esc}[41m"; greenb="${esc}[42m" | |
2097 | yellowb="${esc}[43m" blueb="${esc}[44m"; purpleb="${esc}[45m" | |
2098 | cyanb="${esc}[46m"; whiteb="${esc}[47m" | |
2099 | ||
2100 | boldon="${esc}[1m"; boldoff="${esc}[22m" | |
2101 | italicson="${esc}[3m"; italicsoff="${esc}[23m" | |
2102 | ulon="${esc}[4m"; uloff="${esc}[24m" | |
2103 | invon="${esc}[7m"; invoff="${esc}[27m" | |
2104 | ||
2105 | reset="${esc}[0m" | |
2106 | } | |
2107 | ||
2108 | # note in this first use that switching colors doesn't require a reset | |
2109 | # first - the new color overrides the old one. | |
2110 | ||
2111 | #clear | |
2112 | ||
2113 | initializeANSI | |
2114 | ||
2115 | cat << EOF | |
2116 | ||
2117 | ${yellowf} ▄███████▄${reset} ${redf} ▄██████▄${reset} ${greenf} ▄██████▄${reset} ${bluef} ▄██████▄${reset} ${purplef} ▄██████▄${reset} ${cyanf} ▄██████▄${reset} | |
2118 | ${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} | |
2119 | ${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} | |
2120 | ${yellowf}███████▄${reset} ${redf}████████████${reset} ${greenf}████████████${reset} ${bluef}████████████${reset} ${purplef}████████████${reset} ${cyanf}████████████${reset} | |
2121 | ${yellowf}▀█████████▄▄${reset} ${redf}██▀██▀▀██▀██${reset} ${greenf}██▀██▀▀██▀██${reset} ${bluef}██▀██▀▀██▀██${reset} ${purplef}██▀██▀▀██▀██${reset} ${cyanf}██▀██▀▀██▀██${reset} | |
2122 | ${yellowf} ▀███████▀${reset} ${redf}▀ ▀ ▀ ▀${reset} ${greenf}▀ ▀ ▀ ▀${reset} ${bluef}▀ ▀ ▀ ▀${reset} ${purplef}▀ ▀ ▀ ▀${reset} ${cyanf}▀ ▀ ▀ ▀${reset} | |
2123 | ||
2124 | ${boldon}${yellowf} ▄███████▄ ${redf} ▄██████▄ ${greenf} ▄██████▄ ${bluef} ▄██████▄ ${purplef} ▄██████▄ ${cyanf} ▄██████▄${reset} | |
2125 | ${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} | |
2126 | ${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} | |
2127 | ${boldon}${yellowf}███████▄ ${redf}████████████ ${greenf}████████████ ${bluef}████████████ ${purplef}████████████ ${cyanf}████████████${reset} | |
2128 | ${boldon}${yellowf}▀█████████▄▄ ${redf}██▀██▀▀██▀██ ${greenf}██▀██▀▀██▀██ ${bluef}██▀██▀▀██▀██ ${purplef}██▀██▀▀██▀██ ${cyanf}██▀██▀▀██▀██${reset} | |
2129 | ${boldon}${yellowf} ▀███████▀ ${redf}▀ ▀ ▀ ▀ ${greenf}▀ ▀ ▀ ▀ ${bluef}▀ ▀ ▀ ▀ ${purplef}▀ ▀ ▀ ▀ ${cyanf}▀ ▀ ▀ ▀${reset} | |
2130 | ||
2131 | EOF | |
2132 | #+end_src | |
2133 | ||
33c5a5cd AB |
2134 | *** invade-em |
2135 | :PROPERTIES: | |
2136 | :header-args+: :tangle ~/.local/bin/invade-em :shebang "#!/bin/bash" | |
2137 | :END: | |
2138 | ||
2139 | #+begin_src bash | |
2140 | # | |
2141 | # ANSI color scheme script featuring Space Invaders | |
2142 | # | |
2143 | # Original: http://crunchbang.org/forums/viewtopic.php?pid=126921%23p126921#p126921 | |
2144 | # Modified by lolilolicon | |
2145 | # | |
2146 | ||
2147 | f=3 b=4 | |
2148 | for j in f b; do | |
2149 | for i in {0..7}; do | |
2150 | printf -v $j$i %b "\e[${!j}${i}m" | |
2151 | done | |
2152 | done | |
2153 | bld=$'\e[1m' | |
2154 | rst=$'\e[0m' | |
2155 | ||
2156 | cat << EOF | |
2157 | ||
2158 | $f1 ▀▄ ▄▀ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4 ▀▄ ▄▀ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst | |
2159 | $f1 ▄█▀███▀█▄ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4 ▄█▀███▀█▄ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst | |
2160 | $f1█▀███████▀█ $f2▀▀███▀▀███▀▀ $f3▀█▀██▀█▀ $f4█▀███████▀█ $f5▀▀███▀▀███▀▀ $f6▀█▀██▀█▀$rst | |
2161 | $f1▀ ▀▄▄ ▄▄▀ ▀ $f2 ▀█▄ ▀▀ ▄█▀ $f3▀▄ ▄▀ $f4▀ ▀▄▄ ▄▄▀ ▀ $f5 ▀█▄ ▀▀ ▄█▀ $f6▀▄ ▄▀$rst | |
2162 | ||
2163 | $bld$f1▄ ▀▄ ▄▀ ▄ $f2 ▄▄▄████▄▄▄ $f3 ▄██▄ $f4▄ ▀▄ ▄▀ ▄ $f5 ▄▄▄████▄▄▄ $f6 ▄██▄ $rst | |
2164 | $bld$f1█▄█▀███▀█▄█ $f2███▀▀██▀▀███ $f3▄█▀██▀█▄ $f4█▄█▀███▀█▄█ $f5███▀▀██▀▀███ $f6▄█▀██▀█▄$rst | |
2165 | $bld$f1▀█████████▀ $f2▀▀▀██▀▀██▀▀▀ $f3▀▀█▀▀█▀▀ $f4▀█████████▀ $f5▀▀▀██▀▀██▀▀▀ $f6▀▀█▀▀█▀▀$rst | |
2166 | $bld$f1 ▄▀ ▀▄ $f2▄▄▀▀ ▀▀ ▀▀▄▄ $f3▄▀▄▀▀▄▀▄ $f4 ▄▀ ▀▄ $f5▄▄▀▀ ▀▀ ▀▀▄▄ $f6▄▀▄▀▀▄▀▄$rst | |
2167 | ||
2168 | ||
2169 | $f7▌$rst | |
2170 | ||
2171 | $f7▌$rst | |
2172 | ||
2173 | $f7 ▄█▄ $rst | |
2174 | $f7▄█████████▄$rst | |
2175 | $f7▀▀▀▀▀▀▀▀▀▀▀$rst | |
2176 | ||
2177 | EOF | |
2178 | #+end_src |