Go to file
Pierre Neidhardt 3435dcafdb Emacs: cache folder.
Scripts: minor tweaks.
README: overhauled.
2013-05-31 19:01:32 +02:00
.cmus Cmus: using 'rc' instead of 'autosave' (less dirty, and cross-platform). 2012-10-31 17:19:55 +01:00
.config dwb: fixed adblock path in 'settings'. 2013-05-30 14:51:44 +02:00
.emacs.d Emacs: cache folder. 2013-05-31 19:01:32 +02:00
.kbd kbd: new keyboard layout. 2013-01-15 20:24:44 +01:00
.local/share/applications Mimelist: PDF with zathura. 2013-03-19 17:20:58 +01:00
.mutt Mutt: moved folder to be more consistent. 2013-05-27 23:37:07 +02:00
.scripts Emacs: cache folder. 2013-05-31 19:01:32 +02:00
.shell.d Shell: fixed 'halt' alias. 2013-05-28 19:12:11 +02:00
.texmf/tex/plain Xresources: set URxvt url key to C-M-u to prevent conflict with emacs and others. 2012-09-23 23:06:52 +02:00
.xkb/symbols XKB: added comments. 2012-10-30 19:05:22 +01:00
.Xresources Homeinit: smarter conditions. 2013-05-22 17:35:54 +02:00
.emacs Emacs: minor improvements. 2013-05-25 13:43:22 +02:00
.emacs-light Emacs: Semantic mode config. 2013-02-27 18:44:46 +01:00
.gitconfig Homeinit: smarter conditions. 2013-05-22 17:35:54 +02:00
.gtkrc-2.0 Homeinit: Purged old files. 2012-09-02 19:32:47 +02:00
.pkg-arch-aur-edf23ads Homeinit: emacs 'em' fix. 2013-05-21 21:57:54 +02:00
.pkg-arch-aur-peteramd pkg: list update. 2013-05-04 12:37:42 +02:00
.pkg-arch-expert Moved all non-terminal content of main_rc to xprofile. 2013-05-24 20:01:46 +02:00
.pkg-arch-official-edf23ads Moved all non-terminal content of main_rc to xprofile. 2013-05-24 20:01:46 +02:00
.pkg-arch-official-peteramd pkg: list update. 2013-05-04 12:37:42 +02:00
.pkg-arch-public-low pkg-arch-public-low: scan and network. 2013-05-05 16:30:47 +02:00
.pkg-freebsd-edf23ads Netinit: force zsh usage. Added comments explaning why. 2012-11-01 14:47:35 +01:00
.pkg-texlive-FreeBSD-edf23ads Awesome: fixed sound support for FreeBSD. 2012-11-01 18:08:44 +01:00
.pkg-texlive-Linux-edf23ads Homeinit: emacs 'em' fix. 2013-05-21 21:57:54 +02:00
.pkg-texlive-Linux-peteramd Emacs: C++ mode. 2013-04-13 20:23:47 +02:00
.rtorrent.rc Committed most of the home config files. 2012-06-18 11:02:45 +01:00
.taskrc Committed most of the home config files. 2012-06-18 11:02:45 +01:00
.vimrc Vim: set indent settings. 2012-11-17 12:19:57 +01:00
.xinitrc .xprofile: used to support all DM (LightDM, KDM, GDM, etc.) 2013-05-24 17:27:56 +02:00
.xprofile Xprofile: optional keyboard layout. 2013-05-28 10:17:43 +02:00
.zshrc Shell: hook support. 2013-05-22 17:54:53 +02:00
README Emacs: cache folder. 2013-05-31 19:01:32 +02:00

README

################################################################################
#                           Unix Home Configuration                            #
#                             Author: P. Neidhardt                             #
#                               Date: 2013-05-31                               #
################################################################################

Description
***********

This repository contains scripts configuration files for various Unix programs.
It targets Arch Linux and FreeBSD, but since these are "fundamental" Unix
distributions, it might work for most other Unices as well. I tried hard to
maintain universality: it should work anywhere (whatever the versions of the
programs are) with as few modifications as possible.

Most interesting parts include advanced configuration for Emacs, Mutt, and some
interesting shell scripts like a video transcoding wrapper and a smart audio
organizer using FFmpeg.

################################################################################

Awesome
*******
Extra deps: Vicious (Linux only)

Configuration is very close to the default one, which mostly fits my needs.
Most of the work I've done is for the status bar:  dynamic network speed (it
checks for different interfaces), CPU speed, dynamic battery that will not show
up if no battery is detected, and sound volume. But since I'm using the
Vicious plugin, it is quite straightforward.

This configuration is for now very version-sensitive, so you should make sure to
use latest build.

dwb
***
Some custom options, download location, search engines, plugins, etc.

Emacs
*****
Extra deps
- recommended: emacs-multiple-cursors emacs-xclip emacs-yasnippet
- optional: emacs-bison-mode emacs-flex-mode emacs-glsl-mode emacs-lua-mode
  emacs-make-regexp emacs-mediawiki-bzr

Build options:
  ./configure --prefix=/usr --sysconfdir=/etc --libexecdir=/usr/lib \
    --localstatedir=/var --with-x-toolkit=lucid --with-xft \
    --without-gconf --without-sound

Emacs daemon is integrated flawlessly thanks to a small script. See homeinit.
Because terminal and graphical clients do not behave the same way, it is
sometimes useful to specify which version should be used. For mutt, ranger
bulkrename, git commit message and dwb, it is required to wait for the client to
return.

Configuration for C programming. Bindings to compile either from makefile or
from a custom command if no makefile is found.

TeX and LaTeX full-featured home made environment: no AucTeX required, snippets,
dynamic compilation with various engines, dynamic configuration, proper PDF
view, temp files clean function, PDF compression, SyncTeX support.

Custom theme with 256 colors, works for both text and graphical Emacs.

Extended file support (shell files, Mutt mails, Arch Linux PKGBUILDs).

Some customization: columns, kill whole line, org-mode, semantic, etc.

Some custom functions: duplicate line, unfill-paragraph, etc.

A lot of code snippets, especially for LaTeX. Contains document template, plot
generation, pie chart generation, and others.

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

This one is not easy to get into it. I managed to get multiple accounts with
encrypted passwords working, which means there is no plain password stored on
the disk. As a result, I just get prompted for a main password on Mutt startup,
then everything works out of the box.  I use ccrypt for password management
because it is much more simple than gnupg.

I'm using embedded IMAP and SMTP services which need appropriate compilation
options.

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

Thanks to the colorset.sh script, Mutt will check terminal color support and
load colors appropriately. Therefore this configuration should work on any
terminal, should it have 256-colors support or not.

URxvt has an URL support that works also for 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.

Scripts
*******

Probably the most interesting part here.

*clean: remove junk files from TeX projects, home folder, etc.

abs-*: helper scripts to compile pacman-based packages (using makepkg). With
       these scripts you can recompile your whole system.

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

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

crun: quick way to execute C files.

ediff: diff with Emacs.

formatc: wrapper for 'indent' to prettify C source code.

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

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

pacman-*: a lot of handy functions for the pacman package manager,
  like sorting by size, dependency listing, etc.

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-audio-*: smart audio transcoding implemented as shell functions. It will
  convert, tag and move the input tracks in a dynamic, yet customizable
  manner. It features a smart title case AWK function that will print almost any
  audio tag the proper way. It will copy cover files when found. You can preview
  the changes without writing data. Using FFmpeg.

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

Shell
*****
Target: POSIX shell, dash, zsh

A lot of stuff: aliases, functions, shell options, etc.

Please note that this config is mainly intended -- and tested -- for zsh.  I
removed bash support since it is really a scourge to shell scripting. However
most of the script and the shell configuration are POSIX shell compatible
(tested with dash). When some advanced features were required (like arrays),
I've set the shabang accordingly.

TeX
***

Plain TeX macros, most importantly a partial UTF-8 support (taken from LaTeX).

A lot of LaTeX macros. Among others: pie charts, dynamic plots with
input file and trend.

Plain TeX macros are in the '.texmf' folder. LaTeX macros are all bundled into
Emacs snippets so that .tex documents do not rely on any external file.

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.

Vim
***
I've only been a casual Vim user, so do not expect too much from it.

################################################################################

Usage
*****

The only purpose is to be a source of inspiration. Examples are always a good
technical support. (Especially for applications that do not provide examples in
their documentation.)  There is no use in blind-copying the content of any file
into your personal home folder. At best it might break things.

In case you still want to copy some files -- for quick and dirty testing purpose
-- do not forget that most of the files are in hidden folders.  Also note that
in some shells, the '*' joker will NOT match hidden files, that is

    cp -r source-dir/* dest-dir/

will copy non-hidden folders only.  To match all folders, use the following
joker instead:

    cp -r source-dir/{.*,*} dest-dir/   # zsh
    cp -r source-dir/{.??*,*} dest-dir/ # bash

Still, the solution for bash is not perfect as it affects 3 characters files
only. A more convenient solution:

    # bash only.
    shopt -s dotglob
    cp -r source-dir/* dest-dir/

Versioning
**********

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

    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 .pkg-* files to see what software I've been using.

################################################################################
Known issues
************

Emacs

* From time to time Emacs daemon will 'break' after a while: indentation and
  colors will stop work properly. Investigation in progress. On graphical
  client, this does not seem to happen, but the server seems to crash randomly
  (black/white screen when calling a new client).

* When linenum is on in very large files (5000+ lines), beginning-of-buffer is
  extremly slow when called from a shortcut, but not when called from the
  command mini-buffer.

URxvt

* Using the paste function from Muennich's clipboard on the same terminal where
  text was copied will make it crash.

* There is a bug with Xft anti-aliased font that prevent w3m image preview from
  working (too bad for ranger).

################################################################################
Noteworthy apps
***************

aalib
abook
aircrack-ng
antiword
apvlv
asciidoc
astyle
atool
awesome
awk
bashmount
bc
cal
calc
catdvi
ccrypt
cdrtools
centerim
chrpath
cmus
column
comm
cppcheck
cut
dash
diff
doxygen
dropbox
dtach
dvtm
dwb
emacs
fbpdf
fbv
fdisk
feh
ffmpeg
file
finch
fmt
fortune
gaupol
gcolor2
gdb
gimp
gnumeric
gnuplot
gparted
graphicsmagick
grep
groff
hdparm
highlight
htop
id3v2
imagemagick
indent
inkscape
iotop
irssi
latex2html
latex2rtf
lrzip
lshw
ltrace
luakit
lynx
mediainfo
mercurial
mkfs
mkvtoolnix
movgrab
mplayer2
mutt
nasm
nawk
ncdu
nethogs
newsbeuter
ngrep
nmap
numlockx
octave
od
odt2txt
okular
openshot
openssh
oss
p7zip
pari
parted
patch
poppler
pstotext
pwgen
qpdf
ranger
re2c
rsync
rtorrent
rxvt-unicode
scrot
sdparm
sed
shred
slock
sort
splint
strace
subdl
submarine
sudo
sxiv
syslinux
task
tcc
tcpdump
texi2html
texinfo
texlive
textadept
tig
trash-cli
tree
udiskie
unrtf
upx
valgrind
vim
vlock
w3m
weechat
wipe
wireshark
wmfs
wv
x264
xclip
xlockmore
yasm
youtube-dl
zathura
zsh