#!/bin/sh
+#NOTE: .zshenv XDG paths are hardcoded to allow non-zsh install
+
# test
-if [ 0 -eq 1 ]; then
+if [ "$1" = "test" ]; then
mkdir() { echo -- "$*"; }
alias ln="echo ln"
alias rm="echo rm"
# create preferred folder structure
cd ~
-mkdir -p bin etc share .urxvt/ext > /dev/null 2>&1
-mkdir -m 700 var/tmp var/tmp/vim > /dev/null 2>&1
+mkdir -p bin etc share share/fonts .urxvt/ext .icons .themes > /dev/null 2>&1
+mkdir -pm 700 var/tmp var/tmp/vim > /dev/null 2>&1
cd -
# accomodate multiple userlands
fex='-perm -ugo=x'
+lnargs=-sfnv
+if [ -z "$OSTYPE" ]; then
+ OSTYPE=`uname -s | tr '[:upper:]' '[:lower:]'`
+fi
case "$OSTYPE" in
# TODO: make links safer for systems without -Fw
- freebsd) lnargs=-sFhvw;;
- netbsd|openbsd) lnargs=-sfhv;;
- *) lnargs=-sfnv
- # android busybox find doesn't have -executable
- # and its sh doesn't set OSTYPE :DD
- if [ -z "$ANDROID_ROOT" ]; then
- fex=-executable
- fi;;
+ freebsd*) lnargs=-sFhvw;;
+ netbsd|openbsd*) lnargs=-sfhv;;
+ # android busybox find doesn't have -executable
+ android) fex=-executable;;
esac
l() {
l "$HOME/$x" "$PWD/$x"
done
find "$PWD/xdg" -mindepth 1 -maxdepth 1 | while read -r x; do
- l "${XDG_CONFIG_HOME:-$HOME/etc}/`basename "$x"`"
+ l "$HOME/etc/`basename "$x"`"
done
find "$PWD/urxvt-ext" -type f $fex -mindepth 1 -maxdepth 2 | while read -r x; do
l "$HOME/.urxvt/ext/`basename $x`"
done
+find "$PWD/xorg/icons" -type d -mindepth 2 -maxdepth 2 | while read -r x; do
+ l "$HOME/.icons/`basename "$x"`"
+done
+find "$PWD/xorg/themes" -type d -mindepth 1 -maxdepth 1 | while read -r x; do
+ l "$HOME/.themes/`basename "$x"`"
+done
+find "$PWD/xorg/fonts" -type d -mindepth 1 -maxdepth 1 | while read -r x; do
+ l "$HOME/share/fonts/`basename "$x"`"
+done
cd ~
if [ "$OSTYPE" = "freebsd" ]; then
- touch .hushlogin
-
# FreeBSD tries `_secure_path' on `.login_conf' before reading the
# database, so it needs to be compiled and unlinked for it to actually
# take effect.
rm .login_conf.db
cap_mkdb .login_conf
-
fi
unlink .login_conf
# run .zprofile to set up tmp