Go to file
Pierre Neidhardt f3c48de930 scripts/blind-append: Remove this stupid script 2016-10-10 17:50:32 +05:30
.asy Replace TikZ samples for Asymptote samples 2015-01-08 12:07:57 +01:00
.cmus cmus: Add disc number to playlist display 2016-01-27 18:55:01 +11:00
.config Awesome: Remove spurious 'client.restore' binding 2016-10-05 10:21:16 +05:30
.emacs.d Emacs: Add a 'go-set-compiler' command 2016-10-08 19:40:30 +05:30
.gnupg gpg.conf: Print keygrips and fingerprints 2015-10-20 16:30:32 +02:00
.kbd keymaps: Remove frex 2015-09-23 13:26:25 +02:00
.local/share/applications dwb: Remove forgotten leftover 2015-11-02 20:55:34 +01:00
.mpv mpv: Use xv by default 2016-04-07 12:11:05 +07:00
.mutt Mutt: Fix sidebar options for 1.7 2016-08-22 10:23:47 +05:30
.pkg pkg: Update 2016-08-09 07:19:32 +05:30
.scripts scripts/blind-append: Remove this stupid script 2016-10-10 17:50:32 +05:30
.shell.d shell: Remove current folder from fzf-bcd list 2016-10-10 17:31:31 +05:30
.texmf/tex Replace TikZ samples for Asymptote samples 2015-01-08 12:07:57 +01:00
.xkb xkb: Add ø|Ø symbols 2015-11-07 09:58:58 +01:00
.Xresources Qutebrowser: Init 2015-10-20 11:47:47 +02:00
.gitconfig Remove 'tig' config 2016-06-09 14:50:26 +02:00
.gitignore Update .gitignore 2016-09-24 07:18:32 +05:30
.gprc gprc: PARI/GP init file. 2013-06-17 17:29:04 +02:00
.profile fzf: Bind C-v to page-down, M-v to page-up 2016-10-05 17:52:25 +05:30
.uncrustify.cfg Uncrustify: Remove blank lines before/after '}'/'{' respectively 2016-06-11 16:40:21 +02:00
.xinitrc xinitrc: Use 'exec' and comment logoff cleaning issue 2016-06-22 11:16:48 +02:00
.xprofile Qutebrowser: Init 2015-10-20 11:47:47 +02:00
.zshrc Reformat with tabs and more consistent style 2014-11-12 18:00:08 +01:00
README.md Emacs: Use package-selected-packages feature from v25 2016-10-08 19:40:29 +05:30

README.md

Unix Home Configuration

Author: P. Neidhardt

Overview

This repository contains scripts and configuration files for various Unix programs. I tried hard to maintain universality: it should work anywhere (Arch Linux, FreeBSD...), with whichever version of the programs. In the worst case, only few modifications will be necessary.

Most interesting parts include advanced configuration for Awesome, Emacs, Mutt, ranger, Zsh and some shell scripts.


Description

Awesome

  • Extra deps: Vicious (Linux only)

Configuration is very close to the default one with some features removed (bindings, mouse control, context menu). The main new feature is the status bar: dynamic network speed (it checks for different interfaces), CPU speed, a battery indicator that will not show up if no battery is detected, and sound volume. The implementation is straightforward since I am using the Vicious plugin.

This configuration is very version-sensitive, so make sure to use the latest build.

Emacs

Emacs daemon is flawlessly integrated thanks to a small em script -- see the scripts folder. em forks and does not return. emw and emc (windowed and console version respectively) return to their caller. This can be useful in some contexts: Mutt, ranger bulkrename, git and web editing. The windowed version of Emacs is not limited to terminal capabilities. The console version has the advantage of not spawning a new window when already running in console.

I wrote a lot of Lisp helper functions and a custom theme with 256 colors, works for both text and graphical Emacs.

C-based modes: bindings to compile either from makefile or from a custom command if no makefile is found, formatting with Uncrustify, skeletons.

TeX and LaTeX full-featured environment: no AucTeX, itemize function, skeletons, compilation with various engines and index support, external PDF view with SyncTeX support, temp files clean function, PDF compression.

I make use of just a few unofficial packages. Use package-install-selected-packages to install them all at once.

Mutt

  • Compile options: IMAP and SMTP support, sidebar.
  • Extra deps: antiword, ccrypt, fortune, sxiv, w3m.

Support for multiple accounts with encrypted passwords. (Mutt will prompt for the master password only once.) I use ccrypt for password management because it is much simpler than gnupg.

I use embedded IMAP and SMTP services which need appropriate compilation options. Embedded IMAP does not need to store e-mails locally. To speed-up e-mail queries, I cache them on disk. When the disk usage limit is reached, the older cached e-mails are erased until the cache shrinks below the limit again.

Some customization: custom index view, good Emacs integration (see .emacs.d), custom theme (matches Emacs colors), various tweaks.

For universal terminal support, the colorset.sh script will check terminal capabilities and load colors appropriately.

URxvt has an URL support that works also from Mutt. For other terminals, you might consider using the urlview plugin for Mutt.

Ranger

  • Extra deps: antiword, atool, highlight, img2txt, mediainfo, odt2txt, pdftotext, unrtf, w3m.

Custom bindings, file association, tweaked a few options, additional functions (mkcd, extracthere...).

Scripts

Probably the most interesting part here.

  • archive: simple tar wrapper to create archive for files and folders.

  • asciify: convert many non-ASCII characters to their nearest ASCII counterpart.

  • bsdman: read *BSD man pages.

  • crun: quick way to execute C files.

  • dataindex: create index of hierarchies. Useful to keep track of folder content and structure.

  • ediff: diff with Emacs.

  • einfo: info viewer with Emacs.

  • elisp: Emacs Lisp interpreter using Emacs.

  • extract: simple tar wrapper to extract archives. Atool should be preferred if available.

  • git-*: some git helper functions for sync and so on.

  • homeinit: initialize a new home configuration, i.e. get needed files, create symlinks, etc.

  • imagemount: a CDEmu/fuseiso wrapper that creates/deletes virtual drives automatically.

  • mover: move and merge folder into destination.

  • netinit: network setup. Works with wpa_supplicant. May replace any network manager.

  • pac*: pacman helper functions.

  • pdf*: PDF manipulation, e.g. extract pages, compress, resize to A4.

  • pkggen: generate lists of installed with pacman, FreeBSD's pkg and tlmgr (TeX Live manager).

  • tc-video-*: batch conversion of any kind of videos. Using FFmpeg.

Shell

  • Target: POSIX shell, dash, zsh

Features: aliases, functions, shell options, etc. Most of the shell configuration is POSIX and works with dash.

TeX

Plain TeX macros, most importantly a partial UTF-8 support (taken from LaTeX). Plain TeX macros are in the '.texmf' folder. Some Asymptote functions.

URxvt

  • Extra deps: Muennich's perl extensions (keyboard-select, clipboard, url-matcher)

Custom font and colors, no scroll bar, url-matcher, clipboard, and keyboard-select.


Versioning

Git makes it possible to use your home folder as a git repo, thus versioning all files directly.

cd
git init
git remote add origin <repo>
git fetch
git branch master origin/master
git checkout master

Some applications will need extra dependencies other than the default ones. You might have a look at the lists in the .pkg/ folder to know what programs I am using.


Known issues

  • All scripts take a strong point at being POSIX. However, there is no POSIX way (at least to my knowledge) to execute a shell function on the result of a 'find'. Neither 'find' nor 'xargs' can execute shell functions. One solution to this would be to call an external script, but then we lose all global variables. For now I assume no input file has newline, which is quite a strong assumption and not safe at all.