#!/bin/sh
-# Setup script for OS related configuration files.
+# Runs setup.sh in all configuration directories. Must be run in the main
+# configuration directory.
+# 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
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
-. ../lib.sh
-if [ `os` = darwin ]; then
- # Sets a custom PATH for GUI applications.
- mkdir -p ~/.MacOSX
- link darwin/environment.plist ~/.MacOSX/environment.plist
-fi
-if [ `os` = debian ]; then
- # Necessary as aptitude rewrites the config file on every start.
- generate cat debian/aptitude/config .real
- # aptitude/config uses // as comment instead of #.
- sed -i 's|^#|//|' debian/aptitude/config
+set -eu
- link debian/aptitude ~/.aptitude
-fi
+
+# 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
+
+for path in */setup.sh; do
+ # Skip non executable setup.sh files as an easy way to deactivate one.
+ test ! -x "$path" && continue
+
+ project=`printf '%s' "$path" | sed 's|/setup.sh$||'`
+
+ 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