#!/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