]> ruderich.org/simon Gitweb - config/dotfiles.git/blobdiff - setup.sh
Merge branch 'dotfiles'
[config/dotfiles.git] / setup.sh
index 98c910064a03178666d3762a1cc336c9637e5a1f..d2a3815772217ae7f9dda89e9c81082a99fe1d62 100755 (executable)
--- a/setup.sh
+++ b/setup.sh
@@ -3,12 +3,33 @@
 # 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/>.
 
-# Projects which use git.
-projects="browser lftp mail music os shell vcs vim"
 
-# Run setup.sh in each project.
-for project in $projects; do
-    [ -d "$project" ] && (echo "running setup.sh in '$project'";
-                          cd "$project"; ./setup.sh > /dev/null)
+set -eu
+
+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