X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=setup.sh;h=b6bd30e5df9e307e0bc2669d0d7e3ba1324b2039;hb=92fb2c039fb3510301e34ada4a13fcb8af34974e;hp=d8c00fdee11499a214007c05086bac3e746efe33;hpb=660bd92f28c522138775a62d5ef64e01ad3b8c06;p=config%2Fdotfiles.git diff --git a/setup.sh b/setup.sh index d8c00fd..b6bd30e 100755 --- a/setup.sh +++ b/setup.sh @@ -30,7 +30,7 @@ terminal_available() { terminal_info "$@" > /dev/null } # Check if `infocmp` is available. -if ! infocmp > /dev/null 2>&1; then +if ! infocmp >/dev/null 2>&1; then echo 'Warning: `infocmp` not available! 256color checks will fail.' echo fi @@ -45,6 +45,8 @@ chmod 0700 ~/.tmp # Create rlwrap history directory. mkdir -p shell/rlwrap +# Create zsh cache directory. +mkdir -p zsh/cache # FILE SETUP @@ -62,24 +64,28 @@ perl < lesskey \ | lesskey - chmod 0600 ~/.less +# Custom colors for GNU ls. +if installed dircolors; then + echo '# WARNING! DO NOT EDIT THIS FILE!' >shell/dircolors + dircolors -b shell/dircolors.in >>shell/dircolors +fi + # Find the required options to get colored ls output. GNU ls is preferred. See # shell/aliases.in for details. Doing this here instead of in shell/aliases # speeds up shell starts. # # Check if colors are available. -ls --color > /dev/null 2>&1 -if test $? -eq 0; then +if ls --color >/dev/null 2>&1; then ls_color=gnu else - ls -G > /dev/null 2>&1 - if test $? -eq 0; then + if ls -G >/dev/null 2>&1; then ls_color=cli else ls_color= fi fi # Absolute path to `ls`. -ls_path=`which ls` +ls_path=`installed_path ls` # GNU ls with colors. if test "x$ls_color" = xgnu; then ls_env= @@ -93,14 +99,36 @@ else ls_env= ls_color= fi + +# Also check if `column -t` is available. +if echo test | column -t >/dev/null 2>&1; then + column=' | column -t' +else + column= +fi + generate perl shell/aliases \ -e 'while () { s/\bLS_ENV\b/$ARGV[0]/; s/\bLS_PATH\b/$ARGV[1]/; s/\bLS_COLOR\b/$ARGV[2]/; + s/\bCOLUMN\b/$ARGV[3]/; print; }' \ - "$ls_env" "$ls_path" "$ls_color" + "$ls_env" "$ls_path" "$ls_color" "$column" + +# If `tig` is not available use my simple replacement. +if ! installed tig; then + echo "alias tig='git tig'" >>shell/aliases +fi + +# Check if grep supports --color=auto. +if echo test | grep --color=auto test >/dev/null 2>&1; then + : +else + echo 'shell/aliases: removing grep --color=auto' + sed_i '/^alias grep=/ s/^/#/' shell/aliases +fi generate cat screenrc .in # As screen-256color is not widely supported use it only on machines where the @@ -119,7 +147,7 @@ if terminal_available screen-256color; then # rxvt-unicode binaries (e.g. Debian's rxvt-unicode-256color), the # terminal_info check for manual installations which modify # rxvt-unicode's terminfo entry. - urxvt_path=`which urxvt` + urxvt_path=`installed_path urxvt` urxvt_grep=`strings "$urxvt_path" | grep '^TERM=rxvt-'` if test x"$urxvt_grep" = 'xTERM=rxvt-unicode-256color' \ || terminal_info rxvt-unicode \ @@ -134,15 +162,14 @@ if terminal_available screen-256color; then fi if test -z "$use_256colors"; then echo screenrc: removing 256 colors - sed 's/Enable 256 color/Disable 256 color/; - s/screen-256color/screen/' screenrc > screenrc.tmp - mv screenrc.tmp screenrc + sed_i 's/Enable 256 color/Disable 256 color/; + s/screen-256color/screen/' screenrc fi # Some options are only necessary when running as root. They are marked as # "(ROOT)". if test "`id -u`" -ne 0; then echo screenrc: removing root options - grep -v '(ROOT)' screenrc > screenrc.tmp + grep -v '(ROOT)' screenrc >screenrc.tmp mv screenrc.tmp screenrc fi # I use some features of GNU screen which are only in Git or very recent GNU @@ -150,21 +177,20 @@ fi # marked as "(GIT)". if test ! -d "$HOME/development/shell/screen"; then echo screenrc: removing Git features - grep -v '(GIT)' screenrc > screenrc.tmp + grep -v '(GIT)' screenrc >screenrc.tmp mv screenrc.tmp screenrc fi # Rxvt doesn't need the attrcolor "fix". As I prefer rxvt assume I use it when # it's installed. if installed rxvt; then echo screenrc: removing attrcolor \"fix\" - sed 's/attrcolor b ".I"/#attrcolor b ".I"/' screenrc > screenrc.tmp - mv screenrc.tmp screenrc + sed_i 's/attrcolor b ".I"/#attrcolor b ".I"/' screenrc fi # Display current battery charge on computers with a battery. Necessary lines # are marked as "(BATTERY)". if test ! -d /sys/class/power_supply/BAT0; then echo screenrc: removing battery display - grep -v '(BATTERY)' screenrc > screenrc.tmp + grep -v '(BATTERY)' screenrc >screenrc.tmp mv screenrc.tmp screenrc fi @@ -173,10 +199,10 @@ if installed tmux; then # Add mappings to switch to windows 10-29 quickly. See tmux-window.pl for # details. - perl ./tmux-window.pl 1 "`pwd`/tmux-window2.conf" > tmux-window1.conf - perl ./tmux-window.pl 2 > tmux-window2.conf + perl ./tmux-window.pl 1 "`pwd`/tmux-window2.conf" >tmux-window1.conf + perl ./tmux-window.pl 2 >tmux-window2.conf # Set absolute path to tmux-window1.conf in tmux.conf. - perl < tmux.conf > tmux.conf.tmp \ + perl tmux.conf.tmp \ -e 'while () { s/\bTMUX_WINDOW_PATH\b/$ARGV[0]/; print; @@ -187,27 +213,19 @@ if installed tmux; then # 256 colors not available. if test -z "$use_256colors"; then echo tmux.conf: removing 256 colors - sed 's/Enable 256 color/Disable 256 color/; - s/screen-256color/screen/' tmux.conf > tmux.conf.tmp - mv tmux.conf.tmp tmux.conf + sed_i 's/Enable 256 color/Disable 256 color/; + s/screen-256color/screen/' tmux.conf fi # Tmux doesn't display a warning if the shell wasn't found! if test ! -x '/bin/zsh'; then echo tmux.conf: removing /bin/zsh as shell - sed 's/zsh/sh/' tmux.conf > tmux.conf.tmp - mv tmux.conf.tmp tmux.conf + sed_i 's/zsh/sh/' tmux.conf fi fi # Htop overwrites the comments in its configuration file. generate cat htoprc .in -# Copy remindrc template if ~/.reminders doesn't exist yet. -if installed remind && test ! -e "$HOME/.reminders"; then - echo remind: copying template to .reminders - cp reminders.in "$HOME/.reminders" -fi - # LINK SETUP @@ -226,6 +244,9 @@ link zsh/rc ~/.zshrc link zsh/logout ~/.zlogout # Link setup for additional files. +if installed crontab; then + link crontab.d ~/.crontab.d +fi link lessfilter ~/.lessfilter if installed colordiff; then link colordiffrc ~/.colordiffrc @@ -237,5 +258,10 @@ if installed tmux; then fi if installed htop; then link htoprc ~/.htoprc + # New location for htoprc. Use both for compatibility. + mkdir -p ~/.config/htop + link htoprc ~/.config/htop/htoprc +fi +if test -d ~/.ssh && test -O ~/.ssh; then + link ssh_config ~/.ssh/config fi -