]> ruderich.org/simon Gitweb - config/dotfiles.git/blobdiff - setup.sh
herbstluftwm/autostart: add bindings to run programs and select windows
[config/dotfiles.git] / setup.sh
index 6884298ace204cd30d541f3eed57dfb17a0e95a2..56a90928169eb5ebc4fdcbaedda4bc0ae2cfe882 100755 (executable)
--- a/setup.sh
+++ b/setup.sh
@@ -1,8 +1,9 @@
 #!/bin/sh
 
-# Setup script for Vim configuration files.
+# Runs setup.sh in all configuration directories. Must be run in the main
+# configuration directory.
 
-# Copyright (C) 2011-2012  Simon Ruderich
+# Copyright (C) 2009-2018  Simon Ruderich
 #
 # This program is free software: you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
 
 set -eu
 
-. ../lib.sh
 
+# Enforce evtag checks for submodules.
+git submodule init > /dev/null
+for x in `git config --local --get-regexp 'submodule.*\.url' \
+        | awk '{print $1}'`; do
+    git config "${x%.url}.update" '!git-update-and-verify-submodule'
+done
 
-# Create directories.
-mkdir -p vim/cache
+for path in */setup.sh; do
+    # Skip non executable setup.sh files as an easy way to deactivate one.
+    test ! -x "$path" && continue
 
-# Create documentation tags for pathogen plugins. `vim -e` always exists with
-# 1 for unknown reasons.
-vim -e -c ':call pathogen#helptags()' -c ':q' || true
+    project=`printf '%s' "$path" | sed 's|/setup.sh$||'`
 
-# Link setup.
-link vim ~/.vim
-link vimrc ~/.vimrc
-if installed gvim; then
-    link gvimrc ~/.gvimrc
-fi
-
-# Create/Update custom spell checking files.
-if test -f vim/spell/Makefile; then
-    make -C vim/spell
-fi
-
-if test -d ~/.crontab.d; then
-    link crontab ~/.crontab.d/crontab.dotfiles-vim
-fi
+    printf 'running setup.sh in "%s"\n' "$project"
+    ( cd "$project" && ./setup.sh >/dev/null ) || {
+        printf '%s/setup.sh failed\n' "$project" >&2
+        exit 1
+    }
+done