Update debbug()
[grml-etc-core.git] / etc / skel / .zshrc
index 187e254..e722f76 100644 (file)
@@ -3,68 +3,73 @@
 # Authors:       grml-team (grml.org), (c) Michael Prokop <mika@grml.org>
 # Bug-Reports:   see http://grml.org/bugs/
 # License:       This file is licensed under the GPL v2.
-# Latest change: Don Mai 31 17:19:00 CEST 2007 [mika]
+# Latest change: Son Dez 09 22:58:07 CET 2007 [mika]
 ################################################################################
 
 # source ~/.zshrc.global {{{
+
 # see /etc/zsh/zshrc for some general settings
 # If you don't have write permissions to /etc/zsh/zshrc on your own
 # copy the file to your $HOME as /.zshrc.global and we source it:
-  if [ -r ~/.zshrc.global ] ; then
-     . ~/.zshrc.global
-  fi
+
+# Note, that xsource() is defined in the global file, so here,
+# we will have to do the sourcing manually for once:
+
+[[ -z "$ZSHRC_GLOBAL_HAS_BEEN_READ" ]]  \
+&& [[ -r "${HOME}/.zshrc.global" ]]     \
+&& source "${HOME}/.zshrc.global"
 # }}}
 
 # check whether global file has been read {{{
-  if [ -z "$ZSHRC_GLOBAL_HAS_BEEN_READ" ] ; then
-     print 'Warning: global zsh config has not been read'>&2
-  fi
+if [[ -z "$ZSHRC_GLOBAL_HAS_BEEN_READ" ]] ; then
+    print 'Warning: global zsh config has not been read.' >&2
+    print '         prepare for possible errors!'         >&2
+fi
 # }}}
 
 # autoloading stuff {{{
 # associate types and extensions (be aware with perl scripts and anwanted behaviour!)
-#  type zsh-mime-setup &>/dev/null || { autoload zsh-mime-setup && zsh-mime-setup }
+#  check_com zsh-mime-setup || { autoload zsh-mime-setup && zsh-mime-setup }
 #  alias -s pl='perl -S'
 # }}}
 
 # completion system {{{
 # just make sure it is loaded in this file too
-  type compinit &>/dev/null || { autoload -U compinit && compinit }
+check_com compinit || { autoload -U compinit && compinit }
 # }}}
 
 # make sure isgrmlsmall is defined {{{
-  type isgrmlsmall &>/dev/null || function isgrmlsmall () { return 1 }
+check_com isgrmlsmall || function isgrmlsmall () { return 1 }
 # }}}
 
 ## variables {{{
 
 # do you want grmlsmall-specific adjustments?
-  GRMLSMALL_SPECIFIC=1
+GRMLSMALL_SPECIFIC=1
 
 # set terminal property (used e.g. by msgid-chooser)
-  export COLORTERM="yes"
+export COLORTERM="yes"
 
 # set default browser
-  if [ -z "$BROWSER" ] ; then
-     if [ -n "$DISPLAY" ] ; then
+if [[ -z "$BROWSER" ]] ; then
+    if [[ -n "$DISPLAY" ]] ; then
         #v# If X11 is running
-        [ -x $(which firefox) ] && export BROWSER=firefox
-     else
+        check_com -c firefox && export BROWSER=firefox
+    else
         #v# If no X11 is running
-        [ -x $(which w3m) ] && export BROWSER=w3m
-     fi
-  fi
-  #v#
-  (( ${+PAGER} ))   || export PAGER="less"
+        check_com -c w3m && export BROWSER=w3m
+    fi
+fi
+#v#
+(( ${+PAGER} )) || export PAGER="less"
 
-# export qtdir
-  #m# v QTDIR \kbd{/usr/share/qt[34]}\quad [for non-root only]
-  [ -d /usr/share/qt3 ] && export QTDIR=/usr/share/qt3
-  [ -d /usr/share/qt4 ] && export QTDIR=/usr/share/qt4
+#m# v QTDIR \kbd{/usr/share/qt[34]}\quad [for non-root only]
+[[ -d /usr/share/qt3 ]] && export QTDIR=/usr/share/qt3
+[[ -d /usr/share/qt4 ]] && export QTDIR=/usr/share/qt4
 
 # support running 'jikes *.java && jamvm HelloWorld' OOTB:
-  #v# [for non-root only]
-  [ -f /usr/share/classpath/glibj.zip ] && export JIKESPATH=/usr/share/classpath/glibj.zip
+#v# [for non-root only]
+[[ -f /usr/share/classpath/glibj.zip ]] && export JIKESPATH=/usr/share/classpath/glibj.zip
 # }}}
 
 ## set options {{{
 
 # Xterm resizing-fu.
 # Based on http://svn.kitenet.net/trunk/home-full/.zshrc?rev=11710&view=log (by Joey Hess)
-  alias hide='echo -en "\033]50;nil2\007"'
-  alias tiny='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-80-*-*-c-*-iso8859-15\007"'
-  alias small='echo -en "\033]50;6x10\007"'
-  alias medium='echo -en "\033]50;-misc-fixed-medium-r-normal--13-120-75-75-c-80-iso8859-15\007"'
-  alias default='echo -e "\033]50;-misc-fixed-medium-r-normal-*-*-140-*-*-c-*-iso8859-15\007"'
-  alias large='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-150-*-*-c-*-iso8859-15\007"'
-  alias huge='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-210-*-*-c-*-iso8859-15\007"'
-  alias smartfont='echo -en "\033]50;-artwiz-smoothansi-*-*-*-*-*-*-*-*-*-*-*-*\007"'
-  alias semifont='echo -en "\033]50;-misc-fixed-medium-r-semicondensed-*-*-120-*-*-*-*-iso8859-15\007"'
-#  if [ "$TERM" = "xterm" ] && [ "$LINES" -ge 50 ] && [ "$COLUMNS" -ge 100 ] && [ -z "$SSH_CONNECTION" ]; then
+alias hide='echo -en "\033]50;nil2\007"'
+alias tiny='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-80-*-*-c-*-iso8859-15\007"'
+alias small='echo -en "\033]50;6x10\007"'
+alias medium='echo -en "\033]50;-misc-fixed-medium-r-normal--13-120-75-75-c-80-iso8859-15\007"'
+alias default='echo -e "\033]50;-misc-fixed-medium-r-normal-*-*-140-*-*-c-*-iso8859-15\007"'
+alias large='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-150-*-*-c-*-iso8859-15\007"'
+alias huge='echo -en "\033]50;-misc-fixed-medium-r-normal-*-*-210-*-*-c-*-iso8859-15\007"'
+alias smartfont='echo -en "\033]50;-artwiz-smoothansi-*-*-*-*-*-*-*-*-*-*-*-*\007"'
+alias semifont='echo -en "\033]50;-misc-fixed-medium-r-semicondensed-*-*-120-*-*-*-*-iso8859-15\007"'
+#  if [[ "$TERM" == "xterm" ]] && [[ "$LINES" -ge 50 ]] && [[ "$COLUMNS" -ge 100 ]] && [[ -z "$SSH_CONNECTION" ]] ; then
 #          large
 #  fi
 
 # general
-  #a2# Execute \kbd{du -sch}
-  alias da='du -sch'
-  #a2# Execute \kbd{jobs -l}
-  alias j='jobs -l'
+#a2# Execute \kbd{du -sch}
+alias da='du -sch'
+#a2# Execute \kbd{jobs -l}
+alias j='jobs -l'
 #  alias u='translate -i'          # translate
 
 # compile stuff
-  #a2# Execute \kbd{./configure}
-  alias CO="./configure"
-  #a2# Execute \kbd{./configure --help}
-  alias CH="./configure --help"
+#a2# Execute \kbd{./configure}
+alias CO="./configure"
+#a2# Execute \kbd{./configure --help}
+alias CH="./configure --help"
 
 # http://conkeror.mozdev.org/
-  #a2# Run a keyboard driven firefox
-  alias conkeror='firefox -chrome chrome://conkeror/content'
+#a2# Run a keyboard driven firefox
+alias conkeror='firefox -chrome chrome://conkeror/content'
 
 # arch/tla stuff
-  if type -p tla &>/dev/null ; then
-     #a2# Execute \kbd{tla what-changed --diffs | less}
-     alias tdi='tla what-changed --diffs | less'
-     #a2# Execute \kbd{tla-buildpackage}
-     alias tbp='tla-buildpackage'
-     #a2# Execute \kbd{tla archive-mirror}
-     alias tmi='tla archive-mirror'
-     #a2# Execute \kbd{tla commit}
-     alias tco='tla commit'
-     #a2# Execute \kbd{tla star-merge}
-     alias tme='tla star-merge'
-  fi
+if check_com -c tla ; then
+    #a2# Execute \kbd{tla what-changed --diffs | less}
+    alias tdi='tla what-changed --diffs | less'
+    #a2# Execute \kbd{tla-buildpackage}
+    alias tbp='tla-buildpackage'
+    #a2# Execute \kbd{tla archive-mirror}
+    alias tmi='tla archive-mirror'
+    #a2# Execute \kbd{tla commit}
+    alias tco='tla commit'
+    #a2# Execute \kbd{tla star-merge}
+    alias tme='tla star-merge'
+fi
 
 # listing stuff
-  #a2# Execute \kbd{ls -lSrah}
-  alias dir="ls -lSrah"
-  #a2# Only show dot-directories
-  alias lad='ls -d .*(/)'                # only show dot-directories
-  #a2# Only show dot-files
-  alias lsa='ls -a .*(.)'                # only show dot-files
-  #a2# Only files with setgid/setuid/sticky flag
-  alias lss='ls -l *(s,S,t)'             # only files with setgid/setuid/sticky flag
-  #a2# Only show 1st ten symlinks
-  alias lsl='ls -l *(@[1,10])'           # only symlinks
-  #a2# Display only executables
-  alias lsx='ls -l *(*[1,10])'           # only executables
-  #a2# Display world-{readable,writable,executable} files
-  alias lsw='ls -ld *(R,W,X.^ND/)'       # world-{readable,writable,executable} files
-  #a2# Display the ten biggest files
-  alias lsbig="ls -flh *(.OL[1,10])"     # display the biggest files
-  #a2# Only show directories
-  alias lsd='ls -d *(/)'                 # only show directories
-  #a2# Only show empty directories
-  alias lse='ls -d *(/^F)'               # only show empty directories
-  #a2# Display the ten newest files
-  alias lsnew="ls -rl *(D.om[1,10])"     # display the newest files
-  #a2# Display the ten oldest files
-  alias lsold="ls -rtlh *(D.om[1,10])"   # display the oldest files
-  #a2# Display the ten smallest files
-  alias lssmall="ls -Srl *(.oL[1,10])"   # display the smallest files
+#a2# Execute \kbd{ls -lSrah}
+alias dir="ls -lSrah"
+#a2# Only show dot-directories
+alias lad='ls -d .*(/)'                # only show dot-directories
+#a2# Only show dot-files
+alias lsa='ls -a .*(.)'                # only show dot-files
+#a2# Only files with setgid/setuid/sticky flag
+alias lss='ls -l *(s,S,t)'             # only files with setgid/setuid/sticky flag
+#a2# Only show 1st ten symlinks
+alias lsl='ls -l *(@[1,10])'           # only symlinks
+#a2# Display only executables
+alias lsx='ls -l *(*[1,10])'           # only executables
+#a2# Display world-{readable,writable,executable} files
+alias lsw='ls -ld *(R,W,X.^ND/)'       # world-{readable,writable,executable} files
+#a2# Display the ten biggest files
+alias lsbig="ls -flh *(.OL[1,10])"     # display the biggest files
+#a2# Only show directories
+alias lsd='ls -d *(/)'                 # only show directories
+#a2# Only show empty directories
+alias lse='ls -d *(/^F)'               # only show empty directories
+#a2# Display the ten newest files
+alias lsnew="ls -rl *(D.om[1,10])"     # display the newest files
+#a2# Display the ten oldest files
+alias lsold="ls -rtlh *(D.om[1,10])"   # display the oldest files
+#a2# Display the ten smallest files
+alias lssmall="ls -Srl *(.oL[1,10])"   # display the smallest files
 
 # chmod
-  #a2# Execute \kbd{chmod 600}
-  alias rw-='chmod 600'
-  #a2# Execute \kbd{chmod 700}
-  alias rwx='chmod 700'
-  #m# a2 r-{}- Execute \kbd{chmod 644}
-  alias r--='chmod 644'
-  #a2# Execute \kbd{chmod 755}
-  alias r-x='chmod 755'
+#a2# Execute \kbd{chmod 600}
+alias rw-='chmod 600'
+#a2# Execute \kbd{chmod 700}
+alias rwx='chmod 700'
+#m# a2 r-{}- Execute \kbd{chmod 644}
+alias r--='chmod 644'
+#a2# Execute \kbd{chmod 755}
+alias r-x='chmod 755'
 
 # some useful aliases
-  #a2# Execute \kbd{mkdir -o}
-  alias md='mkdir -p'
+#a2# Execute \kbd{mkdir -o}
+alias md='mkdir -p'
 
-  [ -x $(which ipython) ] && alias ips='ipython -p sh'
+check_com -c ipython && alias ips='ipython -p sh'
 
 # console stuff
-  #a2# Execute \kbd{mplayer -vo fbdev}
-  alias cmplayer='mplayer -vo fbdev'
-  #a2# Execute \kbd{mplayer -vo fbdev -fs -zoom}
-  alias fbmplayer='mplayer -vo fbdev -fs -zoom'
-  #a2# Execute \kbd{links2 -driver fb}
-  alias fblinks='links2 -driver fb'
+#a2# Execute \kbd{mplayer -vo fbdev}
+alias cmplayer='mplayer -vo fbdev'
+#a2# Execute \kbd{mplayer -vo fbdev -fs -zoom}
+alias fbmplayer='mplayer -vo fbdev -fs -zoom'
+#a2# Execute \kbd{links2 -driver fb}
+alias fblinks='links2 -driver fb'
 
 # ignore ~/.ssh/known_hosts entries
 #  alias insecssh='ssh -o "StrictHostKeyChecking=no" -o "UserKnownHostsFile=/dev/null" -o "PreferredAuthentications=keyboard-interactive"'
-  #a2# ssh with StrictHostKeyChecking=no \\&\quad and UserKnownHostsFile unset
-  alias insecssh='ssh -o "StrictHostKeyChecking=no" -o "UserKnownHostsFile=/dev/null"'
-  alias insecscp='scp -o "StrictHostKeyChecking=no" -o "UserKnownHostsFile=/dev/null"'
+#a2# ssh with StrictHostKeyChecking=no \\&\quad and UserKnownHostsFile unset
+alias insecssh='ssh -o "StrictHostKeyChecking=no" -o "UserKnownHostsFile=/dev/null"'
+alias insecscp='scp -o "StrictHostKeyChecking=no" -o "UserKnownHostsFile=/dev/null"'
 
-# use colors when browsing man pages (if not using pinfo or PAGER=most)
-  [ -d ~/.terminfo/ ] && alias man='TERMINFO=~/.terminfo/ LESS=C TERM=mostlike PAGER=less man'
+# Use 'g' instead of 'git':
+check_com g || alias g='git'
+
+# use colors when browsing man pages, but only if not using LESS_TERMCAP_* from /etc/zsh/zshenv:
+if [[ -z "$LESS_TERMCAP_md" ]] ; then
+    [[ -d ~/.terminfo/ ]] && alias man='TERMINFO=~/.terminfo/ LESS=C TERM=mostlike PAGER=less man'
+fi
 
 # check whether Debian's package management (dpkg) is running
-  if type salias &>/dev/null ; then
+if check_com salias ; then
     #a2# Check whether a dpkg instance is currently running
     salias check_dpkg_running="dpkg_running"
-  fi
-
-# work around non utf8 capable software in utf environment
-  if type isutfenv &>/dev/null ; then
-     if [ -x $(which mrxvt) ] ; then
-        isutfenv && [ -n "$LANG" ] && alias mrxvt="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} mrxvt"
-     fi
-
-     if [ -x $(which aterm) ] ; then
-        isutfenv && [ -n "$LANG" ] && alias aterm="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} aterm"
-     fi
-
-     if [ -x $(which centericq) ] ; then
-        isutfenv && [ -n "$LANG" ] && alias centericq="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} centericq"
-     fi
-  fi
+fi
+
+# work around non utf8 capable software in utf environment via $LANG and luit
+if check_com isutfenv && check_com luit ; then
+    if check_com -c mrxvt ; then
+        isutfenv && [[ -n "$LANG" ]] && \
+            alias mrxvt="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} luit mrxvt"
+    fi
+
+    if check_com -c aterm ; then
+        isutfenv && [[ -n "$LANG" ]] && \
+            alias aterm="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} luit aterm"
+    fi
+
+    if check_com -c centericq ; then
+        isutfenv && [[ -n "$LANG" ]] && \
+            alias centericq="LANG=${LANG/(#b)(*)[.@]*/$match[1].iso885915} luit centericq"
+    fi
+fi
 # }}}
 
 ## useful functions {{{
 
 # searching
-  #f4# Search for newspostings from authors
-  agoogle() { ${=BROWSER} "http://groups.google.com/groups?as_uauthors=$*" ; }
-  #f4# Search Debian Bug Tracking System by BugID in mbox format
-  debbug()  { ${=BROWSER} "http://bugs.debian.org/$*" }
-  #f4# Search Debian Bug Tracking System
-  debbugm() { bts show --mbox $1 } # provide bugnummer as "$1"
-  #f4# Search DMOZ
-  dmoz()    { ${=BROWSER} http://search.dmoz.org/cgi-bin/search\?search=${1// /_} }
-  #f4# Search German   Wiktionary
-  dwicti()  { ${=BROWSER} http://de.wiktionary.org/wiki/${(C)1// /_} }
-  #f4# Search English  Wiktionary
-  ewicti()  { ${=BROWSER} http://en.wiktionary.org/wiki/${(C)1// /_} }
-  #f4# Search Google Groups
-  ggogle()  { ${=BROWSER} "http://groups.google.com/groups?q=$*" }
-  #f4# Search Google
-  google()  { ${=BROWSER} "http://www.google.com/search?&num=100&q=$*" }
-  #f4# Search Google Groups for MsgID
-  mggogle() { ${=BROWSER} "http://groups.google.com/groups?selm=$*" }
-  #f4# Search Netcraft
-  netcraft(){ ${=BROWSER} "http://toolbar.netcraft.com/site_report?url=$1" }
-  #f4# Use German Wikipedia's full text search
-  swiki()   { ${=BROWSER} http://de.wikipedia.org/wiki/Spezial:Search/${(C)1} }
-  #f4# search \kbd{dict.leo.org}
-  oleo()    { ${=BROWSER} "http://dict.leo.org/?search=$*" }
-  #f4# Search German   Wikipedia
-  wikide () { ${=BROWSER} http://de.wikipedia.org/wiki/"${(C)*}" }
-  #f4# Search English  Wikipedia
-  wikien()  { ${=BROWSER} http://en.wikipedia.org/wiki/"$*" }
-  #f4# Search official debs
-  wodeb ()  { ${=BROWSER} "http://packages.debian.org/cgi-bin/search_contents.pl?word=$1&version=${2:-unstable}" }
-  #m# f4 gex() Exact search via Google
-  which google &>/dev/null && gex () { google "\"[ $1]\" $*" } # exact search at google
+#f4# Search for newspostings from authors
+agoogle() { ${=BROWSER} "http://groups.google.com/groups?as_uauthors=$*" ; }
+#f4# Search Debian Bug Tracking System by BugID in mbox format
+debbug()  { 
+    setopt localoptions extendedglob
+    if [[ $# -eq 1 ]]; then
+        case "$1" in
+            ([0-9]##)
+            ${=BROWSER} "http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=$1"
+            ;;
+            (*@*)
+            ${=BROWSER} "http://bugs.debian.org/cgi-bin/pkgreport.cgi?submitter=$1"
+            ;;
+            (*)
+            ${=BROWSER} "http://bugs.debian.org/$*"
+            ;;
+        esac
+    else
+        print "$0 needs one argument"
+        return 1
+    fi
+}
+#f4# Search Debian Bug Tracking System
+debbugm() { bts show --mbox $1 } # provide bugnummer as "$1"
+#f4# Search DMOZ
+dmoz()    { ${=BROWSER} http://search.dmoz.org/cgi-bin/search\?search=${1// /_} }
+#f4# Search German   Wiktionary
+dwicti()  { ${=BROWSER} http://de.wiktionary.org/wiki/${(C)1// /_} }
+#f4# Search English  Wiktionary
+ewicti()  { ${=BROWSER} http://en.wiktionary.org/wiki/${(C)1// /_} }
+#f4# Search Google Groups
+ggogle()  { ${=BROWSER} "http://groups.google.com/groups?q=$*" }
+#f4# Search Google
+google()  { ${=BROWSER} "http://www.google.com/search?&num=100&q=$*" }
+#f4# Search Google Groups for MsgID
+mggogle() { ${=BROWSER} "http://groups.google.com/groups?selm=$*" }
+#f4# Search Netcraft
+netcraft(){ ${=BROWSER} "http://toolbar.netcraft.com/site_report?url=$1" }
+#f4# Use German Wikipedia's full text search
+swiki()   { ${=BROWSER} http://de.wikipedia.org/wiki/Spezial:Search/${(C)1} }
+#f4# search \kbd{dict.leo.org}
+oleo()    { ${=BROWSER} "http://dict.leo.org/?search=$*" }
+#f4# Search German   Wikipedia
+wikide()  { ${=BROWSER} http://de.wikipedia.org/wiki/"${(C)*}" }
+#f4# Search English  Wikipedia
+wikien()  { ${=BROWSER} http://en.wikipedia.org/wiki/"${(C)*}" }
+#f4# Search official debs
+wodeb()   { ${=BROWSER} "http://packages.debian.org/search?keywords=$1&searchon=contents&suite=${2:=unstable}&section=all" }
+
+#m# f4 gex() Exact search via Google
+check_com google && gex () { google "\"[ $1]\" $*" } # exact search at google
 
 # misc
-  #f5# Backup \kbd{file {\rm to} file\_timestamp}
-  bk()      { cp -b ${1} ${1}_`date --iso-8601=m` }
-  #f5# Copied diff
-  cdiff()   { diff -crd "$*" | egrep -v "^Only in |^Binary files " }
-  #f5# cd to directoy and list files
-  cl()      { cd $1 && ls -a }        # cd && ls
-  #f5# Cvs add
-  cvsa()    { cvs add $* && cvs com -m 'initial checkin' $* }
-  #f5# Cvs diff
-  cvsd()    { cvs diff -N $* |& $PAGER }
-  #f5# Cvs log
-  cvsl()    { cvs log $* |& $PAGER }
-  #f5# Cvs update
-  cvsq()    { cvs -nq update }
-  #f5# Rcs2log
-  cvsr()    { rcs2log $* | $PAGER }
-  #f5# Cvs status
-  cvss()    { cvs status -v $* }
-  #f5# Disassemble source files using gcc and as
-  disassemble(){ gcc -pipe -S -o - -O -g $* | as -aldh -o /dev/null }
-  #f5# Firefox remote control - open given URL
-  fir()     { firefox -a firefox -remote "openURL($1)" }
-  #f5# Create Directoy and \kbd{cd} to it
-  mcd()     { mkdir -p "$@"; cd "$@" } # mkdir && cd
-  #f5# Unified diff to timestamped outputfile
-  mdiff()   { diff -udrP "$1" "$2" > diff.`date "+%Y-%m-%d"`."$1" }
-  #f5# Memory overview
-  memusage(){ ps aux | awk '{if (NR > 1) print $5; if (NR > 2) print "+"} END { print "p" }' | dc }
-  #f5# Show contents of tar file
-  shtar()   { gunzip -c $1 | tar -tf - -- | $PAGER }
-  #f5# Show contents of tgz file
-  shtgz()   { tar -ztf $1 | $PAGER }
-  #f5# Show contents of zip file
-  shzip()   { unzip -l $1 | $PAGER }
-  #f5# Greps signature from file
-  sig()     { agrep -d '^-- $' "$*" ~/.Signature }
-  #f5# Unified diff
-  udiff()   { diff -urd $* | egrep -v "^Only in |^Binary files " }
-  #f5# (Mis)use \kbd{vim} as \kbd{less}
-  viless()  { vim --cmd 'let no_plugin_maps = 1' -c "so \$VIMRUNTIME/macros/less.vim" "${@:--}" }
-
-  # download video from youtube
-  ytdl() {
-    if ! [ -n "$2" ] ; then
-       print "Usage: ydtl http://youtube.com/watch?v=.... outputfile.flv">&2
-       return 1
+#f5# Backup \kbd{file {\rm to} file\_timestamp}
+bk()      { cp -b ${1} ${1}_`date --iso-8601=m` }
+#f5# Copied diff
+cdiff()   { diff -crd "$*" | egrep -v "^Only in |^Binary files " }
+#f5# cd to directoy and list files
+cl()      { cd $1 && ls -a }        # cd && ls
+#f5# Cvs add
+cvsa()    { cvs add $* && cvs com -m 'initial checkin' $* }
+#f5# Cvs diff
+cvsd()    { cvs diff -N $* |& $PAGER }
+#f5# Cvs log
+cvsl()    { cvs log $* |& $PAGER }
+#f5# Cvs update
+cvsq()    { cvs -nq update }
+#f5# Rcs2log
+cvsr()    { rcs2log $* | $PAGER }
+#f5# Cvs status
+cvss()    { cvs status -v $* }
+#f5# Disassemble source files using gcc and as
+disassemble(){ gcc -pipe -S -o - -O -g $* | as -aldh -o /dev/null }
+#f5# Firefox remote control - open given URL
+fir()     { firefox -a firefox -remote "openURL($1)" }
+#f5# Create Directoy and \kbd{cd} to it
+mcd()     { mkdir -p "$@"; cd "$@" } # mkdir && cd
+#f5# Unified diff to timestamped outputfile
+mdiff()   { diff -udrP "$1" "$2" > diff.`date "+%Y-%m-%d"`."$1" }
+#f5# Memory overview
+memusage(){ ps aux | awk '{if (NR > 1) print $5; if (NR > 2) print "+"} END { print "p" }' | dc }
+#f5# Show contents of tar file
+shtar()   { gunzip -c $1 | tar -tf - -- | $PAGER }
+#f5# Show contents of tgz file
+shtgz()   { tar -ztf $1 | $PAGER }
+#f5# Show contents of zip file
+shzip()   { unzip -l $1 | $PAGER }
+#f5# Greps signature from file
+sig()     { agrep -d '^-- $' "$*" ~/.Signature }
+#f5# Unified diff
+udiff()   { diff -urd $* | egrep -v "^Only in |^Binary files " }
+#f5# (Mis)use \kbd{vim} as \kbd{less}
+viless()  { vim --cmd 'let no_plugin_maps = 1' -c "so \$VIMRUNTIME/macros/less.vim" "${@:--}" }
+
+# download video from youtube
+ytdl() {
+    if ! [[ -n "$2" ]] ; then
+        print "Usage: ydtl http://youtube.com/watch?v=.... outputfile.flv">&2
+        return 1
     else
-       wget -O${2} "http://youtube.com/get_video?"${${${"$(wget -o/dev/null -O- "${1}" | grep -e watch_fullscreen)"}##*watch_fullscreen\?}%%\&fs=*}
+        wget -O${2} "http://youtube.com/get_video?"${${${"$(wget -o/dev/null -O- "${1}" | grep -e watch_fullscreen)"}##*watch_fullscreen\?}%%\&fs=*}
     fi
-  }
+}
 
 
 # Function Usage: doc packagename
-  #f5# \kbd{cd} to /usr/share/doc/\textit{package}
-  doc() { cd /usr/share/doc/$1 && ls }
-  _doc() { _files -W /usr/share/doc -/ }
-  type compdef &>/dev/null && compdef _doc doc
+#f5# \kbd{cd} to /usr/share/doc/\textit{package}
+doc() { cd /usr/share/doc/$1 && ls }
+_doc() { _files -W /usr/share/doc -/ }
+check_com compdef && compdef _doc doc
 
 #f5# Make screenshot
-  sshot() {
-        [[ ! -d ~/shots  ]] && mkdir ~/shots
-        #cd ~/shots ; sleep 5 ; import -window root -depth 8 -quality 80 `date "+%Y-%m-%d--%H:%M:%S"`.png
-        cd ~/shots ; sleep 5; import -window root shot_`date --iso-8601=m`.jpg
-  }
+sshot() {
+    [[ ! -d ~/shots  ]] && mkdir ~/shots
+    #cd ~/shots ; sleep 5 ; import -window root -depth 8 -quality 80 `date "+%Y-%m-%d--%H:%M:%S"`.png
+    cd ~/shots ; sleep 5; import -window root shot_`date --iso-8601=m`.jpg
+}
 
 # list images only
-  limg() {
+limg() {
     local -a images
     images=( *.{jpg,gif,png}(.N) )
+
     if [[ $#images -eq 0 ]] ; then
-      print "No image files found"
+        print "No image files found"
     else
-      ls "$@" "$images[@]"
+        ls "$@" "$images[@]"
     fi
-  }
+}
 
 #f5# Create PDF file from source code
-  makereadable() {
-     output=$1
-     shift
-     a2ps --medium A4dj -E -o $output $*
-     ps2pdf $output
-  }
+makereadable() {
+    output=$1
+    shift
+    a2ps --medium A4dj -E -o $output $*
+    ps2pdf $output
+}
 
 # zsh with perl-regex - use it e.g. via:
 # regcheck '\s\d\.\d{3}\.\d{3} Euro' ' 1.000.000 Euro'
 #f5# Checks whether a regex matches or not.\\&\quad Example: \kbd{regcheck '.\{3\} EUR' '500 EUR'}
-  regcheck() {
+regcheck() {
     zmodload -i zsh/pcre
     pcre_compile $1 && \
     pcre_match $2 && echo "regex matches" || echo "regex does not match"
-  }
+}
 
 #f5# List files which have been modified within the last {\it n} days
-  new() { print -l *(m-$1) }
+new() { print -l *(m-$1) }
 
 #f5# Grep in history
-  greph () { history 0 | grep $1 }
-  # use colors when GNU grep with color-support
-  #a2# Execute \kbd{grep -{}-color=auto}
-  (grep --help 2>/dev/null |grep -- --color) >/dev/null && alias grep='grep --color=auto'
-  #a2# Execute \kbd{grep -i -{}-color=auto}
-  alias GREP='grep -i --color=auto'
+greph() { history 0 | grep $1 }
+# use colors when GNU grep with color-support
+#a2# Execute \kbd{grep -{}-color=auto}
+(grep --help 2>/dev/null |grep -- --color) >/dev/null && alias grep='grep --color=auto'
+#a2# Execute \kbd{grep -i -{}-color=auto}
+alias GREP='grep -i --color=auto'
 
 # one blank line between each line
-  if [ -r ~/.terminfo/m/mostlike ] ; then
-#     alias man2='MANPAGER="sed -e G |less" TERMINFO=~/.terminfo TERM=mostlike /usr/bin/man'
-     #f5# Watch manpages in a stretched style
-     man2() { PAGER='dash -c "sed G | /usr/bin/less"' TERM=mostlike /usr/bin/man "$@" ; }
-  fi
-
-# jump between directories
-# Copyright 2005 Nikolai Weibull <nikolai@bitwi.se>
+if [[ -r ~/.terminfo/m/mostlike ]] ; then
+#   alias man2='MANPAGER="sed -e G |less" TERMINFO=~/.terminfo TERM=mostlike /usr/bin/man'
+    #f5# Watch manpages in a stretched style
+    man2() { PAGER='dash -c "sed G | /usr/bin/less"' TERM=mostlike /usr/bin/man "$@" ; }
+fi
+
+# d():Copyright 2005 Nikolai Weibull <nikolai@bitwi.se>
 # notice: option AUTO_PUSHD has to be set
-  #f5# Jump between directories
-  d(){
+#f5# Jump between directories
+d() {
     emulate -L zsh
     autoload -U colors
     local color=$fg_bold[blue]
     integer i=0
     dirs -p | while read dir; do
-      local num="${$(printf "%-4d " $i)/ /.}"
-      printf " %s  $color%s$reset_color\n" $num $dir
-      (( i++ ))
+        local num="${$(printf "%-4d " $i)/ /.}"
+        printf " %s  $color%s$reset_color\n" $num $dir
+        (( i++ ))
     done
     integer dir=-1
     read -r 'dir?Jump to directory: ' || return
     (( dir == -1 )) && return
     if (( dir < 0 || dir >= i )); then
-      echo d: no such directory stack entry: $dir
-      return 1
+        echo d: no such directory stack entry: $dir
+        return 1
     fi
     cd ~$dir
-  }
+}
 
 # usage example: 'lcheck strcpy'
 #f5# Find out which libs define a symbol
-  lcheck() {
-     if [ -n "$1" ] ; then
+lcheck() {
+    if [[ -n "$1" ]] ; then
         nm -go /usr/lib/lib*.a 2>/dev/null | grep ":[[:xdigit:]]\{8\} . .*$1"
-      else
+    else
         echo "Usage: lcheck <function>" >&2
-     fi
-  }
+    fi
+}
 
 #f5# Clean up directory - remove well known tempfiles
-  purge() {
-        FILES=(*~(N) .*~(N) \#*\#(N) *.o(N) a.out(N) *.core(N) *.cmo(N) *.cmi(N) .*.swp(N))
-        NBFILES=${#FILES}
-        if [[ $NBFILES > 0 ]]; then
-                print $FILES
-                local ans
-                echo -n "Remove these files? [y/n] "
-                read -q ans
-                if [[ $ans == "y" ]]
-                then
-                        rm ${FILES}
-                        echo ">> $PWD purged, $NBFILES files removed"
-                else
-                        echo "Ok. .. than not.."
-                fi
+purge() {
+    FILES=(*~(N) .*~(N) \#*\#(N) *.o(N) a.out(N) *.core(N) *.cmo(N) *.cmi(N) .*.swp(N))
+    NBFILES=${#FILES}
+    if [[ $NBFILES > 0 ]] ; then
+        print $FILES
+        local ans
+        echo -n "Remove these files? [y/n] "
+        read -q ans
+        if [[ $ans == "y" ]] ; then
+            rm ${FILES}
+            echo ">> $PWD purged, $NBFILES files removed"
+        else
+            echo "Ok. .. than not.."
         fi
-   }
+    fi
+}
 
 # Translate DE<=>EN
 # 'translate' looks up fot a word in a file with language-to-language
 #  $ awk -F ':' '{ print $2" : "$1" "$3 }' \
 #    /usr/local/lib/words/en-de.ISO-8859-1.vok > ~/.translate/de-en.ISO-8859-1.vok
 #f5# Translates a word
-  trans() {
-        case "$1" in
-                -[dD]*) translate -l de-en $2
-                ;;
-                -[eE]*) translate -l en-de $2
-                ;;
-                *)
-                echo "Usage: $0 { -D | -E }"
-                echo "         -D == German to English"
-                echo "         -E == English to German"
-        esac
-  }
+trans() {
+    case "$1" in
+        -[dD]*)
+            translate -l de-en $2
+            ;;
+        -[eE]*)
+            translate -l en-de $2
+            ;;
+        *)
+            echo "Usage: $0 { -D | -E }"
+            echo "         -D == German to English"
+            echo "         -E == English to German"
+    esac
+}
 
 # Some quick Perl-hacks aka /useful/ oneliner
 #  bew() { perl -le 'print unpack "B*","'$1'"' }
 #  vimhelp ()    { vim -c "help $1" -c on -c "au! VimEnter *" }
 
 #f5# List all occurrences of programm in current PATH
-  plap() {
-        if [[ $# = 0 ]]
-        then
-                echo "Usage:    $0 program"
-                echo "Example:  $0 zsh"
-                echo "Lists all occurrences of program in the current PATH."
-        else
-                ls -l ${^path}/*$1*(*N)
-        fi
-  }
+plap() {
+    if [[ $# = 0 ]] ; then
+        echo "Usage:    $0 program"
+        echo "Example:  $0 zsh"
+        echo "Lists all occurrences of program in the current PATH."
+    else
+        ls -l ${^path}/*$1*(*N)
+    fi
+}
 
 # Found in the mailinglistarchive from Zsh (IIRC ~1996)
 #f5# Select items for specific command(s) from history
-  selhist() {
-        emulate -L zsh
-        local TAB=$'\t';
-        (( $# < 1 )) && {
-                echo "Usage: $0 command"
-                return 1
-        };
-        cmd=(${(f)"$(grep -w $1 $HISTFILE | sort | uniq | pr -tn)"})
-        print -l $cmd | less -F
-        echo -n "enter number of desired command [1 - $(( ${#cmd[@]} - 1 ))]: "
-        local answer
-        read answer
-        print -z "${cmd[$answer]#*$TAB}"
-  }
+selhist() {
+    emulate -L zsh
+    local TAB=$'\t';
+    (( $# < 1 )) && {
+        echo "Usage: $0 command"
+        return 1
+    };
+    cmd=(${(f)"$(grep -w $1 $HISTFILE | sort | uniq | pr -tn)"})
+    print -l $cmd | less -F
+    echo -n "enter number of desired command [1 - $(( ${#cmd[@]} - 1 ))]: "
+    local answer
+    read answer
+    print -z "${cmd[$answer]#*$TAB}"
+}
 
 # Use vim to convert plaintext to HTML
-  #f5# Transform files to html with highlighting
-  2html() { vim -u NONE -n -c ':syntax on' -c ':so $VIMRUNTIME/syntax/2html.vim' -c ':wqa' $1 &>/dev/null }
+#f5# Transform files to html with highlighting
+2html() { vim -u NONE -n -c ':syntax on' -c ':so $VIMRUNTIME/syntax/2html.vim' -c ':wqa' $1 &>/dev/null }
 
 # Usage: simple-extract <file>
 #f5# Smart archive extractor
-  simple-extract () {
-        if [[ -f $1 ]]
-        then
-                case $1 in
-                        *.tar.bz2)  bzip2 -v -d $1      ;;
-                        *.tar.gz)   tar -xvzf $1        ;;
-                        *.rar)      unrar $1            ;;
-                        *.deb)      ar -x $1            ;;
-                        *.bz2)      bzip2 -d $1         ;;
-                        *.lzh)      lha x $1            ;;
-                        *.gz)       gunzip -d $1        ;;
-                        *.tar)      tar -xvf $1         ;;
-                        *.tgz)      gunzip -d $1        ;;
-                        *.tbz2)     tar -jxvf $1        ;;
-                        *.zip)      unzip $1            ;;
-                        *.Z)        uncompress $1       ;;
-                        *)          echo "'$1' Error. Please go away" ;;
-                esac
-        else
-                echo "'$1' is not a valid file"
-        fi
-  }
+simple-extract () {
+    if [[ -f $1 ]] ; then
+        case $1 in
+            *.tar.bz2)  bzip2 -v -d $1      ;;
+            *.tar.gz)   tar -xvzf $1        ;;
+            *.rar)      unrar $1            ;;
+            *.deb)      ar -x $1            ;;
+            *.bz2)      bzip2 -d $1         ;;
+            *.lzh)      lha x $1            ;;
+            *.gz)       gunzip -d $1        ;;
+            *.tar)      tar -xvf $1         ;;
+            *.tgz)      gunzip -d $1        ;;
+            *.tbz2)     tar -jxvf $1        ;;
+            *.zip)      unzip $1            ;;
+            *.Z)        uncompress $1       ;;
+            *)          echo "'$1' Error. Please go away" ;;
+        esac
+    else
+        echo "'$1' is not a valid file"
+    fi
+}
 
 # Usage: smartcompress <file> (<type>)
 #f5# Smart archive creator
-  smartcompress() {
-        if [ $2 ]; then
-                case $2 in
-                        tgz | tar.gz)   tar -zcvf$1.$2 $1 ;;
-                        tbz2 | tar.bz2) tar -jcvf$1.$2 $1 ;;
-                        tar.Z)          tar -Zcvf$1.$2 $1 ;;
-                        tar)            tar -cvf$1.$2  $1 ;;
-                        gz | gzip)      gzip           $1 ;;
-                        bz2 | bzip2)    bzip2          $1 ;;
-                        *)
-                        echo "Error: $2 is not a valid compression type"
-                        ;;
-                esac
-        else
-                smartcompress $1 tar.gz
-        fi
-  }
+smartcompress() {
+    if [[ -n $2 ]] ; then
+        case $2 in
+            tgz | tar.gz)   tar -zcvf$1.$2 $1 ;;
+            tbz2 | tar.bz2) tar -jcvf$1.$2 $1 ;;
+            tar.Z)          tar -Zcvf$1.$2 $1 ;;
+            tar)            tar -cvf$1.$2  $1 ;;
+            gz | gzip)      gzip           $1 ;;
+            bz2 | bzip2)    bzip2          $1 ;;
+            *)
+                echo "Error: $2 is not a valid compression type"
+                ;;
+        esac
+    else
+        smartcompress $1 tar.gz
+    fi
+}
 
 # Usage: show-archive <archive>
 #f5# List an archive's content
-  show-archive() {
-        if [[ -f $1 ]]
-        then
-                case $1 in
-                        *.tar.gz)      gunzip -c $1 | tar -tf - -- ;;
-                        *.tar)         tar -tf $1 ;;
-                        *.tgz)         tar -ztf $1 ;;
-                        *.zip)         unzip -l $1 ;;
-                        *.bz2)         bzless $1 ;;
-                        *)             echo "'$1' Error. Please go away" ;;
-                esac
-        else
-                echo "'$1' is not a valid archive"
-        fi
-  }
+show-archive() {
+    if [[ -f $1 ]] ; then
+        case $1 in
+            *.tar.gz)      gunzip -c $1 | tar -tf - -- ;;
+            *.tar)         tar -tf $1 ;;
+            *.tgz)         tar -ztf $1 ;;
+            *.zip)         unzip -l $1 ;;
+            *.bz2)         bzless $1 ;;
+            *)             echo "'$1' Error. Please go away" ;;
+        esac
+    else
+        echo "'$1' is not a valid archive"
+    fi
+}
 
+# TODO: isn't ssl() like this, but clean?
+#       I'd like to remove this, it's a gross hack, IMHO -ft
 #f5# Follow symlinks
-  folsym() {
-    if [[ -e $1 || -h $1 ]]; then
+folsym() {
+    if [[ -e $1 || -h $1 ]] ; then
         file=$1
     else
         file=`which $1`
     fi
-    if [[ -e $file || -L $file ]]; then
-        if [[ -L $file ]]; then
+    if [[ -e $file || -L $file ]] ; then
+        if [[ -L $file ]] ; then
             echo `ls -ld $file | perl -ane 'print $F[7]'` '->'
             folsym `perl -le '$file = $ARGV[0];
                               $dest = readlink $file;
     else
         echo $file
     fi
-  }
+}
 
 # It's shameless stolen from <http://www.vim.org/tips/tip.php?tip_id=167>
 #f5# Use \kbd{vim} as your manpage reader
-  vman() { man $* | col -b | view -c 'set ft=man nomod nolist' - }
+vman() { man $* | col -b | view -c 'set ft=man nomod nolist' - }
 
 # function readme() { $PAGER -- (#ia3)readme* }
 #f5# View all README-like files in current directory in pager
-  readme() {
-        local files
-        files=(./(#i)*(read*me|lue*m(in|)ut)*(ND))
-        if (($#files))
-        then $PAGER $files
-        else
-                print 'No README files.'
-        fi
-  }
+readme() {
+    local files
+    files=(./(#i)*(read*me|lue*m(in|)ut)*(ND))
+    if (($#files)) ; then
+        $PAGER $files
+    else
+        print 'No README files.'
+    fi
+}
 
 # suidfind() { ls -latg $path | grep '^...s' }
 #f5# Find all files in \$PATH with setuid bit set
-  suidfind() { ls -latg $path/*(sN) }
+suidfind() { ls -latg $path/*(sN) }
 
 # See above but this is /better/ ... anywise ..
-  findsuid() {
+findsuid() {
     print 'Output will be written to ~/suid_* ...'
     $SUDO find / -type f \( -perm -4000 -o -perm -2000 \) -ls > ~/suid_suidfiles.`date "+%Y-%m-%d"`.out 2>&1
     $SUDO find / -type d \( -perm -4000 -o -perm -2000 \) -ls > ~/suid_suiddirs.`date "+%Y-%m-%d"`.out 2>&1
     $SUDO find / -type f \( -perm -2 -o -perm -20 \) -ls > ~/suid_writefiles.`date "+%Y-%m-%d"`.out 2>&1
     $SUDO find / -type d \( -perm -2 -o -perm -20 \) -ls > ~/suid_writedirs.`date "+%Y-%m-%d"`.out 2>&1
     print 'Finished'
-  }
+}
 
 #f5# Reload given functions
-  refunc() {
-        for func in $argv
-        do
-                unfunction $func
-                autoload $func
-        done
-  }
+refunc() {
+    for func in $argv ; do
+        unfunction $func
+        autoload $func
+    done
+}
 
 # a small check to see which DIR is located on which server/partition.
 # stolen and modified from Sven's zshrc.forall
-  #f5# Report diskusage of a directory
-  dirspace() {
-    if [ -n "$1" ] ; then
-       for dir in $* ; do
-          if [ -d "$dir" ] ; then
-             ( cd $dir; echo "-<$dir>"; du -shx .; echo);
-          else
-             echo "warning: $dir does not exist" >&2
-          fi
-       done
+#f5# Report diskusage of a directory
+dirspace() {
+    if [[ -n "$1" ]] ; then
+        for dir in $* ; do
+            if [[ -d "$dir" ]] ; then
+                ( cd $dir; echo "-<$dir>"; du -shx .; echo);
+            else
+                echo "warning: $dir does not exist" >&2
+            fi
+        done
     else
         for dir in $path; do
-          if [ -d "$dir" ] ; then
-             ( cd $dir; echo "-<$dir>"; du -shx .; echo);
-          else
-             echo "warning: $dir does not exist" >&2
-          fi
+            if [[ -d "$dir" ]] ; then
+                ( cd $dir; echo "-<$dir>"; du -shx .; echo);
+            else
+                echo "warning: $dir does not exist" >&2
+            fi
         done
     fi
-  }
+}
 
 # % slow_print `cat /etc/passwd`
 #f5# Slowly print out parameters
-  slow_print() {
-        for argument in "${@}"
-        do
-                for ((i = 1; i <= ${#1} ;i++)) {
-                        print -n "${argument[i]}"
-                        sleep 0.08
-                }
-                print -n " "
+slow_print() {
+    for argument in "${@}" ; do
+        for ((i = 1; i <= ${#1} ;i++)) ; do
+            print -n "${argument[i]}"
+            sleep 0.08
         done
-        print ""
-  }
+        print -n " "
+    done
+    print ""
+}
 
 #f5# Show some status info
-  status() {
-        print ""
-        print "Date..: "$(date "+%Y-%m-%d %H:%M:%S")""
-        print "Shell.: Zsh $ZSH_VERSION (PID = $$, $SHLVL nests)"
-        print "Term..: $TTY ($TERM), $BAUD bauds, $COLUMNS x $LINES cars"
-        print "Login.: $LOGNAME (UID = $EUID) on $HOST"
-        print "System: $(cat /etc/[A-Za-z]*[_-][rv]e[lr]*)"
-        print "Uptime:$(uptime)"
-        print ""
-  }
+status() {
+    print ""
+    print "Date..: "$(date "+%Y-%m-%d %H:%M:%S")""
+    print "Shell.: Zsh $ZSH_VERSION (PID = $$, $SHLVL nests)"
+    print "Term..: $TTY ($TERM), $BAUD bauds, $COLUMNS x $LINES cars"
+    print "Login.: $LOGNAME (UID = $EUID) on $HOST"
+    print "System: $(cat /etc/[A-Za-z]*[_-][rv]e[lr]*)"
+    print "Uptime:$(uptime)"
+    print ""
+}
 
 # Rip an audio CD
-  #f5# Rip an audio CD
-  audiorip() {
-        mkdir -p ~/ripps
-        cd ~/ripps
-        cdrdao read-cd --device $DEVICE --driver generic-mmc audiocd.toc
-        cdrdao read-cddb --device $DEVICE --driver generic-mmc audiocd.toc
-        echo " * Would you like to burn the cd now? (yes/no)"
-        read input
-        if
-                [ "$input" = "yes" ]; then
-                echo " ! Burning Audio CD"
-                audioburn
-                echo " * done."
-        else
-                echo " ! Invalid response."
-        fi
-  }
+#f5# Rip an audio CD
+audiorip() {
+    mkdir -p ~/ripps
+    cd ~/ripps
+    cdrdao read-cd --device $DEVICE --driver generic-mmc audiocd.toc
+    cdrdao read-cddb --device $DEVICE --driver generic-mmc audiocd.toc
+    echo " * Would you like to burn the cd now? (yes/no)"
+    read input
+    if [[ "$input" = "yes" ]] ; then
+        echo " ! Burning Audio CD"
+        audioburn
+        echo " * done."
+    else
+        echo " ! Invalid response."
+    fi
+}
 
 # and burn it
-  #f5# Burn an audio CD (in combination with audiorip)
-  audioburn() {
-        cd ~/ripps
-        cdrdao write --device $DEVICE --driver generic-mmc audiocd.toc
-        echo " * Should I remove the temporary files? (yes/no)"
-        read input
-        if [ "$input" = "yes" ]; then
-                echo " ! Removing Temporary Files."
-                cd ~
-                rm -rf ~/ripps
-                echo " * done."
-        else
-                echo " ! Invalid response."
-        fi
-  }
+#f5# Burn an audio CD (in combination with audiorip)
+audioburn() {
+    cd ~/ripps
+    cdrdao write --device $DEVICE --driver generic-mmc audiocd.toc
+    echo " * Should I remove the temporary files? (yes/no)"
+    read input
+    if [[ "$input" = "yes" ]] ; then
+        echo " ! Removing Temporary Files."
+        cd ~
+        rm -rf ~/ripps
+        echo " * done."
+    else
+        echo " ! Invalid response."
+    fi
+}
 
 #f5# Make an audio CD from all mp3 files
-  mkaudiocd() {
-        cd ~/ripps
-        for i in *.[Mm][Pp]3; do mv "$i" `echo $i | tr '[A-Z]' '[a-z]'`; done
-        for i in *.mp3; do mv "$i" `echo $i | tr ' ' '_'`; done
-        for i in *.mp3; do mpg123 -w `basename $i .mp3`.wav $i; done
-        normalize -m *.wav
-        for i in *.wav; do sox $i.wav -r 44100 $i.wav resample; done
-  }
+mkaudiocd() {
+    # TODO: do the renaming more zshish, possibly with zmv()
+    cd ~/ripps
+    for i in *.[Mm][Pp]3; do mv "$i" `echo $i | tr '[A-Z]' '[a-z]'`; done
+    for i in *.mp3; do mv "$i" `echo $i | tr ' ' '_'`; done
+    for i in *.mp3; do mpg123 -w `basename $i .mp3`.wav $i; done
+    normalize -m *.wav
+    for i in *.wav; do sox $i.wav -r 44100 $i.wav resample; done
+}
 
 #f5# Create an ISO image. You are prompted for\\&\quad volume name, filename and directory
-  mkiso() {
-        echo " * Volume name "
-        read volume
-        echo " * ISO Name (ie. tmp.iso)"
-        read iso
-        echo " * Directory or File"
-        read files
-        mkisofs -o ~/$iso -A $volume -allow-multidot -J -R -iso-level 3 -V $volume -R $files
-  }
+mkiso() {
+    echo " * Volume name "
+    read volume
+    echo " * ISO Name (ie. tmp.iso)"
+    read iso
+    echo " * Directory or File"
+    read files
+    mkisofs -o ~/$iso -A $volume -allow-multidot -J -R -iso-level 3 -V $volume -R $files
+}
 
 #f5# Simple thumbnails generator
-  genthumbs () {
+genthumbs() {
     rm -rf thumb-* index.html
     echo "
 <html>
     <title>Images</title>
   </head>
   <body>" > index.html
-    for f in *.(gif|jpeg|jpg|png)
-    do
+    for f in *.(gif|jpeg|jpg|png) ; do
         convert -size 100x200 "$f" -resize 100x200 thumb-"$f"
         echo "    <a href=\"$f\"><img src=\"thumb-$f\"></a>" >> index.html
     done
     echo "
   </body>
 </html>" >> index.html
-  }
+}
 
 #f5# Set all ulimit parameters to \kbd{unlimited}
-  allulimit() {
+allulimit() {
     ulimit -c unlimited
     ulimit -d unlimited
     ulimit -f unlimited
     ulimit -n unlimited
     ulimit -s unlimited
     ulimit -t unlimited
-  }
+}
 
 # ogg2mp3 with bitrate of 192
-  ogg2mp3_192() {
+ogg2mp3_192() {
     oggdec -o - ${1} | lame -b 192 - ${1:r}.mp3
-  }
+}
 
 #f5# RFC 2396 URL encoding in Z-Shell
-  urlencode() {
-   setopt localoptions extendedglob
-   input=( ${(s::)1} )
-   print ${(j::)input/(#b)([^A-Za-z0-9_.!~*\'\(\)-])/%$(([##16]#match))}
-  }
+urlencode() {
+    setopt localoptions extendedglob
+    input=( ${(s::)1} )
+    print ${(j::)input/(#b)([^A-Za-z0-9_.!~*\'\(\)-])/%$(([##16]#match))}
+}
 
 #f5# Install x-lite (VoIP software)
-  getxlite() {
+getxlite() {
     setopt local_options
     setopt errreturn
-    [ -d ~/tmp ] || mkdir ~/tmp
+    [[ -d ~/tmp ]] || mkdir ~/tmp
     cd ~/tmp
+
     echo "Downloading http://www.counterpath.com/download/X-Lite_Install.tar.gz and storing it in ~/tmp:"
     if wget http://www.counterpath.com/download/X-Lite_Install.tar.gz ; then
-       unp X-Lite_Install.tar.gz && echo done || echo failed
+        unp X-Lite_Install.tar.gz && echo done || echo failed
     else
-       echo "Error while downloading." ; return 1
+        echo "Error while downloading." ; return 1
     fi
-    if [ -x xten-xlite/xtensoftphone ] ; then
-       echo "Execute xten-xlite/xtensoftphone to start xlite."
+
+    if [[ -x xten-xlite/xtensoftphone ]] ; then
+        echo "Execute xten-xlite/xtensoftphone to start xlite."
     fi
-   }
+}
 
 #f5# Install skype
-  getskype() {
+getskype() {
     setopt local_options
     setopt errreturn
     echo "Downloading debian package of skype."
     echo "Notice: If you want to use a more recent skype version run 'getskypebeta'."
     wget http://www.skype.com/go/getskype-linux-deb
-    $SUDO dpkg -i skype_debian-*.deb && echo "skype installed."
-  }
+    $SUDO dpkg -i skype*.deb && echo "skype installed."
+}
 
 #f5# Install beta-version of skype
-  getskypebeta() {
+getskypebeta() {
     setopt local_options
     setopt errreturn
     echo "Downloading debian package of skype (beta version)."
     wget http://www.skype.com/go/getskype-linux-beta-deb
     $SUDO dpkg -i skype-beta*.deb && echo "skype installed."
-  }
+}
 
 #f5# Install gizmo (VoIP software)
-  getgizmo() {
+getgizmo() {
     setopt local_options
     setopt errreturn
     echo "gconf2-common and libgconf2-4 have to be available. Installing therefor."
     $SUDO apt-get install gconf2-common libgconf2-4
     wget $(lynx --dump http://www.gizmoproject.com/download-linux.html | awk '/\.deb/ {print $2" "}' | tr -d '\n')
     $SUDO dpkg -i libsipphoneapi*.deb bonjour_*.deb gizmo-*.deb && echo "gizmo installed."
-  }
+}
 
 #f5# Get and run AIR (Automated Image and Restore)
-  getair() {
+getair() {
     setopt local_options
     setopt errreturn
-    [ -w . ] || { echo 'Error: you do not have write permissions in this directory. Exiting.' ; return 1 }
+    [[ -w . ]] || { echo 'Error: you do not have write permissions in this directory. Exiting.' ; return 1 }
     local VER='1.2.8'
     wget http://puzzle.dl.sourceforge.net/sourceforge/air-imager/air-$VER.tar.gz
     tar zxf air-$VER.tar.gz
     cd air-$VER
     INTERACTIVE=no $SUDO ./install-air-1.2.8
-    [ -x /usr/local/bin/air ] && [ -n "$DISPLAY" ] && $SUDO air
-  }
+    [[ -x /usr/local/bin/air ]] && [[ -n "$DISPLAY" ]] && $SUDO air
+}
 
 #f5# Get specific git commitdiff
-  git-get-diff() {
-    if [ -z $GITTREE ] ; then
-      GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
+git-get-diff() {
+    if [[ -z $GITTREE ]] ; then
+        GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
     fi
-    if ! [ -z $1 ] ; then
-     ${=BROWSER} "http://kernel.org/git/?p=$GITTREE;a=commitdiff;h=$1"
+    if ! [[ -z $1 ]] ; then
+        ${=BROWSER} "http://kernel.org/git/?p=$GITTREE;a=commitdiff;h=$1"
     else
-      echo "Usage: git-get-diff <commit>"
+        echo "Usage: git-get-diff <commit>"
     fi
-  }
+}
 
 #f5# Get specific git commit
-  git-get-commit() {
-    if [ -z $GITTREE ] ; then
-      GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
+git-get-commit() {
+    if [[ -z $GITTREE ]] ; then
+        GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
     fi
-    if ! [ -z $1 ] ; then
-     ${=BROWSER} "http://kernel.org/git/?p=$GITTREE;a=commit;h=$1"
+    if ! [[ -z $1 ]] ; then
+        ${=BROWSER} "http://kernel.org/git/?p=$GITTREE;a=commit;h=$1"
     else
-      echo "Usage: git-get-commit <commit>"
+        echo "Usage: git-get-commit <commit>"
     fi
-  }
+}
 
 #f5# Get specific git diff
-  git-get-plaindiff() {
-    if [ -z $GITTREE ] ; then
-      GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
+git-get-plaindiff() {
+    if [[ -z $GITTREE ]] ; then
+        GITTREE='linux/kernel/git/torvalds/linux-2.6.git'
     fi
-    if ! [ -z $1 ] ; then
-      wget "http://kernel.org/git/?p=$GITTREE;a=commitdiff_plain;h=$1" -O $1.diff
+    if ! [[ -z $1 ]] ; then
+        wget "http://kernel.org/git/?p=$GITTREE;a=commitdiff_plain;h=$1" -O $1.diff
     else
-      echo 'Usage: git-get-plaindiff '
+        echo 'Usage: git-get-plaindiff '
     fi
-  }
+}
 
 # http://strcat.de/blog/index.php?/archives/335-Software-sauber-deinstallieren...html
 #f5# Log 'make install' output
-  mmake() {
+mmake() {
     [[ ! -d ~/.errorlogs ]] && mkdir ~/.errorlogs
-    =make -n install > ~/.errorlogs/${PWD##*/}-makelog
-  }
+    make -n install > ~/.errorlogs/${PWD##*/}-makelog
+}
 
 #f5# Indent source code
-  smart-indent() {
+smart-indent() {
     indent -npro -kr -i8 -ts8 -sob -l80 -ss -ncs $*
-  }
+}
 
 # highlight important stuff in diff output, usage example: hg diff | hidiff
-  #m# a2 hidiff \kbd{histring} oneliner for diffs
-  [ -x $(which histring) ] && \
-  alias hidiff="histring -fE '^Comparing files .*|^diff .*' | histring -c yellow -fE '^\-.*' | histring -c green -fE '^\+.*'"
+#m# a2 hidiff \kbd{histring} oneliner for diffs
+check_com -c histring && \
+    alias hidiff="histring -fE '^Comparing files .*|^diff .*' | histring -c yellow -fE '^\-.*' | histring -c green -fE '^\+.*'"
 
 # rename pictures based on information found in exif headers
-  #f5# Rename pictures based on information found in exif headers
-  exirename() {
-    if [ $# -lt 1 ] ; then
-       echo 'Usage: jpgrename $FILES' >& 2
-       return 1
+#f5# Rename pictures based on information found in exif headers
+exirename() {
+    if [[ $# -lt 1 ]] ; then
+        echo 'Usage: jpgrename $FILES' >& 2
+        return 1
     else
-       echo -n 'Checking for jhead with version newer than 1.9: '
-       jhead_version=`jhead -h | grep 'used by most Digital Cameras.  v.*' | awk '{print $6}' | tr -d v`
-       if [[ $jhead_version > '1.9' ]]; then
-          echo 'success - now running jhead.'
-          jhead -n%Y-%m-%d_%Hh%M_%f $*
-       else
-          echo 'failed - exiting.'
-       fi
+        echo -n 'Checking for jhead with version newer than 1.9: '
+        jhead_version=`jhead -h | grep 'used by most Digital Cameras.  v.*' | awk '{print $6}' | tr -d v`
+        if [[ $jhead_version > '1.9' ]]; then
+            echo 'success - now running jhead.'
+            jhead -n%Y-%m-%d_%Hh%M_%f $*
+        else
+            echo 'failed - exiting.'
+        fi
     fi
-  }
+}
 
 # open file in vim and jump to line
 # http://www.downgra.de/archives/2007/05/08/T19_21_11/
-  j2v() {
+j2v() {
     local -a params
     params=(${*//(#m):[0-9]*:/\\n+${MATCH//:/}}) # replace ':23:' to '\n+23'
     params=(${(s|\n|)${(j|\n|)params}}) # join array using '\n', then split on all '\n'
     vim ${params}
-  }
+}
 
 # get_ic() - queries imap servers for capabilities; real simple. no imaps
-  ic_get() {
+ic_get() {
     local port
-    if [[ ! -z $1 ]]; then
-      port=${2:-143}
-      print "querying imap server on $1:${port}...\n";
-      print "a1 capability\na2 logout\n" | nc $1 ${port}
+    if [[ ! -z $1 ]] ; then
+        port=${2:-143}
+        print "querying imap server on $1:${port}...\n";
+        print "a1 capability\na2 logout\n" | nc $1 ${port}
     else
-      print "usage:\n  $0 <imap-server> [port]"
+        print "usage:\n  $0 <imap-server> [port]"
     fi
-  }
+}
 
 # creates a Maildir/ with its {new,cur,tmp} subdirs
-  mkmaildir() {
+mkmaildir() {
     local root subdir
     root=${MAILDIR_ROOT:-${HOME}/Mail}
     if [[ -z ${1} ]] ; then print "Usage:\n $0 <dirname>" ; return 1 ; fi
     subdir=${1}
     mkdir -p ${root}/${subdir}/{cur,new,tmp}
-  }
+}
 
 # xtrename() rename xterm from within GNU-screen
-  xtrename() {
+xtrename() {
     if [[ -z ${DISPLAY} ]] ; then
-      printf 'xtrename only makes sense in X11.\n'
-      return 1
+        printf 'xtrename only makes sense in X11.\n'
+        return 1
     fi
     if [[ -z ${1} ]] ; then
-      printf 'usage: xtrename() "title for xterm"\n'
-      printf '  renames the title of xterm from _within_ screen.\n'
-      printf '  Also works without screen.\n'
-      return 0
+        printf 'usage: xtrename() "title for xterm"\n'
+        printf '  renames the title of xterm from _within_ screen.\n'
+        printf '  Also works without screen.\n'
+        return 0
     fi
     print -n "\eP\e]0;${1}\C-G\e\\"
     return 0
-  }
+}
 
 # hl() highlighted less
 # http://ft.bewatermyfriend.org/comp/data/zsh/zfunct.html
-  if [ -x $(which highlight) ] ; then
+if check_com -c highlight ; then
     function hl() {
-      local theme lang
-      theme=${HL_THEME:-""}
-      case ${1} in
-        (-l|--list)
-          ( printf 'available languages (syntax parameter):\n\n' ;
-            highlight --list-langs ; ) | less -SMr
-          ;;
-        (-t|--themes)
-          ( printf 'available themes (style parameter):\n\n' ;
-            highlight --list-themes ; ) | less -SMr
-          ;;
-        (-h|--help)
-          printf 'usage: hl <syntax[:theme]> <file>\n'
-          printf '    available options: --list (-l), --themes (-t), --help (-h)\n\n'
-          printf '  Example: hl c main.c\n'
-          ;;
-        (*)
-          if [[ -z ${2} ]] || (( ${#argv} > 2 )) ; then
-            printf 'usage: hl <syntax[:theme]> <file>\n'
-            printf '    available options: --list (-l), --themes (-t), --help (-h)\n'
-            (( ${#argv} > 2 )) && printf '  Too many arguments.\n'
-            return 1
-          fi
-          lang=${1%:*}
-          [[ ${1} == *:* ]] && [[ -n ${1#*:} ]] && theme=${1#*:}
-          if [[ -n ${theme} ]] ; then
-            highlight --xterm256 --syntax ${lang} --style ${theme} ${2} | less -SMr
-          else
-            highlight --ansi --syntax ${lang} ${2} | less -SMr
-          fi
-          ;;
-      esac
-      return 0
+        local theme lang
+        theme=${HL_THEME:-""}
+        case ${1} in
+            (-l|--list)
+                ( printf 'available languages (syntax parameter):\n\n' ;
+                    highlight --list-langs ; ) | less -SMr
+                ;;
+            (-t|--themes)
+                ( printf 'available themes (style parameter):\n\n' ;
+                    highlight --list-themes ; ) | less -SMr
+                ;;
+            (-h|--help)
+                printf 'usage: hl <syntax[:theme]> <file>\n'
+                printf '    available options: --list (-l), --themes (-t), --help (-h)\n\n'
+                printf '  Example: hl c main.c\n'
+                ;;
+            (*)
+                if [[ -z ${2} ]] || (( ${#argv} > 2 )) ; then
+                    printf 'usage: hl <syntax[:theme]> <file>\n'
+                    printf '    available options: --list (-l), --themes (-t), --help (-h)\n'
+                    (( ${#argv} > 2 )) && printf '  Too many arguments.\n'
+                    return 1
+                fi
+                lang=${1%:*}
+                [[ ${1} == *:* ]] && [[ -n ${1#*:} ]] && theme=${1#*:}
+                if [[ -n ${theme} ]] ; then
+                    highlight --xterm256 --syntax ${lang} --style ${theme} ${2} | less -SMr
+                else
+                    highlight --ansi --syntax ${lang} ${2} | less -SMr
+                fi
+                ;;
+        esac
+        return 0
     }
     # ... and a proper completion for hl()
     # needs 'highlight' as well, so it fits fine in here.
     function _hl_genarg()  {
-      local expl
-      if [[ -prefix 1 *: ]] ; then
-        local themes
-        themes=(${${${(f)"$(LC_ALL=C highlight --list-themes)"}/ #/}:#*(Installed|Use name)*})
-        compset -P 1 '*:'
-        _wanted -C list themes expl theme compadd ${themes}
-      else
-        local langs
-        langs=(${${${(f)"$(LC_ALL=C highlight --list-langs)"}/ #/}:#*(Installed|Use name)*})
-        _wanted -C list languages expl languages compadd -S ':' -q ${langs}
-      fi
+        local expl
+        if [[ -prefix 1 *: ]] ; then
+            local themes
+            themes=(${${${(f)"$(LC_ALL=C highlight --list-themes)"}/ #/}:#*(Installed|Use name)*})
+            compset -P 1 '*:'
+            _wanted -C list themes expl theme compadd ${themes}
+        else
+            local langs
+            langs=(${${${(f)"$(LC_ALL=C highlight --list-langs)"}/ #/}:#*(Installed|Use name)*})
+            _wanted -C list languages expl languages compadd -S ':' -q ${langs}
+        fi
     }
     function _hl_complete() {
-      _arguments -s '1: :_hl_genarg' '2:files:_path_files'
+        _arguments -s '1: :_hl_genarg' '2:files:_path_files'
     }
     compdef _hl_complete hl
-  fi
+fi
 
 # create small urls via tinyurl.com using wget, grep and sed
-  zurl() {
-  [[ -z ${1} ]] && print "please give an url to shrink." && return 1
-  local url=${1}
-  local tiny="http://tinyurl.com/create.php?url="
-  #print "${tiny}${url}" ; return
-  wget  -O-             \
-        -o/dev/null     \
-        "${tiny}${url}" \
-    | grep -Eio 'value="(http://tinyurl.com/.*)"' \
-    | sed 's/value=//;s/"//g'
+zurl() {
+    [[ -z ${1} ]] && print "please give an url to shrink." && return 1
+    local url=${1}
+    local tiny="http://tinyurl.com/create.php?url="
+    #print "${tiny}${url}" ; return
+    wget  -O-             \
+          -o/dev/null     \
+          "${tiny}${url}" \
+        | grep -Eio 'value="(http://tinyurl.com/.*)"' \
+        | sed 's/value=//;s/"//g'
 }
 
 # change fluxbox keys from 'Alt-#' to 'Alt-F#' and vice versa
-  fluxkey-change() {
-    [ -n "$FLUXKEYS" ] || local FLUXKEYS="$HOME/.fluxbox/keys"
-    if ! [ -r "$FLUXKEYS" ] ; then
-       echo "Sorry, \$FLUXKEYS file $FLUXKEYS could not be read - nothing to be done."
-       return 1
+fluxkey-change() {
+    [[ -n "$FLUXKEYS" ]] || local FLUXKEYS="$HOME/.fluxbox/keys"
+    if ! [[ -r "$FLUXKEYS" ]] ; then
+        echo "Sorry, \$FLUXKEYS file $FLUXKEYS could not be read - nothing to be done."
+        return 1
     else
-       if grep -q 'Mod1 F[0-9] :Workspace [0-9]' $FLUXKEYS ; then
-          echo -n 'Switching to Alt-# mode in ~/.fluxbox/keys: '
-          sed -i -e 's|^\(Mod[0-9]\+[: space :]\+\)F\([0-9]\+[: space :]\+:Workspace.*\)|\1\2|' $FLUXKEYS && echo done || echo failed
-       elif grep -q 'Mod1 [0-9] :Workspace [0-9]' $FLUXKEYS ; then
-          echo -n 'Switching to Alt-F# mode in ~/.fluxbox/keys: '
-          sed -i -e 's|^\(Mod[0-9]\+[: space :]\+\)\([0-9]\+[: space :]\+:Workspace.*\)|\1F\2|' $FLUXKEYS && echo done || echo failed
-       else
-          echo 'Sorry, do not know what to do.'
-          return 1
-       fi
+        if grep -q 'Mod1 F[0-9] :Workspace [0-9]' $FLUXKEYS ; then
+            echo -n 'Switching to Alt-# mode in ~/.fluxbox/keys: '
+            sed -i -e 's|^\(Mod[0-9]\+[: space :]\+\)F\([0-9]\+[: space :]\+:Workspace.*\)|\1\2|' $FLUXKEYS && echo done || echo failed
+        elif grep -q 'Mod1 [0-9] :Workspace [0-9]' $FLUXKEYS ; then
+            echo -n 'Switching to Alt-F# mode in ~/.fluxbox/keys: '
+            sed -i -e 's|^\(Mod[0-9]\+[: space :]\+\)\([0-9]\+[: space :]\+:Workspace.*\)|\1F\2|' $FLUXKEYS && echo done || echo failed
+        else
+            echo 'Sorry, do not know what to do.'
+            return 1
+        fi
     fi
-  }
+}
 
 # retrieve weather information on the console
 # Usage example: 'weather LOWG'
-  weather () {
-   [ -n "$1" ] || {
-           print 'Usage: weather <station_id>' >&2
-           return 1
-   }
-
-   local PLACE="${1:u}"
-   local FILE="$HOME/.weather/$PLACE"
-   local LOG="$HOME/.weather/log"
-
-   [ -d $HOME/.weather ] || {
-           print -n "Creating $HOME/.weather: "
-           mkdir $HOME/.weather
-           print 'done'
-   }
-
-   print "Retrieving information for ${PLACE}:"
-   print
-   wget -T 10 --no-verbose --output-file=$LOG --output-document=$FILE --timestamping http://weather.noaa.gov/pub/data/observations/metar/decoded/$PLACE.TXT
-
-   if [[ $? = 0 ]] ; then
-           if [ -n "$VERBOSE" ] ; then
-                   cat $FILE
-           else
-                   DATE=$(grep 'UTC' $FILE | sed 's#.* /##')
-                   TEMPERATURE=$(awk '/Temperature/ { print $4" degree Celcius / " $2" degree Fahrenheit" }' $FILE| tr -d '(')
-                   echo "date: $DATE"
-                   echo "temp:  $TEMPERATURE"
-           fi
-   else
-           print "There was an error retrieving the weather information for $PLACE" >&2
-           cat $LOG
-           return 1
-   fi
-  }
+weather() {
+    [[ -n "$1" ]] || {
+        print 'Usage: weather <station_id>' >&2
+        return 1
+    }
+
+    local PLACE="${1:u}"
+    local FILE="$HOME/.weather/$PLACE"
+    local LOG="$HOME/.weather/log"
+
+    [[ -d $HOME/.weather ]] || {
+        print -n "Creating $HOME/.weather: "
+        mkdir $HOME/.weather
+        print 'done'
+    }
+
+    print "Retrieving information for ${PLACE}:"
+    print
+    wget -T 10 --no-verbose --output-file=$LOG --output-document=$FILE --timestamping http://weather.noaa.gov/pub/data/observations/metar/decoded/$PLACE.TXT
+
+    if [[ $? -eq 0 ]] ; then
+        if [[ -n "$VERBOSE" ]] ; then
+            cat $FILE
+        else
+            DATE=$(grep 'UTC' $FILE | sed 's#.* /##')
+            TEMPERATURE=$(awk '/Temperature/ { print $4" degree Celcius / " $2" degree Fahrenheit" }' $FILE| tr -d '(')
+            echo "date: $DATE"
+            echo "temp:  $TEMPERATURE"
+        fi
+    else
+        print "There was an error retrieving the weather information for $PLACE" >&2
+        cat $LOG
+        return 1
+    fi
+}
 
 
 # }}}
 
 # mercurial related stuff {{{
-  if type -p hg &>/dev/null ; then
-  # gnu like diff for mercurial
-  # http://www.selenic.com/mercurial/wiki/index.cgi/TipsAndTricks
+if check_com -c hg ; then
+    # gnu like diff for mercurial
+    # http://www.selenic.com/mercurial/wiki/index.cgi/TipsAndTricks
     #f5# GNU like diff for mercurial
     hgdi() {
-      for i in `hg status -marn "$@"` ; diff -ubwd <(hg cat "$i") "$i"
+        for i in $(hg status -marn "$@") ; diff -ubwd <(hg cat "$i") "$i"
     }
 
-  # build debian package
+    # build debian package
     #a2# Alias for \kbd{hg-buildpackage}
     alias hbp='hg-buildpackage'
 
-  # execute commands on the versioned patch-queue from the current repos
+    # execute commands on the versioned patch-queue from the current repos
     alias mq='hg -R $(readlink -f $(hg root)/.hg/patches)'
 
-  # diffstat for specific version of a mercurial repository
-  #   hgstat      => display diffstat between last revision and tip
-  #   hgstat 1234 => display diffstat between revision 1234 and tip
+    # diffstat for specific version of a mercurial repository
+    #   hgstat      => display diffstat between last revision and tip
+    #   hgstat 1234 => display diffstat between revision 1234 and tip
     #f5# Diffstat for specific version of a mercurial repos
     hgstat() {
-      [ -n "$1" ] && hg diff -r $1 -r tip | diffstat || hg export tip | diffstat
+        [[ -n "$1" ]] && hg diff -r $1 -r tip | diffstat || hg export tip | diffstat
     }
 
-  # get current mercurial tip via hg itself
     #f5# Get current mercurial tip via hg itself
     gethgclone() {
-      setopt local_options
-      setopt errreturn
-      if [ -f mercurial-tree/.hg ] ; then
-        cd mercurial-tree
-        echo "Running hg pull for retreiving latest version..."
-        hg pull
-        echo "Finished update. Building mercurial"
-        make local
-        echo "Setting \$PATH to $PWD:\$PATH..."
-        export PATH="$PWD:$PATH"
-      else
-        echo "Downloading mercurial via hg"
-        hg clone http://selenic.com/repo/hg mercurial-tree
-        cd mercurial-tree
-        echo "Building mercurial"
-        make local
-        echo "Setting \$PATH to $PWD:\$PATH..."
-        export PATH="$PWD:$PATH"
-        echo "make sure you set it permanent via ~/.zshrc if you plan to use it permanently."
-        # echo "Setting \$PYTHONPATH to PYTHONPATH=\${HOME}/lib/python,"
-        # export PYTHONPATH=${HOME}/lib/python
-      fi
+        setopt local_options
+        setopt errreturn
+        if [[ -f mercurial-tree/.hg ]] ; then
+            cd mercurial-tree
+            echo "Running hg pull for retreiving latest version..."
+            hg pull
+            echo "Finished update. Building mercurial"
+            make local
+            echo "Setting \$PATH to $PWD:\$PATH..."
+            export PATH="$PWD:$PATH"
+        else
+            echo "Downloading mercurial via hg"
+            hg clone http://selenic.com/repo/hg mercurial-tree
+            cd mercurial-tree
+            echo "Building mercurial"
+            make local
+            echo "Setting \$PATH to $PWD:\$PATH..."
+            export PATH="$PWD:$PATH"
+            echo "make sure you set it permanent via ~/.zshrc if you plan to use it permanently."
+            # echo "Setting \$PYTHONPATH to PYTHONPATH=\${HOME}/lib/python,"
+            # export PYTHONPATH=${HOME}/lib/python
+        fi
     }
 
-  fi # end of check whether we have the 'hg'-executable
+fi # end of check whether we have the 'hg'-executable
 
-  # get current mercurial snapshot
-    #f5# Get current mercurial snapshot
-    gethgsnap() {
-      setopt local_options
-      setopt errreturn
-      if [ -f mercurial-snapshot.tar.gz ] ; then
+# get current mercurial snapshot
+#f5# Get current mercurial snapshot
+gethgsnap() {
+    setopt local_options
+    setopt errreturn
+    if [[ -f mercurial-snapshot.tar.gz ]] ; then
          echo "mercurial-snapshot.tar.gz exists already, skipping download."
-      else
+    else
         echo "Downloading mercurial snapshot"
         wget http://www.selenic.com/mercurial/mercurial-snapshot.tar.gz
-      fi
-      echo "Unpacking mercurial-snapshot.tar.gz"
-      tar zxf mercurial-snapshot.tar.gz
-      cd mercurial-snapshot/
-      echo "Installing required build-dependencies"
-      $SUDO apt-get update
-      $SUDO apt-get install python2.4-dev
-      echo "Building mercurial"
-      make local
-      echo "Setting \$PATH to $PWD:\$PATH..."
-      export PATH="$PWD:$PATH"
-      echo "make sure you set it permanent via ~/.zshrc if you plan to use it permanently."
-    }
+    fi
+    echo "Unpacking mercurial-snapshot.tar.gz"
+    tar zxf mercurial-snapshot.tar.gz
+    cd mercurial-snapshot/
+    echo "Installing required build-dependencies"
+    $SUDO apt-get update
+    $SUDO apt-get install python2.4-dev
+    echo "Building mercurial"
+    make local
+    echo "Setting \$PATH to $PWD:\$PATH..."
+    export PATH="$PWD:$PATH"
+    echo "make sure you set it permanent via ~/.zshrc if you plan to use it permanently."
+}
 # }}}
 
 # some useful commands often hard to remember - let's grep for them {{{
 
 # Work around ion/xterm resize bug.
-#if [ "$SHLVL" = 1 ]; then
-#       if [ -x $(which resize) ]; then
+#if [[ "$SHLVL" -eq 1 ]]; then
+#       if check_com -c resize ; then
 #               eval `resize </dev/null`
 #       fi
 #fi
 #     $GRMLSMALL_SPECIFIC to 0 or comment out the variable definition.
 #  b) remove/rename .zshrc.grmlsmall
 #  c) comment out the following line
-  (( GRMLSMALL_SPECIFIC > 0 )) && isgrmlsmall && source ~/.zshrc.grmlsmall
+(( GRMLSMALL_SPECIFIC > 0 )) && isgrmlsmall && source ~/.zshrc.grmlsmall
 
 # this allows us to stay in sync with /etc/skel/.zshrc
 # through 'ln -s /etc/skel/.zshrc ~/.zshrc' and put own
 # modifications in ~/.zshrc.local
-  if [ -r ~/.zshrc.local ] ; then
-     . ~/.zshrc.local
-  fi
+xsource "${HOME}/.zshrc.local"
+
+# ...and remove utility functions again.
+xunfunction
+
 # }}}
 
 ### doc strings for external functions from files
 #m# f5 grml-wallpaper() Sets a wallpaper (try completion for possible values)
 ## END OF FILE #################################################################
-# vim:foldmethod=marker
+# vim:foldmethod=marker autoindent expandtab shiftwidth=4