| 1 | #+title: rc.org |
| 2 | #+property: header-args :comments link :mkdirp yes :results silent |
| 3 | |
| 4 | * About |
| 5 | |
| 6 | This org file contains the configuration files of pretty much every |
| 7 | program I use. The files are tangled (i.e. exported, or derived) from |
| 8 | this file using =org-babel=. |
| 9 | |
| 10 | Note: This file is best viewed inside Emacs with org mode. |
| 11 | |
| 12 | * Configs |
| 13 | |
| 14 | This section contains the configuration files (dotfiles) of various |
| 15 | programs I use. |
| 16 | |
| 17 | ** [[https://github.com/afewmail/afew][afew]] |
| 18 | :PROPERTIES: |
| 19 | :header-args+: :tangle ~/.config/afew/config |
| 20 | :END: |
| 21 | |
| 22 | #+begin_quote |
| 23 | an initial tagging script for notmuch mail |
| 24 | #+end_quote |
| 25 | |
| 26 | #+begin_src conf |
| 27 | # This is the default filter chain |
| 28 | [SpamFilter] |
| 29 | #[ClassifyingFilter] |
| 30 | [KillThreadsFilter] |
| 31 | #[ListMailsFilter] |
| 32 | [ArchiveSentMailsFilter] |
| 33 | sent_tag = sent |
| 34 | [InboxFilter] |
| 35 | |
| 36 | #[Filter.1] |
| 37 | #query = 'folder:amin/lists/.haskell-cafe' |
| 38 | #tags = +lists;+lists/haskell-cafe |
| 39 | #message = lists/haskell-cafe |
| 40 | |
| 41 | #[Filter.2] |
| 42 | #query = 'folder:amin/lists/.haskell-weekly' |
| 43 | #tags = +lists;+lists/haskell-weekly |
| 44 | #message = lists/haskell-weekly |
| 45 | |
| 46 | #[Filter.3] |
| 47 | #query = 'folder:amin/lists/.hackernewsletter' |
| 48 | #tags = +lists;+lists/hackernewsletter |
| 49 | #message = lists/hackernewsletter |
| 50 | |
| 51 | |
| 52 | #[FolderNameFilter] |
| 53 | #folder_blacklist = Inbox |
| 54 | #maildir_separator = /. |
| 55 | #folder_transforms = Drafts:draft Junk:spam Trash:deleted Sent:sent Archive:archive lists/haskell-cafe:lists/haskell-cafe |
| 56 | #+end_src |
| 57 | |
| 58 | ** bspwm |
| 59 | |
| 60 | *** bspwmrc |
| 61 | :PROPERTIES: |
| 62 | :header-args+: :tangle ~/.config/bspwm/bspwmrc :shebang "#!/bin/sh" |
| 63 | :END: |
| 64 | |
| 65 | #+begin_src sh |
| 66 | sxhkd & |
| 67 | sh ~/.fehbg & |
| 68 | xfce4-panel -d & |
| 69 | #compton & |
| 70 | sleep 0.5 && pasystray --notify=all & |
| 71 | |
| 72 | bspc monitor -d I II III IV V VI VII VIII IX X |
| 73 | #bspc monitor eDP-1 -d I II III IV V |
| 74 | #bspc monitor HDMI-1 -d VI VII VIII IX X |
| 75 | |
| 76 | #bspc config border_width 2 |
| 77 | #bspc config window_gap 8 |
| 78 | bspc config window_gap 0 |
| 79 | |
| 80 | bspc config bottom_padding 26 |
| 81 | |
| 82 | bspc config split_ratio 0.52 |
| 83 | bspc config borderless_monocle true |
| 84 | bspc config gapless_monocle true |
| 85 | bspc config click_to_focus button1 |
| 86 | bspc config directional_focus_tightness low |
| 87 | |
| 88 | bspc rule -a Firefox desktop='^1' follow=on |
| 89 | bspc rule -a Nightly desktop='^1' follow=on |
| 90 | bspc rule -a Emacs desktop='^2' state=tiled follow=on |
| 91 | #bspc rule -a Chromium desktop='^4' follow=on |
| 92 | bspc rule -a URxvt state=floating |
| 93 | bspc rule -a URxvt:tiled state=tiled |
| 94 | bspc rule -a Connman-gtk state=floating |
| 95 | bspc rule -a Xfce4-panel state=floating |
| 96 | bspc rule -a TelegramDesktop state=floating |
| 97 | bspc rule -a Ec state=floating |
| 98 | bspc rule -a Pavucontrol state=floating |
| 99 | bspc rule -a Eog state=floating |
| 100 | bspc rule -a Seahorse state=floating |
| 101 | bspc rule -a mpv state=floating |
| 102 | bspc rule -a Evince state=floating |
| 103 | bspc rule -a Meld state=floating |
| 104 | bspc rule -a Autokey-gtk state=floating |
| 105 | bspc rule -a Mousepad state=floating |
| 106 | bspc rule -a Wrapper-1.0 state=floating |
| 107 | bspc rule -a File-roller state=floating |
| 108 | bspc rule -a Gnome-disks state=floating |
| 109 | bspc rule -a Termite state=floating |
| 110 | bspc rule -a Termite:tiled state=tiled |
| 111 | bspc rule -a Thunderbird:Calendar state=floating |
| 112 | bspc rule -a Audacity state=floating |
| 113 | bspc rule -a Proof state=floating # pvs x-show-proof |
| 114 | bspc rule -a Nm-connection-editor state=floating |
| 115 | bspc rule -a Wire state=floating |
| 116 | bspc rule -a discord state=floating |
| 117 | bspc rule -a X2goclient state=floating |
| 118 | bspc rule -a SimpleScreenRecorder state=floating |
| 119 | bspc rule -a Gimp state=floating |
| 120 | bspc rule -a Wrapper-2.0 state=floating |
| 121 | bspc rule -a Zathura state=tiled |
| 122 | #+end_src |
| 123 | |
| 124 | *** sxhkdrc |
| 125 | :PROPERTIES: |
| 126 | :header-args+: :tangle ~/.config/sxhkd/sxhkdrc |
| 127 | :END: |
| 128 | |
| 129 | #+begin_src conf |
| 130 | # |
| 131 | # wm independent hotkeys |
| 132 | # |
| 133 | |
| 134 | # terminal emulator |
| 135 | super + {_,shift} + Return |
| 136 | urxvt{_, -name tiled} |
| 137 | |
| 138 | #super + {_,shift} + Return |
| 139 | # termite{_, --name=tiled} |
| 140 | |
| 141 | # program launcher |
| 142 | super + space |
| 143 | rofi -show run -display-run '> ' -display-window ' 🗔 ' |
| 144 | |
| 145 | super + alt + space |
| 146 | xfce4-popup-whiskermenu |
| 147 | |
| 148 | # window finder |
| 149 | super + backslash |
| 150 | rofi -show window -display-run '> ' -display-window ' 🗔 ' |
| 151 | |
| 152 | # password manager |
| 153 | alt + space |
| 154 | rofi-pass |
| 155 | |
| 156 | # firefox |
| 157 | #super + r |
| 158 | # firefox |
| 159 | |
| 160 | # chromium |
| 161 | #super + c |
| 162 | # chromium -incognito |
| 163 | |
| 164 | # emacs |
| 165 | super + e |
| 166 | emacs |
| 167 | |
| 168 | # make sxhkd reload its configuration files: |
| 169 | super + Escape |
| 170 | pkill -USR1 -x sxhkd |
| 171 | |
| 172 | # volume {up,down} |
| 173 | XF86Audio{Raise,Lower}Volume |
| 174 | pamixer --allow-boost --{in,de}crease 5 |
| 175 | |
| 176 | # mute |
| 177 | XF86AudioMute |
| 178 | pamixer --toggle-mute |
| 179 | |
| 180 | # playback control |
| 181 | XF86Audio{Play,Prev,Next} |
| 182 | mpc {toggle,prev,next} |
| 183 | |
| 184 | # lock the screen |
| 185 | super + shift + q |
| 186 | light-locker-command -l |
| 187 | |
| 188 | # Toggle keyboard layout |
| 189 | super + F7 |
| 190 | toggle-layout |
| 191 | |
| 192 | # Toggle Xfce presentation mode |
| 193 | XF86LaunchB |
| 194 | toggle-presentation-mode |
| 195 | |
| 196 | # monitor brightness |
| 197 | XF86MonBrightness{Up,Down} |
| 198 | light -{A,U} 5 |
| 199 | |
| 200 | super + apostrophe |
| 201 | rofi-light |
| 202 | |
| 203 | # keyboard brightness |
| 204 | #XF86KbdBrightness{Up,Down} |
| 205 | # kbdlight {up,down} |
| 206 | |
| 207 | # |
| 208 | # bspwm hotkeys |
| 209 | # |
| 210 | |
| 211 | # quit bspwm normally |
| 212 | super + alt + Escape |
| 213 | bspc quit |
| 214 | |
| 215 | # close and kill |
| 216 | super + {w,q} |
| 217 | bspc node -{c,k} |
| 218 | |
| 219 | # alternate between the tiled and monocle layout |
| 220 | super + m |
| 221 | bspc desktop -l next |
| 222 | |
| 223 | # send the newest marked node to the newest preselected node |
| 224 | super + y |
| 225 | bspc node newest.marked.local -n newest.!automatic.local |
| 226 | |
| 227 | # swap the current node and the biggest node |
| 228 | super + g |
| 229 | bspc node -s biggest |
| 230 | |
| 231 | # |
| 232 | # state/flags |
| 233 | # |
| 234 | |
| 235 | # set the window state |
| 236 | super + {t,shift + t,s,f} |
| 237 | bspc node -t {tiled,pseudo_tiled,floating,fullscreen} |
| 238 | |
| 239 | # set the node flags |
| 240 | super + ctrl + {m,x,y,z} |
| 241 | bspc node -g {marked,locked,sticky,private} |
| 242 | |
| 243 | # |
| 244 | # focus/swap |
| 245 | # |
| 246 | |
| 247 | # focus the node in the given direction |
| 248 | super + {_,shift + }{h,j,k,l} |
| 249 | bspc node -{f,s} {west,south,north,east} |
| 250 | |
| 251 | # focus the node for the given path jump |
| 252 | super + {p,b,comma,period} |
| 253 | bspc node -f @{parent,brother,first,second} |
| 254 | |
| 255 | # focus the next/previous node in the current desktop |
| 256 | super + {_,shift + }c |
| 257 | bspc node -f {next,prev}.local |
| 258 | |
| 259 | # focus the next/previous desktop in the current monitor |
| 260 | super + bracket{left,right} |
| 261 | bspc desktop -f {prev,next}.local |
| 262 | |
| 263 | # send to next/prev desktop |
| 264 | super + shift + bracket{left,right} |
| 265 | bspc node -d {prev,next} --follow |
| 266 | |
| 267 | # focus the last node/desktop |
| 268 | super + {grave,Tab} |
| 269 | bspc {node,desktop} -f last |
| 270 | |
| 271 | # focus the older or newer node in the focus history |
| 272 | super + {o,i} |
| 273 | bspc wm -h off; \ |
| 274 | bspc node {older,newer} -f; \ |
| 275 | bspc wm -h on |
| 276 | |
| 277 | # focus or send to the given desktop |
| 278 | super + {_,shift + }{1-9,0} |
| 279 | bspc {desktop -f,node -d} '^{1-9,10}' |
| 280 | |
| 281 | # |
| 282 | # preselect |
| 283 | # |
| 284 | |
| 285 | # preselect the direction |
| 286 | super + ctrl + {h,j,k,l} |
| 287 | bspc node -p {west,south,north,east} |
| 288 | |
| 289 | # preselect the ratio |
| 290 | super + ctrl + {1-9} |
| 291 | bspc node -o 0.{1-9} |
| 292 | |
| 293 | # cancel the preselection for the focused node |
| 294 | super + ctrl + space |
| 295 | bspc node -p cancel |
| 296 | |
| 297 | # cancel the preselection for the focused desktop |
| 298 | super + ctrl + shift + space |
| 299 | bspc query -N -d | xargs -I id -n 1 bspc node id -p cancel |
| 300 | |
| 301 | # |
| 302 | # move/resize |
| 303 | # |
| 304 | |
| 305 | # expand a window by moving one of its side outward |
| 306 | super + alt + {h,j,k,l} |
| 307 | bspc node -z {left -20 0,bottom 0 20,top 0 -20,right 20 0} |
| 308 | |
| 309 | # contract a window by moving one of its side inward |
| 310 | super + alt + shift + {h,j,k,l} |
| 311 | bspc node -z {right -20 0,top 0 20,bottom 0 -20,left 20 0} |
| 312 | |
| 313 | # move a floating window |
| 314 | super + {Left,Down,Up,Right} |
| 315 | bspc node -v {-20 0,0 20,0 -20,20 0} |
| 316 | |
| 317 | #alt + bracket{left,right} |
| 318 | # xdotool key --clearmodifiers ctrl+Page_{Up,Down} |
| 319 | #+end_src |
| 320 | |
| 321 | ** compton |
| 322 | :PROPERTIES: |
| 323 | :header-args+: :tangle ~/.config/compton.conf |
| 324 | :END: |
| 325 | |
| 326 | #+begin_src conf |
| 327 | # Shadow |
| 328 | shadow = false; # Enabled client-side shadows on windows. |
| 329 | no-dock-shadow = true; # Avoid drawing shadows on dock/panel windows. |
| 330 | no-dnd-shadow = true; # Don't draw shadows on DND windows. |
| 331 | clear-shadow = true; # Zero the part of the shadow's mask behind the |
| 332 | # window. Fix some weirdness with ARGB windows. |
| 333 | shadow-radius = 5; # The blur radius for shadows. (default 12) |
| 334 | shadow-offset-x = -5; # The left offset for shadows. (default -15) |
| 335 | shadow-offset-y = -5; # The top offset for shadows. (default -15) |
| 336 | # shadow-opacity = 0.7; # The translucency for shadows. (default .75) |
| 337 | # shadow-red = 0.0; # Red color value of shadow. (0.0 - 1.0, defaults to 0) |
| 338 | # shadow-green = 0.0; # Green color value of shadow. (0.0 - 1.0, defaults to 0) |
| 339 | # shadow-blue = 0.0; # Blue color value of shadow. (0.0 - 1.0, defaults to 0) |
| 340 | shadow-exclude = [ "n:e:Notification", "class_g = 'Chromium'", "class_g = 'Dmenu'", "class_g = 'Firefox' && argb" ]; # Exclude conditions for shadows. |
| 341 | # shadow-exclude = "n:e:Notification"; |
| 342 | #shadow-exclude = [ "_GTK_FRAME_EXTENTS@:c" ] # Fix dual shadow on some gtk3 powered applications |
| 343 | shadow-ignore-shaped = true; # Avoid drawing shadow on all shaped windows |
| 344 | # (see also: --detect-rounded-corners) |
| 345 | |
| 346 | # Opacity |
| 347 | menu-opacity = 1.0; # The opacity for menus. (default 1.0) |
| 348 | #inactive-opacity = 0.9; # Default opacity of inactive windows. (0.0 - 1.0) |
| 349 | # active-opacity = 0.8; # Default opacity for active windows. (0.0 - 1.0) |
| 350 | frame-opacity = 1.0; # Opacity of window titlebars and borders. (0.1 - 1.0) |
| 351 | # inactive-opacity-override = true; # Let inactive opacity set by 'inactive-opacity' overrides |
| 352 | # value of _NET_WM_OPACITY. Bad choice. |
| 353 | alpha-step = 0.06; # XRender backend: Step size for alpha pictures. Increasing |
| 354 | # it may result in less X resource usage, |
| 355 | # Yet fading may look bad. |
| 356 | #inactive-dim = 0.5; # Dim inactive windows. (0.0 - 1.0) |
| 357 | #inactive-dim-fixed = true; # Do not let dimness adjust based on window opacity. |
| 358 | # blur-background = true; # Blur background of transparent windows. |
| 359 | # Bad performance with X Render backend. |
| 360 | # GLX backend is preferred. |
| 361 | # blur-background-frame = true; # Blur background of opaque windows with transparent |
| 362 | # frames as well. |
| 363 | blur-background-fixed = true; # Do not let blur radius adjust based on window opacity. |
| 364 | blur-background-exclude = [ "window_type = 'dock'", "window_type = 'desktop'" ]; |
| 365 | # Exclude conditions for background blur. |
| 366 | |
| 367 | # Fading |
| 368 | fading = false; # Fade windows during opacity changes. |
| 369 | fade-delta = 3; # The time between steps in a fade in milliseconds. (default 10). |
| 370 | fade-in-step = 0.03; # Opacity change between steps while fading in. (default 0.028). |
| 371 | fade-out-step = 0.03; # Opacity change between steps while fading out. (default 0.03). |
| 372 | # no-fading-openclose = true; # Avoid fade windows in/out when opening/closing. |
| 373 | fade-exclude = [ ]; # Exclude conditions for fading. |
| 374 | |
| 375 | # Other |
| 376 | backend = "glx" # Backend to use: "xrender" or "glx". GLX backend is typically |
| 377 | # much faster but depends on a sane driver. |
| 378 | mark-wmwin-focused = true; # Try to detect WM windows and mark them as active. |
| 379 | mark-ovredir-focused = true; # Mark all non-WM but override-redirect windows active (e.g. menus). |
| 380 | use-ewmh-active-win = true; # Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused |
| 381 | # instead of using FocusIn/Out events. Usually more reliable but |
| 382 | # depends on a EWMH-compliant WM. |
| 383 | detect-rounded-corners = false; # Detect rounded corners and treat them as rectangular when --shadow-ignore- shaped is on. |
| 384 | detect-client-opacity = true; # Detect _NET_WM_OPACITY on client windows, useful for window |
| 385 | # managers not passing _NET_WM_OPACITY of client windows to frame |
| 386 | # windows. |
| 387 | refresh-rate = 0; # For --sw-opti: Specify refresh rate of the screen. 0 for auto. |
| 388 | vsync = "drm"; # "none", "drm", "opengl", "opengl-oml", "opengl-swc", "opengl-mswc" |
| 389 | # See man page for more details. |
| 390 | dbe = false; # Enable DBE painting mode. Rarely needed. |
| 391 | paint-on-overlay = true; # Painting on X Composite overlay window. Recommended. |
| 392 | sw-opti = false; # Limit compton to repaint at most once every 1 / refresh_rate. |
| 393 | # Incompatible with certain VSync methods. |
| 394 | unredir-if-possible = false; # Unredirect all windows if a full-screen opaque window is |
| 395 | # detected, to maximize performance for full-screen windows. |
| 396 | focus-exclude = [ ]; # A list of conditions of windows that should always be considered |
| 397 | # focused. |
| 398 | detect-transient = true; # Use WM_TRANSIENT_FOR to group windows, and consider windows in |
| 399 | # the same group focused at the same time. |
| 400 | detect-client-leader = true; # Use WM_CLIENT_LEADER to group windows. |
| 401 | invert-color-include = [ ]; # Conditions for windows to be painted with inverted color. |
| 402 | |
| 403 | # GLX backend # GLX backend fine-tune options. See man page for more info. |
| 404 | glx-no-stencil = true; # Recommended. |
| 405 | glx-copy-from-front = false; # Useful with --glx-swap-method, |
| 406 | # glx-use-copysubbuffermesa = true; # Recommended if it works. Breaks VSync. |
| 407 | # glx-no-rebind-pixmap = true; # Recommended if it works. |
| 408 | glx-no-rebind-pixmap = true; # Recommended if it works. |
| 409 | #glx-swap-method = "4"; # See man page. |
| 410 | glx-swap-method = "4"; # See man page. |
| 411 | |
| 412 | # Window type settings |
| 413 | wintypes: |
| 414 | { |
| 415 | tooltip = { fade = true; shadow = false; opacity = 1; focus = true; }; |
| 416 | menu = { shadow = false; }; |
| 417 | dropdown_menu = { shadow = false; }; |
| 418 | popup_menu = { shadow = false; }; |
| 419 | utility = { shadow = false; }; |
| 420 | # fade: Fade the particular type of windows. |
| 421 | # shadow: Give those windows shadow |
| 422 | # opacity: Default opacity for the type of windows. |
| 423 | # focus: Whether to always consider windows of this type focused. |
| 424 | }; |
| 425 | #+end_src |
| 426 | |
| 427 | ** Dunst |
| 428 | :PROPERTIES: |
| 429 | :header-args+: :tangle ~/.config/dunst/dunstrc |
| 430 | :END: |
| 431 | |
| 432 | #+begin_src conf |
| 433 | [global] |
| 434 | #font = Ubuntu Mono 10.5 |
| 435 | font = Inconsolata 11 |
| 436 | |
| 437 | # Path to default icons. |
| 438 | icon_folders = /usr/share/icons/Moka/16x16/status/:/usr/share/icons/Moka/16x16/devices/:/usr/share/icons/Faba-Mono/16x16/status/:/usr/share/icons/Faba-Mono/16x16/devices/:/usr/share/icons/Moka/16x16/actions/:/usr/share/icons/Moka/16x16/categories/:/usr/share/icons/Moka/16x16/mimetypes/:/usr/share/icons/Moka/16x16/apps/:/usr/share/icons/Moka/16x16/places/:/usr/share/icons/Paper/16x16/status/ |
| 439 | |
| 440 | icon_position = left |
| 441 | # <b>bold</b> |
| 442 | # <i>italic</i> |
| 443 | # <s>strikethrough<s/> |
| 444 | # <u>underline</u> |
| 445 | markup = full |
| 446 | # The format of the message. Possible variables are: |
| 447 | # %a appname |
| 448 | # %s summary |
| 449 | # %b body |
| 450 | # %i iconname (including its path) |
| 451 | # %I iconname (without its path) |
| 452 | # %p progress value if set ([ 0%] to [100%]) or nothing |
| 453 | # Markup is allowed |
| 454 | format = "<b>%s</b>\n%b" |
| 455 | # Sort messages by urgency |
| 456 | sort = yes |
| 457 | # Show how many messages are currently hidden (because of geometry) |
| 458 | indicate_hiddenl= no |
| 459 | # Alignment of message text. |
| 460 | # Possible values are "left", "center" and "right" |
| 461 | alignment = center |
| 462 | # The frequency with wich text that is longer than the notification |
| 463 | # window allows bounces back and forth. |
| 464 | # This option conflicts with 'word_wrap'. |
| 465 | # Set to 0 to disable |
| 466 | bounce_freq = 3 |
| 467 | # show age of message if message is older than show_age_threshold seconds. |
| 468 | # set to -1 to disable |
| 469 | show_age_threshold = -1 |
| 470 | # split notifications into multiple lines if they don't fit into geometry |
| 471 | word_wrap = yes |
| 472 | # ignore newlines '\n' in notifications |
| 473 | ignore_newline = no |
| 474 | # The geometry of the message window. |
| 475 | # geometry [{width}]x{height}][+/-{x}+/-{y}] |
| 476 | # The height is measured in number of notifications everything else in pixels. If the width |
| 477 | # is omitted but the height is given ("-geometry x2"), the message window |
| 478 | # expands over the whole screen (dmenu-like). If width is 0, |
| 479 | # the window expands to the longest message displayed. |
| 480 | # A positive x is measured from the left, a negative from the |
| 481 | # right side of the screen. Y is measured from the top and down respectevly. |
| 482 | # The width can be negative. In this case the actual width is the |
| 483 | # screen width minus the width defined in within the geometry option. |
| 484 | #geometry = "410x12-12+12" |
| 485 | #geometry = "0x0-30-30" |
| 486 | geometry = "260x12-30-30" |
| 487 | # The transparency of the window. range: [0; 100] |
| 488 | # This option will only work if a compositing windowmanager is present (e.g. xcompmgr, compiz, etc..) |
| 489 | transparency = 0 |
| 490 | # Don't remove messages, if the user is idle (no mouse or keyboard input) |
| 491 | # for longer than idle_threshold seconds. |
| 492 | # Set to 0 to disable. |
| 493 | idle_threshold = 120 |
| 494 | # Which monitor should the notifications be displayed on. |
| 495 | monitor = 0 |
| 496 | # Display notification on focused monitor. Possible modes are: |
| 497 | # mouse: follow mouse pointer |
| 498 | # keyboard: follow window with keyboard focus |
| 499 | # none: don't follow anything |
| 500 | # |
| 501 | # "keyboard" needs a windowmanager that exports the _NET_ACTIVE_WINDOW property. |
| 502 | # This should be the case for almost all modern windowmanagers. |
| 503 | # |
| 504 | # If this option is set to mouse or keyboard, the monitor option will be |
| 505 | # ignored. |
| 506 | follow = keyboard |
| 507 | # should a notification popped up from history be sticky or |
| 508 | # timeout as if it would normally do. |
| 509 | sticky_history = yes |
| 510 | # The height of a single line. If the height is smaller than the font height, |
| 511 | # it will get raised to the font height. |
| 512 | # This adds empty space above and under the text. |
| 513 | line_height = 0 |
| 514 | |
| 515 | show_indicators = yes |
| 516 | |
| 517 | # Draw a line of 'separatpr_height' pixel height between two notifications. |
| 518 | # Set to 0 to disable |
| 519 | separator_height = 3 |
| 520 | # padding between text and separator |
| 521 | padding = 8 |
| 522 | # horizontal padding |
| 523 | horizontal_padding = 8 |
| 524 | # Define a color for the separator. |
| 525 | # possible values are: |
| 526 | # * auto: dunst tries to find a color fitting to the background |
| 527 | # * foreground: use the same color as the foreground |
| 528 | # * frame: use the same color as the frame. |
| 529 | # * anything else will be interpreted as a X color |
| 530 | separator_color = foreground |
| 531 | # print a notification on startup |
| 532 | # This is mainly for error detection, since dbus (re-)starts dunst |
| 533 | # automatically after a crash. |
| 534 | startup_notification = false |
| 535 | # dmenu path |
| 536 | #dmenu = /usr/bin/dmenu -p dunst: |
| 537 | dmenu = /usr/bin/rofi -dmenu -p dunst: |
| 538 | # browser for opening urls in context menu |
| 539 | browser = /usr/bin/firefox -new-tab |
| 540 | [frame] |
| 541 | width = 0 |
| 542 | color = "#377222" |
| 543 | [shortcuts] |
| 544 | # shortcuts are specified as [modifier+][modifier+]...key |
| 545 | # available modifiers are 'ctrl', 'mod1' (the alt-key), 'mod2', 'mod3' |
| 546 | # and 'mod4' (windows-key) |
| 547 | # xev might be helpful to find names for keys |
| 548 | # close notification |
| 549 | close = ctrl+space |
| 550 | # close all notifications |
| 551 | close_all = ctrl+shift+space |
| 552 | # redisplay last message(s) |
| 553 | # On the US keyboard layout 'grave' is normally above TAB and left of '1'. |
| 554 | history = ctrl+shift+h |
| 555 | # context menu |
| 556 | context = ctrl+shift+period |
| 557 | [urgency_low] |
| 558 | # IMPORTANT: colors have to be defined in quotation marks. |
| 559 | # Otherwise the '#' and following would be interpreted as a comment. |
| 560 | background = "#1d2a30" |
| 561 | foreground = "#71c2af" |
| 562 | timeout = 3 |
| 563 | [urgency_normal] |
| 564 | background = "#1d2a30" |
| 565 | foreground = "#71c2af" |
| 566 | timeout = 0 |
| 567 | [urgency_critical] |
| 568 | background = "#1d2a30" |
| 569 | foreground = "#ff9982" |
| 570 | timeout = 0 |
| 571 | |
| 572 | # Every section that isn't one of the above is interpreted as a rules |
| 573 | # to override settings for certain messages. |
| 574 | # Messages can be matched by 'appname', 'summary', 'body' or 'icon' |
| 575 | # and you can override the 'timeout', 'urgency', 'foreground', 'background' |
| 576 | # and 'format'. |
| 577 | # Shell-like globbing will get expanded. |
| 578 | # |
| 579 | # SCRIPTING |
| 580 | # you can specify a script that gets run when the rule matches by setting |
| 581 | # the 'script' option. |
| 582 | # The script will be called as follows: |
| 583 | # script appname summary body icon urgency |
| 584 | # where urgency can be "LOW", "NORMAL" or "CRITICAL". |
| 585 | # |
| 586 | # NOTE: if you don't want a notification to be displayed, set the format to "" |
| 587 | # NOTE: It might be helpful to run dunst -print in a terminal in order to find |
| 588 | # fitting options for rules. |
| 589 | #[espeak] |
| 590 | # summary = "*" |
| 591 | # script = dunst_espeak.sh |
| 592 | #[script-test] |
| 593 | # summary = "*script*" |
| 594 | # script = dunst_test.sh |
| 595 | #[ignore] |
| 596 | ## This notification will not be displayed |
| 597 | # summary = "foobar" |
| 598 | # format = "" |
| 599 | #[signed_on] |
| 600 | # appname = Pidgin |
| 601 | # summary = "*signed on*" |
| 602 | # urgency = low |
| 603 | # |
| 604 | #[signed_off] |
| 605 | # appname = Pidgin |
| 606 | # summary = *signed off* |
| 607 | # urgency = low |
| 608 | # |
| 609 | #[says] |
| 610 | # appname = Pidgin |
| 611 | # summary = *says* |
| 612 | # urgency = critical |
| 613 | # |
| 614 | #[twitter] |
| 615 | # appname = Pidgin |
| 616 | # summary = *twitter.com* |
| 617 | # urgency = normal |
| 618 | # |
| 619 | [xfpm-backlight] |
| 620 | summary = *Brightness* |
| 621 | urgency = low |
| 622 | #+end_src |
| 623 | |
| 624 | ** Fontconfig |
| 625 | :PROPERTIES: |
| 626 | :header-args+: :tangle ~/.config/fontconfig/fonts.conf |
| 627 | :END: |
| 628 | |
| 629 | #+begin_src xml |
| 630 | <?xml version="1.0"?> |
| 631 | <!DOCTYPE fontconfig SYSTEM "fonts.dtd"> |
| 632 | <fontconfig> |
| 633 | <match target="font"> |
| 634 | <edit mode="assign" name="rgba"> |
| 635 | <const>rgb</const> |
| 636 | </edit> |
| 637 | </match> |
| 638 | <match target="font"> |
| 639 | <edit mode="assign" name="hinting"> |
| 640 | <bool>true</bool> |
| 641 | </edit> |
| 642 | </match> |
| 643 | <match target="font"> |
| 644 | <edit mode="assign" name="hintstyle"> |
| 645 | <const>hintslight</const> |
| 646 | </edit> |
| 647 | </match> |
| 648 | <match target="font"> |
| 649 | <edit mode="assign" name="antialias"> |
| 650 | <bool>true</bool> |
| 651 | </edit> |
| 652 | </match> |
| 653 | <match target="font"> |
| 654 | <edit mode="assign" name="lcdfilter"> |
| 655 | <const>lcddefault</const> |
| 656 | </edit> |
| 657 | </match> |
| 658 | <dir>~/.fonts</dir> |
| 659 | |
| 660 | <!-- Use Liberation Sans for Helvetica (instead of Nimbus Sans) --> |
| 661 | <alias binding="same"> |
| 662 | <family>Helvetica</family> |
| 663 | <accept> |
| 664 | <family>Liberation Sans</family> |
| 665 | </accept> |
| 666 | </alias> |
| 667 | </fontconfig> |
| 668 | #+end_src |
| 669 | |
| 670 | ** Git |
| 671 | |
| 672 | *** gitconfig |
| 673 | :PROPERTIES: |
| 674 | :header-args+: :tangle ~/.gitconfig |
| 675 | :END: |
| 676 | |
| 677 | **** user |
| 678 | #+begin_src conf |
| 679 | [user] |
| 680 | name = Amin Bandali |
| 681 | email = amin@aminb.org |
| 682 | # signingkey = 4E05246AB0BF7FFB |
| 683 | #+end_src |
| 684 | |
| 685 | **** signing |
| 686 | #+begin_src conf |
| 687 | # [commit] |
| 688 | # gpgsign = true |
| 689 | # [format] |
| 690 | # signoff = true |
| 691 | #+end_src |
| 692 | |
| 693 | **** core |
| 694 | #+begin_src conf |
| 695 | [core] |
| 696 | autocrlf = input # CRLF -> LF on commit |
| 697 | editor = emacsclient -t |
| 698 | excludesfile = ~/.gitignore_global |
| 699 | pager = "less" |
| 700 | #+end_src |
| 701 | |
| 702 | **** gpg |
| 703 | #+begin_src conf |
| 704 | [gpg] |
| 705 | program = gpg2 |
| 706 | #+end_src |
| 707 | |
| 708 | **** alias |
| 709 | #+begin_src conf |
| 710 | [alias] |
| 711 | git = !exec git # handle nested git calls, e.g. git git status |
| 712 | aliases = config --get-regexp '^alias\\.' |
| 713 | a = add |
| 714 | s = status |
| 715 | sl = status --long |
| 716 | c = checkout |
| 717 | cb = checkout -b |
| 718 | b = branch |
| 719 | r = rebase |
| 720 | p = pull |
| 721 | pr = pull --rebase |
| 722 | ps = push |
| 723 | psf = push --force |
| 724 | #+end_src |
| 725 | |
| 726 | **** color |
| 727 | #+begin_src conf |
| 728 | [color] |
| 729 | ui = auto |
| 730 | [color "status"] |
| 731 | added = green bold |
| 732 | changed = red bold |
| 733 | untracked = red bold |
| 734 | [color "branch"] |
| 735 | current = green bold |
| 736 | remote = magenta bold |
| 737 | [color "diff"] |
| 738 | new = green bold |
| 739 | old = red bold |
| 740 | #+end_src |
| 741 | |
| 742 | **** status |
| 743 | #+begin_src conf |
| 744 | [status] |
| 745 | # showUntrackedFiles = all |
| 746 | short=true |
| 747 | branch=true |
| 748 | #+end_src |
| 749 | |
| 750 | **** github |
| 751 | #+begin_src conf |
| 752 | [github] |
| 753 | user = aminb |
| 754 | #+end_src |
| 755 | |
| 756 | *** gitignore |
| 757 | :PROPERTIES: |
| 758 | :header-args+: :tangle ~/.gitignore_global |
| 759 | :END: |
| 760 | |
| 761 | #+begin_src conf |
| 762 | *.orig |
| 763 | *.py[co] |
| 764 | *.sublime-workspace |
| 765 | *~ |
| 766 | .DS_Store |
| 767 | *.elc |
| 768 | *-autoloads.el |
| 769 | #+end_src |
| 770 | |
| 771 | ** Latexmk |
| 772 | :PROPERTIES: |
| 773 | :header-args+: :tangle ~/.latexmkrc |
| 774 | :END: |
| 775 | |
| 776 | #+begin_src conf |
| 777 | $pdf_previewer = "start zathura %O %S"; |
| 778 | $clean_ext = "aux out"; |
| 779 | |
| 780 | # $pdf_update_method = 4; |
| 781 | # $pdf_update_command = "zathura %O %S"; |
| 782 | |
| 783 | # Synctex allows one to jump to from the PDF in Zathura to the source in Emacs |
| 784 | # by Ctrl+click in the PDF. |
| 785 | # Tell latexmk to use Zathura as a previewer, and run emacsclient as the Synctex |
| 786 | # editor. |
| 787 | # $pdf_previewer = 'exec zathura --synctex-forward -x \'emacsclient --no-wait +%{line} %{input}\' %O %S'; |
| 788 | #+end_src |
| 789 | |
| 790 | ** 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 | |
| 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 |
| 932 | User abandali |
| 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 | |
| 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 | |
| 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 | |
| 2041 | #+begin_src bash |
| 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 | |
| 2052 | #+begin_src bash |
| 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 | |
| 2068 | #+begin_src bash |
| 2069 | xfconf-query -c xfce4-power-manager -p /xfce4-power-manager/presentation-mode -T |
| 2070 | #+end_src |
| 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 | |
| 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 |