From c7927ea61730bd6d8a283078d89dffdca08535cd Mon Sep 17 00:00:00 2001 From: Daniel Friesel Date: Thu, 12 Nov 2009 22:02:20 +0100 Subject: Merge stuff into .zshrc --- etc/alias | 10 - etc/aliases/debian | 46 ----- etc/aliases/default | 69 ------- etc/aliases/font | 9 - etc/aliases/global | 9 - etc/aliases/short | 46 ----- etc/aliases/suffix | 20 -- etc/aliases/x | 49 ----- etc/cleanup | 9 - etc/completion | 51 ----- etc/directories | 7 - etc/function | 19 -- etc/include | 6 - etc/keys | 7 - etc/ls-colors | 18 -- etc/mime-setup | 20 -- etc/misc | 9 - etc/options | 31 --- etc/osdetect | 11 - etc/parameters | 43 ---- etc/prompt | 38 ---- etc/rc | 579 ++++++++++++++++++++++++++++++++++++++++++++++++++-- etc/rc_status | 7 - etc/zle | 8 - 24 files changed, 561 insertions(+), 560 deletions(-) delete mode 100644 etc/alias delete mode 100644 etc/aliases/debian delete mode 100644 etc/aliases/default delete mode 100644 etc/aliases/font delete mode 100644 etc/aliases/global delete mode 100644 etc/aliases/short delete mode 100644 etc/aliases/suffix delete mode 100644 etc/aliases/x delete mode 100644 etc/cleanup delete mode 100644 etc/completion delete mode 100644 etc/directories delete mode 100644 etc/function delete mode 100644 etc/include delete mode 100644 etc/keys delete mode 100644 etc/ls-colors delete mode 100644 etc/mime-setup delete mode 100644 etc/misc delete mode 100644 etc/options delete mode 100644 etc/osdetect delete mode 100644 etc/parameters delete mode 100644 etc/prompt delete mode 100644 etc/rc_status delete mode 100644 etc/zle diff --git a/etc/alias b/etc/alias deleted file mode 100644 index 98a462f..0000000 --- a/etc/alias +++ /dev/null @@ -1,10 +0,0 @@ -## vim:ft=zsh -zrc_status aliases -source $ZDIR/aliases/suffix -source $ZDIR/aliases/font -source $ZDIR/aliases/default -source $ZDIR/aliases/global -source $ZDIR/aliases/short - -[[ $distro == debian ]] && source $ZDIR/aliases/debian -check_com -c startx && source $ZDIR/aliases/x diff --git a/etc/aliases/debian b/etc/aliases/debian deleted file mode 100644 index 1ca5e2d..0000000 --- a/etc/aliases/debian +++ /dev/null @@ -1,46 +0,0 @@ -## vim:ft=zsh -## Debian package system (aptitude/apt-get, apt-cache, dpkg) - -# Search the packages list -alias acse='apt-cache search' -alias afse='apt-file search' -alias apse='aptitude search' - -# Show package information -alias acp='apt-cache policy' -alias acsh='apt-cache show' -alias afsh='apt-file show' -alias apsh='aptitude show' -alias dps='dpkg --status' - -# Update packages list -salias agu='apt-get update' -salias apu='aptitude update' - -# Update packages -salias ags='apt-get upgrade' -salias agf='apt-get dist-upgrade' -salias aps='aptitude safe-upgrade' -salias apf='aptitude full-upgrade' - -# Install packages -salias agi='apt-get install' -salias api='aptitude install' -salias dpi='dpkg --install' - -# Clean packages cache -salias agc='apt-get clean' -salias apc='aptitude clean' - -# Remove/Purge packages -salias agar='apt-get autoremove' -salias agp='apt-get purge' -salias agr='apt-get remove' -salias dpp='dpkg --purge' -salias dpr='dpkg --remove' - -# Get package source -alias agsrc='apt-get source' - -# Configure packages -salias dprc='dpkg-reconfigure' diff --git a/etc/aliases/default b/etc/aliases/default deleted file mode 100644 index 85d8c5e..0000000 --- a/etc/aliases/default +++ /dev/null @@ -1,69 +0,0 @@ -## vim:ft=zsh -## Some useful default options -## To evade them, use '=foo' instead of 'foo' - - -## grep -linux: { - alias egrep='grep -E --color=auto' - alias fgrep='grep -F --color=auto' - alias grep='grep --color=auto' -} - - -## file and filesystem information -# human-readable sizes, local filesystems only -linux: alias df='df -hl --exclude-type=fuse.encfs' || - alias df='df -hl' - -# human-readable sizes, summarize, dereference args -linux: alias du='du -shD' || - alias du='du -shH' - -# human-readable sizes, mark executables with '*' etc. -linux: alias ls='ls -h --color=auto' || - alias ls='ls -Fh' - -## enable alias expansion -alias exec='exec ' -alias sudo='sudo ' - -## networking -alias mx='mx -aZ' - -# Only TCP/TCP6, not sockets and such -linux: salias netstat='netstat --program --all --tcp --extend' || - salias netstat='netstat -atp tcp' - - -# less frequent updates when running ncdu via ssh -[[ -n $SSH_CONNECTION ]] && check_com -c ncdu && alias ncdu='ncdu -q' - -alias bc='bc -l' - -alias cal='cal -m' -alias fbi='fbi -readahead' - -# I keep accidently overwriting files -alias cp='cp -i' -alias mv='mv -i' - -# no atime -alias pmount='pmount -A' - -# find does globbing itself -alias find='noglob find' - -# Show all available manuals (all sections) -alias man='man -a' - -# BSD style -alias ps='ps -F' - -# use unicode, reattach anyway, resize if neccessary -alias screen='tscreen -ADRUa' - -alias tilp='kdesudo "tilp --calc=ti84+ --cable=DirectLink"' - -# Don't collapse trees -alias todo='noglob todo -f +children' diff --git a/etc/aliases/font b/etc/aliases/font deleted file mode 100644 index 986df27..0000000 --- a/etc/aliases/font +++ /dev/null @@ -1,9 +0,0 @@ -## Shamelessly stolen from http://git.kitenet.net/?p=joey/home-etc;a=summary -## vim:ft=zsh -alias font-tiny='echo -en "\033]50;-misc-fixed-medium-r-normal--8-80-75-75-c-50-iso10646-1\007"' -alias font-small='echo -en "\033]50;6x10\007"' -alias font-default='echo -e "\033]50;-misc-fixed-medium-r-semicondensed--13-*-*-*-*-*-iso10646-1\007"' -alias font-medium='echo -en "\033]50;-misc-fixed-medium-r-normal--13-120-75-75-c-80-iso10646-1\007"' -alias font-large='echo -en "\033]50;-misc-fixed-medium-*-*-*-15-*-*-*-*-*-iso10646-1\007"' -alias font-larger='echo -en "\033]50;-misc-fixed-medium-r-normal--18-*-*-*-*-*-iso10646-1\007"' -alias font-huge='echo -en "\033]50;-misc-fixed-medium-r-normal--20-200-75-75-c-100-iso10646-1\007"' diff --git a/etc/aliases/global b/etc/aliases/global deleted file mode 100644 index 4398484..0000000 --- a/etc/aliases/global +++ /dev/null @@ -1,9 +0,0 @@ -## Global aliases -## evil, but rarely messy -## vim:ft=zsh -alias -g EG='|egrep' -alias -g FG='|fgrep' -alias -g G='|grep' -alias -g H='|head' -alias -g L='|less' -alias -g T='|tail' diff --git a/etc/aliases/short b/etc/aliases/short deleted file mode 100644 index bff06c9..0000000 --- a/etc/aliases/short +++ /dev/null @@ -1,46 +0,0 @@ -## Short aliases -## vim:ft=zsh - -## For Loops -alias allf='for i in *(.);' -alias alld='for i in *(/);' -alias alle='for i in *(*);' -alias alll='for i in *(@);' -alias all='for i in *;' - -alias allfr='for i in **/*(.);' -alias alldr='for i in **/*(/);' -alias aller='for i in **/*(*);' -alias alllr='for i in **/*(@);' -alias allr='for i in **/*;' - -alias dua='du --apparent-size' - -alias lasth='last | head -$((LINES-1))' - -## fbi -alias fbif='fbi -a' -alias fbij='fbi -a -u' - -for i in ~/var/gtd/*(.N); { - alias gtd-${i:t}='todo --database '$i -} - -# File listings -alias lsi='feh --list' -alias lst='tar tvf' -alias lsz='unzip -l' - -alias nb='newsbeuter' -alias nbr='newsbeuter -r' - -alias rd='rmdir' - -alias rsync-serve="rsync --daemon --port=10873 --no-detach --config=/dev/stdin --log-file=/dev/stdout -v <<< $'[.]\n\tpath = .\n\tuse chroot = no'" - -## Suspend -salias s2d='s2disk' -salias s2r='s2ram -f' - -## Getränke -alias mate='decrement ~/stuff/$(cat ~/var/tmp/.actual-location)/mateguthaben' diff --git a/etc/aliases/suffix b/etc/aliases/suffix deleted file mode 100644 index 2587c3e..0000000 --- a/etc/aliases/suffix +++ /dev/null @@ -1,20 +0,0 @@ -## Sufix aliases -## Like, enter "somefile.ogg" and zsh will automatically open it using $audio_app -## vim:ft=zsh - -typeset -A alias_apps -alias_apps=( - archive extract - audio mplayer - document kpdf - image feh - video mplayer -) - -for meta in ${parameters[(I)mime_*]#mime_}; { - for format in $(eval echo "$"mime_$meta); { - alias -s $format=$alias_apps[$meta] - } -} - -unset filetypes meta format alias_apps diff --git a/etc/aliases/x b/etc/aliases/x deleted file mode 100644 index 1a41cc3..0000000 --- a/etc/aliases/x +++ /dev/null @@ -1,49 +0,0 @@ -## vim:ft=zsh - -# feh etc if X is running, x for startx otherwise -if pgrep -x Xorg &> /dev/null; then - - # quiet and verbose can actually be used together here. - # quiet = suppress non-critical errors, verbose = show progress bars - alias feh='feh --quiet --verbose' - - # Alias structure: - # feh[theme][recursive?][slide-delay?] - # theme = [f]ullscreen | [i]ndex | [j]ust | [t]humbnail - # recursive: r for recursive, nothing otherwise - # slide-delay: - # none - no slideshow - # number - slideshow, $number seconds per image - # x - slideshow, seconds will be specified on commandline - # (like "fehfrx 7 .") - # the themes are defined in .fehrc - alias fehf='feh -Tfull' # Fullscreen - alias fehfr='feh -Tfull --recursive' - alias fehi='feh .fehindex.jpg' - alias fehj='feh -Tjust' # Screensaver-like - alias fehjr='feh -Tjust --recursive' - for i in {5,10,15,20}; { - alias fehj$i="feh -Tjust --slideshow-delay $i" - alias fehf$i="feh -Tfull --slideshow-delay $i" - alias fehjr$i="feh -Tjust --slideshow-delay $i --recursive" - alias fehfr$i="feh -Tfull --slideshow-delay $i --recursive" - } - alias fehjx='feh -Tjust --slideshow-delay' - alias fehfx='feh -Tfull --slideshow-delay' - alias fehjrx='feh -Tjust --recursive --slideshow-delay' - alias fehfrx='feh -Tfull --recursive --slideshow-delay' - alias feht='feh -Tthumbnail' # List thumbnails - alias fehtr='feh -Tthumbnail --recursive' - - # Automatically upload screenshot plzkthx - alias putscreen='put $(screenshot)' - - # Useful when a beamer is connected to my laptop - alias rplayer='mplayer -vo x11 -zoom -vf scale=1024:-2' - - # show current weather - alias weather='feh http://www.bredeney-wetter.de/aktuell.gif' -else - # start x and log out immediately - alias x='unsetopt bg_nice; startx &! exit' -fi diff --git a/etc/cleanup b/etc/cleanup deleted file mode 100644 index defd566..0000000 --- a/etc/cleanup +++ /dev/null @@ -1,9 +0,0 @@ -## vim:ft=zsh -# cleanup -echo -n "\r\e[2K" -unalias 'linux:' -unalias 'openbsd:' -unfunction zrc_status zrc_info -unfunction xsource -unset system distro -unset -m 'mime_*' diff --git a/etc/completion b/etc/completion deleted file mode 100644 index 15db625..0000000 --- a/etc/completion +++ /dev/null @@ -1,51 +0,0 @@ -## vim:ft=zsh -zrc_status completion - -zstyle ':completion:*' cache-path $ZCACHEDIR -zstyle ':completion:*' use-cache true - -# Use ls-colors for file completion -zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS} - -# Mark the current selection when tabbing through possible completions -zstyle ':completion:*' menu select=1 - -# Complete uppercase names with lowercase and spaces with _ -zstyle ':completion:*' matcher-list '' 'm:{a-z}={A-Z} m:_=\\\ ' '+ l:|=* r:|=*' - -# Be verbose -zstyle ':completion:*' verbose true -zstyle ':completion:*:descriptions' format \ - "· %d ·" -zstyle ':completion:*:messages' format \ - "· %d ·" -zstyle ':completion:*:corrections' format \ - "· %d ·" -zstyle ':completion:*:warnings' format \ - "%F{red}no match:%F{default} %d" - -zstyle ':completion:*' group-name '' - -# Force menu completion since the input is just a stupid number -zstyle ':completion:*:*:kill:*' menu yes -zstyle ':completion:*:*:(todo|td*):*:items' menu yes - -zstyle ':completion:*:*:vi(m|):*' ignored-patterns \ - 'a.out|*.o' - -# fancy kill completion -# source: http://madism.org/~madcoder/dotfiles/zsh/40_completion -zstyle ':completion:*:processes' command 'ps -au$USER -o pid,time,cmd|grep -v "ps -au$USER -o pid,time,cmd"' -zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#)[ 0-9:]#([^ ]#)*=01;30=01;31=01;38' - -# separate manuals by sections -zstyle ':completion:*:manuals' separate-sections true -zstyle ':completion:*:manuals.*' insert-sections true - -# $hosts is set from the hosts package -zstyle ':completion:*' hosts ${(k)hosts} - -compinit -C -d $compdump - -compdef _hosts sshmount -compdef _functions reload diff --git a/etc/directories b/etc/directories deleted file mode 100644 index 0f9e70a..0000000 --- a/etc/directories +++ /dev/null @@ -1,7 +0,0 @@ -## Named directories -## vim:ft=zsh - -hash -d vcs=~/var/svn -xhashd lyrics=~vcs/lyrics -xhashd www=/var/www -xhashd web=~/public_html diff --git a/etc/function b/etc/function deleted file mode 100644 index 61fc8fa..0000000 --- a/etc/function +++ /dev/null @@ -1,19 +0,0 @@ -## vim:ft=zsh -zrc_status functions - -# zsh functions -autoload -U compinit -autoload zargs - -# own functions -autoload $ZDIR/functions/*(:t) - -function Status Start Stop Restart Reload { - typeset script sudo - if ((EUID)) { - sudo=sudo - } - for script in $*; { - $sudo /etc/init.d/$script ${0:l} - } -} diff --git a/etc/include b/etc/include deleted file mode 100644 index 09ecc30..0000000 --- a/etc/include +++ /dev/null @@ -1,6 +0,0 @@ -## vim:ft=zsh -zrc_status "includes" -source $ZDIR/../provided/includes -xsource $ZDIR/local # local configuration, not in git -[[ -e /tmp/envstore-$UID ]] && check_com envstore && eval $(envstore eval) -xsource $ZDIR/hosts/$HOST # local configuration in git diff --git a/etc/keys b/etc/keys deleted file mode 100644 index 6527cd2..0000000 --- a/etc/keys +++ /dev/null @@ -1,7 +0,0 @@ -## vim:ft=zsh -bindkey -e -[[ -z $terminfo[kdch1] ]] || bindkey -M emacs $terminfo[kdch1] delete-char -[[ -z $terminfo[khome] ]] || bindkey -M emacs $terminfo[khome] beginning-of-line -[[ -z $terminfo[kend] ]] || bindkey -M emacs $terminfo[kend] end-of-line -bindkey '^Z' predict-on -bindkey '^X^Z' predict-off diff --git a/etc/ls-colors b/etc/ls-colors deleted file mode 100644 index 2be023a..0000000 --- a/etc/ls-colors +++ /dev/null @@ -1,18 +0,0 @@ -## vim:ft=zsh - -# default:file :dirctory: link : pipe : socket -LS_COLORS="no=00:fi=00:di=01;37:ln=01;36:pi=40;33:so=01;35" - -# door : block dev : char dev :broken link: setuid -LS_COLORS+=":do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41" - -# setgid : +t,o+w : o+w : sticky : executable -LS_COLORS+=":sg=30;43:tw=30;42:ow=34;42:st=37;44:ex=01;32" - -LS_COLORS+=:${(j/:/):-"*."${^mime_archive}"=04;31"} -LS_COLORS+=:${(j/:/):-"*."${^mime_audio}"=04;36"} -LS_COLORS+=:${(j/:/):-"*."${^mime_document}"=04"} -LS_COLORS+=:${(j/:/):-"*."${^mime_image}"=04;33"} -LS_COLORS+=:${(j/:/):-"*."${^mime_video}"=04;32"} - -export LS_COLORS diff --git a/etc/mime-setup b/etc/mime-setup deleted file mode 100644 index 0ac05a1..0000000 --- a/etc/mime-setup +++ /dev/null @@ -1,20 +0,0 @@ -## vim:ft=zsh -## mime-setup - Initialize parameters used for suffix aliases and ls-colors - -mime_archive=( - 7z ace arj bz bz2 cpio deb dz gz jar lzh lzma rar rpm rz svgz - tar taz tbz2 tgz tz z Z zip zoo -) -mime_audio=( - aif aifc aiff amr amr au awb awb axa flac gsm kar m3u m3u m4a mid midi - mp2 mp3 mpega mpga oga ogg pls ra ra ram rm sd2 sid snd spx wav wax wma -) -mime_document=(pdf ps) -mime_image=( - art bmp cdr cdt cpt cr2 crw djv djvu erf gif ico ief jng jpe jpeg jpg nef orf - pat pbm pcx pgm png pnm ppm psd ras rgb svg svgz tif tiff wbmp xbm xpm xwd -) -mime_video=( - 3gp asf asx avi axv dif divx dl dv fli flv gl lsf lsx m2t mkv mng mov - movie mp4 mpe mpeg mpg mpv mxu ogm ogv qt rmvb wm wmv wmx wvx -) diff --git a/etc/misc b/etc/misc deleted file mode 100644 index e115cd6..0000000 --- a/etc/misc +++ /dev/null @@ -1,9 +0,0 @@ -## vim:ft=zsh -# misc -mesg n -if ((UID)) { - umask 077 -} else { - umask 002 -} -chpwd diff --git a/etc/options b/etc/options deleted file mode 100644 index 056abbb..0000000 --- a/etc/options +++ /dev/null @@ -1,31 +0,0 @@ -## Some useful options, see zshoptions(1) -## vim:ft=zsh - -## Directory changing -# Automatically use 'pushd' when cd'ing into a directory -# so I can use popd or 'cd -1' to get back where I came from. -# And don't print the stack everytime using popd. -setopt auto_pushd pushd_ignore_dups pushd_minus pushd_silent -setopt auto_cd - -## Prompt -setopt transient_rprompt - -## Completion -setopt list_packed - -## Expansion / Globbing -setopt extended_glob - -## History -unsetopt bang_hist - -## Input/Output -setopt correct -# greedy is more like dvorak than qwerty... -setopt dvorak -unsetopt flow_control -setopt rc_quotes - -## ZLE -unsetopt beep diff --git a/etc/osdetect b/etc/osdetect deleted file mode 100644 index 91a7c8a..0000000 --- a/etc/osdetect +++ /dev/null @@ -1,11 +0,0 @@ -## vim:ft=zsh -# for system-specific setup -system=${$(uname):l} -alias 'linux:'='[[ $system == linux ]] &&' -alias 'openbsd:'='[[ $system == openbsd ]] &&' -if [[ $system == linux ]] { - [[ -f /etc/debian_version ]] && distro=debian - [[ -f /etc/gentoo-release ]] && distro=gentoo - [[ -f /etc/arch-release ]] && distro=arch - [[ -f /etc/redhat-release ]] && distro=redhat -} diff --git a/etc/parameters b/etc/parameters deleted file mode 100644 index b05e245..0000000 --- a/etc/parameters +++ /dev/null @@ -1,43 +0,0 @@ -## vim:ft=zsh -## parameters which are only important for interactive shells. -## For application-related parameters, see zshenv - -# zsh cache directory -if [[ -d ~/var/cache/zsh ]] { - ZCACHEDIR=~/var/cache/zsh -} else { - zrc_info "~/var/cache/zsh does not exist, using ~/.zsh-cache instead" - mkdir -p ~/.zsh-cache - ZCACHEDIR=~/.zsh-cache -} - -# There's no point in having more history than what can be saved on disk -HISTFILE=$ZCACHEDIR/history -HISTSIZE=50000 -SAVEHIST=$HISTSIZE - -# how many entries to keep for popd -DIRSTACKSIZE=20 - -# Use the full terminal size for listings -LISTMAX=0 - -# be accurate -TIMEFMT='%J (%P) - %*E real, %*U user, %*S system' - -# completion cache for compinit -compdump=$ZCACHEDIR/compdump - -if ((EUID)) { - path+=(/sbin /usr/sbin /usr/local/sbin) -} - -export MAKEFLAGS=j$(grep -c '^processor' /proc/cpuinfo) - -# Add my own executables, if they're not already in the path -[[ $path[1] = $HOME/bin ]] || export PATH=$HOME/bin:$PATH - -# Add manuals from caretaker to manpath -which manpath &> /dev/null && [[ -z $MANPATH ]] && export MANPATH=$(manpath):$HOME/packages/.collected/man - -openbsd: export PKG_PATH="ftp://ftp.freenet.de/pub/ftp.openbsd.org/pub/OpenBSD/`uname -r`/packages/`machine -a`/:ftp://openbsd.ftp.fu-berlin.de/pub/OpenBSD/`uname -r`/packages/`machine -a`/" diff --git a/etc/prompt b/etc/prompt deleted file mode 100644 index afc6365..0000000 --- a/etc/prompt +++ /dev/null @@ -1,38 +0,0 @@ -## Prompt -## vim:ft=zsh -# RPS1 is on the right side of the terminal -# The \ek\e\\ is for screen's 'shelltitle' - -# psvar[1] = directory info -# psvar[2] = rtab (current directory) - -typeset -A ps rps - -ps=( - host "%F{yellow}%m" - dir "%F{default}%30<…<%2v%>>" - sign "%(!.%F{red}.%F{green})%(?.%(!.#.>).%?)%F{default}" - screen $'%{\ek\e\\%}' -) - -rps=( - start_always "%F{yellow}[" - start_screen "%(1V.%F{yellow}[" - dirinfo "%F{default}%1v" - time '%T' - end_always "%F{yellow}]%F{default}" - end_screen "%(1V.%F{yellow}]%F{default}.)" -) - -PS1="${ps[host]} ${ps[dir]} ${ps[sign]} ${ps[screen]}" - -if [[ $TERM == screen ]] { - RPS1="${rps[start_screen]}${rps[dirinfo]}${rps[end_screen]}" -} else { - RPS1="${rps[start_always]}${rps[dirinfo]}${rps[time]}${rps[end_always]}" -} - -unset ps rps - -zstyle ':prompt:rtab' fish yes -zstyle ':prompt:rtab' nameddirs yes diff --git a/etc/rc b/etc/rc index 84ffd04..4a2207d 100644 --- a/etc/rc +++ b/etc/rc @@ -1,24 +1,567 @@ -## vim:ft=zsh +## vim:ft=zsh:foldmethod=marker ## Copyright (c) 2008, 2009 by Daniel Friesel -## Unless otherwise noted, this Licence applies to all files sourced here: +## Licence: ## 0. You just DO WHAT THE FUCK YOU WANT TO. ## ## https://derf.homelinux.org/~derf/dotfiles/zsh/rc ## see also: https://derf.homelinux.org/~derf/dotfiles/zsh/ -source $ZDIR/osdetect -source $ZDIR/rc_status -source $ZDIR/options -source $ZDIR/parameters -source $ZDIR/mime-setup -source $ZDIR/ls-colors -source $ZDIR/function -source $ZDIR/zle -source $ZDIR/prompt -source $ZDIR/directories -source $ZDIR/keys -source $ZDIR/alias -source $ZDIR/misc -source $ZDIR/include -source $ZDIR/completion -source $ZDIR/cleanup +# {{{ OS Detection +system=${$(uname):l} + +alias 'linux:'='[[ $system == linux ]] &&' +alias 'openbsd:'='[[ $system == openbsd ]] &&' + +if [[ $system == linux ]] { + [[ -f /etc/debian_version ]] && distro=debian + [[ -f /etc/gentoo-release ]] && distro=gentoo + [[ -f /etc/arch-release ]] && distro=arch + [[ -f /etc/redhat-release ]] && distro=redhat +} +# }}} + +# {{{ Functions for startup status +function zrc_status { + echo -n "\r\e[2K\e[0;36m䷢\e[0m $*" +} + +function zrc_info { + echo "\e[0;36mℹ\e[0m $*" +} +# }}} + +# {{{ Options +## Directory changing +# Automatically use 'pushd' when cd'ing into a directory +# so I can use popd or 'cd -1' to get back where I came from. +# And don't print the stack everytime using popd. +setopt auto_pushd pushd_ignore_dups pushd_minus pushd_silent +setopt auto_cd + +## Prompt +setopt transient_rprompt + +## Completion +setopt list_packed + +## Expansion / Globbing +setopt extended_glob + +## History +unsetopt bang_hist + +## Input/Output +setopt correct +# greedy is more like dvorak than qwerty... +setopt dvorak +unsetopt flow_control +setopt rc_quotes + +## ZLE +unsetopt beep +# }}} + +# {{{ Shell parameters +## parameters which are only important for interactive shells. +## For application-related parameters, see zshenv + +# zsh cache directory +if [[ -d ~/var/cache/zsh ]] { + ZCACHEDIR=~/var/cache/zsh +} else { + zrc_info "~/var/cache/zsh does not exist, using ~/.zsh-cache instead" + mkdir -p ~/.zsh-cache + ZCACHEDIR=~/.zsh-cache +} + +# There's no point in having more history than what can be saved on disk +HISTFILE=$ZCACHEDIR/history +HISTSIZE=50000 +SAVEHIST=$HISTSIZE + +# how many entries to keep for popd +DIRSTACKSIZE=20 + +# Use the full terminal size for listings +LISTMAX=0 + +# be accurate +TIMEFMT='%J (%P) - %*E real, %*U user, %*S system' + +# completion cache for compinit +compdump=$ZCACHEDIR/compdump + +if ((EUID)) { + path+=(/sbin /usr/sbin /usr/local/sbin) +} + +export MAKEFLAGS=j$(grep -c '^processor' /proc/cpuinfo) + +# Add my own executables, if they're not already in the path +[[ $path[1] = $HOME/bin ]] || export PATH=$HOME/bin:$PATH + +# Add manuals from caretaker to manpath +which manpath &> /dev/null && [[ -z $MANPATH ]] && export MANPATH=$(manpath):$HOME/packages/.collected/man + +openbsd: export PKG_PATH="ftp://ftp.freenet.de/pub/ftp.openbsd.org/pub/OpenBSD/`uname -r`/packages/`machine -a`/:ftp://openbsd.ftp.fu-berlin.de/pub/OpenBSD/`uname -r`/packages/`machine -a`/" +# }}} + +# {{{ MIME parameters +mime_archive=( + 7z ace arj bz bz2 cpio deb dz gz jar lzh lzma rar rpm rz svgz + tar taz tbz2 tgz tz z Z zip zoo +) +mime_audio=( + aif aifc aiff amr amr au awb awb axa flac gsm kar m3u m3u m4a mid midi + mp2 mp3 mpega mpga oga ogg pls ra ra ram rm sd2 sid snd spx wav wax wma +) +mime_document=(pdf ps) +mime_image=( + art bmp cdr cdt cpt cr2 crw djv djvu erf gif ico ief jng jpe jpeg jpg nef orf + pat pbm pcx pgm png pnm ppm psd ras rgb svg svgz tif tiff wbmp xbm xpm xwd +) +mime_video=( + 3gp asf asx avi axv dif divx dl dv fli flv gl lsf lsx m2t mkv mng mov + movie mp4 mpe mpeg mpg mpv mxu ogm ogv qt rmvb wm wmv wmx wvx +) +# }}} + +# {{{ ls-colors (partially based on MIME) +# default:file :dirctory: link : pipe : socket +LS_COLORS="no=00:fi=00:di=01;37:ln=01;36:pi=40;33:so=01;35" + +# door : block dev : char dev :broken link: setuid +LS_COLORS+=":do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41" + +# setgid : +t,o+w : o+w : sticky : executable +LS_COLORS+=":sg=30;43:tw=30;42:ow=34;42:st=37;44:ex=01;32" + +LS_COLORS+=:${(j/:/):-"*."${^mime_archive}"=04;31"} +LS_COLORS+=:${(j/:/):-"*."${^mime_audio}"=04;36"} +LS_COLORS+=:${(j/:/):-"*."${^mime_document}"=04"} +LS_COLORS+=:${(j/:/):-"*."${^mime_image}"=04;33"} +LS_COLORS+=:${(j/:/):-"*."${^mime_video}"=04;32"} + +export LS_COLORS +# }}} + +# {{{ Functions +zrc_status functions + +# zsh functions +autoload -U compinit +autoload zargs + +# own functions +autoload $ZDIR/functions/*(:t) + +function Status Start Stop Restart Reload { + typeset script sudo + if ((EUID)) { + sudo=sudo + } + for script in $*; { + $sudo /etc/init.d/$script ${0:l} + } +} +# }}} + +# {{{ ZLE +autoload -U url-quote-magic +zle -N self-insert url-quote-magic + +autoload predict-on +zle -N predict-on +zle -N predict-off +zstyle ':predict' verbose true +# }}} + +# {{{ Prompt +# RPS1 is on the right side of the terminal +# The \ek\e\\ is for screen's 'shelltitle' + +# psvar[1] = directory info +# psvar[2] = rtab (current directory) + +typeset -A ps rps + +ps=( + host "%F{yellow}%m" + dir "%F{default}%30<…<%2v%>>" + sign "%(!.%F{red}.%F{green})%(?.%(!.#.>).%?)%F{default}" + screen $'%{\ek\e\\%}' +) + +rps=( + start_always "%F{yellow}[" + start_screen "%(1V.%F{yellow}[" + dirinfo "%F{default}%1v" + time '%T' + end_always "%F{yellow}]%F{default}" + end_screen "%(1V.%F{yellow}]%F{default}.)" +) + +PS1="${ps[host]} ${ps[dir]} ${ps[sign]} ${ps[screen]}" + +if [[ $TERM == screen ]] { + RPS1="${rps[start_screen]}${rps[dirinfo]}${rps[end_screen]}" +} else { + RPS1="${rps[start_always]}${rps[dirinfo]}${rps[time]}${rps[end_always]}" +} + +unset ps rps + +zstyle ':prompt:rtab' fish yes +zstyle ':prompt:rtab' nameddirs yes +# }}} + +# {{{ Named directories +hash -d vcs=~/var/svn +xhashd lyrics=~vcs/lyrics +xhashd www=/var/www +xhashd web=~/public_html +# }}} + +# {{{ Keys +bindkey -e +[[ -z $terminfo[kdch1] ]] || bindkey -M emacs $terminfo[kdch1] delete-char +[[ -z $terminfo[khome] ]] || bindkey -M emacs $terminfo[khome] beginning-of-line +[[ -z $terminfo[kend] ]] || bindkey -M emacs $terminfo[kend] end-of-line +bindkey '^Z' predict-on +bindkey '^X^Z' predict-off +# }}} + +# {{{ Aliases +zrc_status aliases + +# {{{ Suffix +typeset -A alias_apps +alias_apps=( + archive extract + audio mplayer + document kpdf + image feh + video mplayer +) + +for meta in ${parameters[(I)mime_*]#mime_}; { + for format in $(eval echo "$"mime_$meta); { + alias -s $format=$alias_apps[$meta] + } +} + +unset filetypes meta format alias_apps +# }}} +# {{{ Font +# Shamelessly stolen from http://git.kitenet.net/?p=joey/home-etc;a=summary + +alias font-tiny='echo -en "\033]50;-misc-fixed-medium-r-normal--8-80-75-75-c-50-iso10646-1\007"' +alias font-small='echo -en "\033]50;6x10\007"' +alias font-default='echo -e "\033]50;-misc-fixed-medium-r-semicondensed--13-*-*-*-*-*-iso10646-1\007"' +alias font-medium='echo -en "\033]50;-misc-fixed-medium-r-normal--13-120-75-75-c-80-iso10646-1\007"' +alias font-large='echo -en "\033]50;-misc-fixed-medium-*-*-*-15-*-*-*-*-*-iso10646-1\007"' +alias font-larger='echo -en "\033]50;-misc-fixed-medium-r-normal--18-*-*-*-*-*-iso10646-1\007"' +alias font-huge='echo -en "\033]50;-misc-fixed-medium-r-normal--20-200-75-75-c-100-iso10646-1\007"' +# }}} +# {{{ Defaults +# evade them with '=foo' instead of 'foo' +## grep +linux: { + alias egrep='grep -E --color=auto' + alias fgrep='grep -F --color=auto' + alias grep='grep --color=auto' +} + + +## file and filesystem information +# human-readable sizes, local filesystems only +linux: alias df='df -hl --exclude-type=fuse.encfs' || + alias df='df -hl' + +# human-readable sizes, summarize, dereference args +linux: alias du='du -shD' || + alias du='du -shH' + +# human-readable sizes, mark executables with '*' etc. +linux: alias ls='ls -h --color=auto' || + alias ls='ls -Fh' + +## enable alias expansion +alias exec='exec ' +alias sudo='sudo ' + +## networking +alias mx='mx -aZ' + +# Only TCP/TCP6, not sockets and such +linux: salias netstat='netstat --program --all --tcp --extend' || + salias netstat='netstat -atp tcp' + + +# less frequent updates when running ncdu via ssh +[[ -n $SSH_CONNECTION ]] && check_com -c ncdu && alias ncdu='ncdu -q' + +alias bc='bc -l' + +alias cal='cal -m' +alias fbi='fbi -readahead' + +# I keep accidently overwriting files +alias cp='cp -i' +alias mv='mv -i' + +# no atime +alias pmount='pmount -A' + +# find does globbing itself +alias find='noglob find' + +# Show all available manuals (all sections) +alias man='man -a' + +# BSD style +alias ps='ps -F' + +# use unicode, reattach anyway, resize if neccessary +alias screen='tscreen -ADRUa' + +alias tilp='kdesudo "tilp --calc=ti84+ --cable=DirectLink"' + +# Don't collapse trees +alias todo='noglob todo -f +children' +# }}} +# {{{ Global +# global aliases are slightly evil, but (usually) not messy +alias -g EG='|egrep' +alias -g FG='|fgrep' +alias -g G='|grep' +alias -g H='|head' +alias -g L='|less' +alias -g T='|tail' +# }}} +# {{{ Loop me +alias allf='for i in *(.);' +alias alld='for i in *(/);' +alias alle='for i in *(*);' +alias alll='for i in *(@);' +alias all='for i in *;' + +alias allfr='for i in **/*(.);' +alias alldr='for i in **/*(/);' +alias aller='for i in **/*(*);' +alias alllr='for i in **/*(@);' +alias allr='for i in **/*;' +# }}} +# {{{ Short (similar to default options) +alias dua='du --apparent-size' + +alias lasth='last | head -$((LINES-1))' + +## fbi +alias fbif='fbi -a' +alias fbij='fbi -a -u' + +for i in ~/var/gtd/*(.N); { + alias gtd-${i:t}='todo --database '$i +} + +# File listings +alias lsi='feh --list' +alias lst='tar tvf' +alias lsz='unzip -l' + +alias nb='newsbeuter' +alias nbr='newsbeuter -r' + +alias rd='rmdir' + +alias rsync-serve="rsync --daemon --port=10873 --no-detach --config=/dev/stdin --log-file=/dev/stdout -v <<< $'[.]\n\tpath = .\n\tuse chroot = no'" + +## Suspend +salias s2d='s2disk' +salias s2r='s2ram -f' + +## Getränke +alias mate='decrement ~/stuff/$(cat ~/var/tmp/.actual-location)/mateguthaben' + +alias x='unsetopt bg_nice; startx &! exit' +# }}} + +if [[ $distro == debian ]] { #{{{ + # Search the packages list + alias acse='apt-cache search' + alias afse='apt-file search' + alias apse='aptitude search' + + # Show package information + alias acp='apt-cache policy' + alias acsh='apt-cache show' + alias afsh='apt-file show' + alias apsh='aptitude show' + alias dps='dpkg --status' + + # Update packages list + salias agu='apt-get update' + salias apu='aptitude update' + + # Update packages + salias ags='apt-get upgrade' + salias agf='apt-get dist-upgrade' + salias aps='aptitude safe-upgrade' + salias apf='aptitude full-upgrade' + + # Install packages + salias agi='apt-get install' + salias api='aptitude install' + salias dpi='dpkg --install' + + # Clean packages cache + salias agc='apt-get clean' + salias apc='aptitude clean' + + # Remove/Purge packages + salias agar='apt-get autoremove' + salias agp='apt-get purge' + salias agr='apt-get remove' + salias dpp='dpkg --purge' + salias dpr='dpkg --remove' + + # Get package source + alias agsrc='apt-get source' + + # Configure packages + salias dprc='dpkg-reconfigure' +} #}}} + +if [[ -e /tmp/.x-started ]] { #{{{ + # quiet and verbose can actually be used together here. + # quiet = suppress non-critical errors, verbose = show progress bars + alias feh='feh --quiet --verbose' + + # Alias structure: + # feh[theme][recursive?][slide-delay?] + # theme = [f]ullscreen | [i]ndex | [j]ust | [t]humbnail + # recursive: r for recursive, nothing otherwise + # slide-delay: + # none - no slideshow + # number - slideshow, $number seconds per image + # x - slideshow, seconds will be specified on commandline + # (like "fehfrx 7 .") + # the themes are defined in .fehrc + alias fehf='feh -Tfull' # Fullscreen + alias fehfr='feh -Tfull --recursive' + alias fehi='feh .fehindex.jpg' + alias fehj='feh -Tjust' # Screensaver-like + alias fehjr='feh -Tjust --recursive' + for i in {5,10,15,20}; { + alias fehj$i="feh -Tjust --slideshow-delay $i" + alias fehf$i="feh -Tfull --slideshow-delay $i" + alias fehjr$i="feh -Tjust --slideshow-delay $i --recursive" + alias fehfr$i="feh -Tfull --slideshow-delay $i --recursive" + } + alias fehjx='feh -Tjust --slideshow-delay' + alias fehfx='feh -Tfull --slideshow-delay' + alias fehjrx='feh -Tjust --recursive --slideshow-delay' + alias fehfrx='feh -Tfull --recursive --slideshow-delay' + alias feht='feh -Tthumbnail' # List thumbnails + alias fehtr='feh -Tthumbnail --recursive' + + # Automatically upload screenshot plzkthx + alias putscreen='put $(screenshot)' + + # Useful when a beamer is connected to my laptop + alias rplayer='mplayer -vo x11 -zoom -vf scale=1024:-2' + + # show current weather + alias weather='feh http://www.bredeney-wetter.de/aktuell.gif' +} #}}} + +# }}} + +# {{{ Misc +mesg n +if ((UID)) { + umask 077 +} else { + umask 002 +} +chpwd +# }}} + +# {{{ Includes +zrc_status include + +source $ZDIR/../provided/includes + +# local configuration, not in git +xsource $ZDIR/local + +check_com envstore && eval $(envstore eval) + +# local configuration, in git +xsource $ZDIR/hosts/$HOST +# }}} + +# {{{ Completion +zrc_status completion + +zstyle ':completion:*' cache-path $ZCACHEDIR +zstyle ':completion:*' use-cache true + +# Use ls-colors for file completion +zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS} + +# Mark the current selection when tabbing through possible completions +zstyle ':completion:*' menu select=1 + +# Complete uppercase names with lowercase and spaces with _ +zstyle ':completion:*' matcher-list '' 'm:{a-z}={A-Z} m:_=\\\ ' '+ l:|=* r:|=*' + +# Be verbose +zstyle ':completion:*' verbose true +zstyle ':completion:*:descriptions' format \ + "· %d ·" +zstyle ':completion:*:messages' format \ + "· %d ·" +zstyle ':completion:*:corrections' format \ + "· %d ·" +zstyle ':completion:*:warnings' format \ + "%F{red}no match:%F{default} %d" + +zstyle ':completion:*' group-name '' + +# Force menu completion since the input is just a stupid number +zstyle ':completion:*:*:kill:*' menu yes +zstyle ':completion:*:*:(todo|td*):*:items' menu yes + +zstyle ':completion:*:*:vi(m|):*' ignored-patterns \ + 'a.out|*.o' + +# fancy kill completion +# source: http://madism.org/~madcoder/dotfiles/zsh/40_completion +zstyle ':completion:*:processes' command 'ps -au$USER -o pid,time,cmd|grep -v "ps -au$USER -o pid,time,cmd"' +zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#)[ 0-9:]#([^ ]#)*=01;30=01;31=01;38' + +# separate manuals by sections +zstyle ':completion:*:manuals' separate-sections true +zstyle ':completion:*:manuals.*' insert-sections true + +# $hosts is set from the hosts package +zstyle ':completion:*' hosts ${(k)hosts} + +compinit -C -d $compdump + +compdef _hosts sshmount +compdef _functions reload + +# }}} + +# {{{ Cleanup +echo -n "\r\e[2K" +unalias 'linux:' +unalias 'openbsd:' +unfunction zrc_status zrc_info +unfunction xsource +unset system distro +unset -m 'mime_*' +# }}} diff --git a/etc/rc_status b/etc/rc_status deleted file mode 100644 index 0ff7193..0000000 --- a/etc/rc_status +++ /dev/null @@ -1,7 +0,0 @@ -## vim:ft=zsh -function zrc_status { - echo -n "\r\e[2K\e[0;36m䷢\e[0m $*" -} -function zrc_info { - echo "\e[0;36mℹ\e[0m $*" -} diff --git a/etc/zle b/etc/zle deleted file mode 100644 index f0fb108..0000000 --- a/etc/zle +++ /dev/null @@ -1,8 +0,0 @@ -## vim:ft=zsh -autoload -U url-quote-magic -zle -N self-insert url-quote-magic - -autoload predict-on -zle -N predict-on -zle -N predict-off -zstyle ':predict' verbose true -- cgit v1.2.3