]> ruderich.org/simon Gitweb - config/dotfiles.git/commitdiff
source_config() can load normal configuration files.
authorSimon Ruderich <simon@ruderich.org>
Sun, 22 Feb 2009 02:29:56 +0000 (03:29 +0100)
committerSimon Ruderich <simon@ruderich.org>
Sun, 22 Feb 2009 02:29:56 +0000 (03:29 +0100)
No extension (like hostname; $4) have to be used. See source code for more
information.

Update tests and add Vim modeline.

shell/env
tests/source_config.test
tests/source_config.test.out

index af46c8b8add8e2ec7a2f97557cc48d63784e2e9d..6424c5892077d3625659cd94cbc1ecc811fcea6b 100644 (file)
--- a/shell/env
+++ b/shell/env
@@ -65,6 +65,7 @@ export LSCOLORS
 #     in $1.
 # $3: Base name of file in $2, for example "rc" or "env".
 # $4: Extension for $3, if this file doesn't exist "$1/$3.local" is sourced.
+#     Can be empty, then no extension is used.
 # $5: Additional options, set to nolocal to prevent loading of "$1/$3.local"
 #                         if "$1/$2/$3.$4" doesn't exist.
 #
@@ -91,13 +92,24 @@ export LSCOLORS
 # source_config zsh os   env $os       nolocal # loads os/rc.Darwin
 # source_config zsh host env $hostname         # loads env.local
 #
+# By letting $4 empty normal configuration files can be sourced. A .local can
+# still be used.
+#
+# source_config zsh "" file # loads zsh/file if it exists
+#
 # Doesn't fit perfectly in this file, but this is the best place to make it
 # available everywhere.
 #
 # If DEBUG is set to a non empty value additional debug output is printed.
 function source_config() {
     # Path to the file to source and its local counterpart.
-    source_file=$1/$2/$3.$4
+    if [ x$4 != x ]; then
+        source_file=$1/$2/$3.$4
+    # If $4 is empty don't append a trailing dot. This allows source_config()
+    # to load normal configuration files.
+    else
+        source_file=$1/$2/$3
+    fi
     source_file_local=$1/$3.local
 
     # Additional debug output.
@@ -122,3 +134,5 @@ function source_config() {
 }
 
 source_debug "finished sourcing ~/.shell/env"
+
+# vim: ft=sh
index c8d888e7bf6de65d8ed2aa16399cc2601a6951c3..7237d11f2a74c626432415307bb221cf48be649d 100644 (file)
@@ -14,6 +14,7 @@ mkdir tmp/shell
 mkdir tmp/zsh tmp/zsh/host tmp/zsh/os
 echo echo loaded bash/env.zucker > tmp/shell/env.zucker
 echo echo loaded shell/env.zucker > tmp/shell/env.zucker
+echo echo loaded shell/logout > tmp/shell/logout
 echo echo loaded zsh.env.local > tmp/zsh/env.local
 echo echo loaded zsh/rc.local > tmp/zsh/rc.local
 echo echo loaded zsh/host/rc.zucker > tmp/zsh/host/rc.zucker
@@ -36,9 +37,16 @@ function tests() {
 
     source_config tmp/shell "" env zucker
     echo -n $source_file$source_file_local
+
+    source_config tmp/shell "" logout
+    echo -n $source_file$source_file_local
+    source_config tmp/shell "" doesnt-exist
+    echo -n $source_file$source_file_local
 }
 
 # Run tests without and with debug output.
 tests
 echo
 DEBUG=1 tests
+
+# vim: ft=sh
index 3f473a679ade0cbb766e27c6671c19ce940aeb46..693a4af0d2aa2f804ac553e66e2a2de84f59a0b8 100644 (file)
@@ -2,6 +2,7 @@ loaded zsh/os/rc.Darwin
 loaded zsh/host/rc.zucker
 loaded zsh.env.local
 loaded shell/env.zucker
+loaded shell/logout
 
 source_config(): checking if tmp/zsh/os/rc.Darwin exists
 source_config(): checking if tmp/zsh/rc.local exists
@@ -25,3 +26,10 @@ source_config(): checking if tmp/shell//env.zucker exists
 source_config(): checking if tmp/shell/env.local exists
 source_config(): -> sourcing tmp/shell//env.zucker
 loaded shell/env.zucker
+source_config(): checking if tmp/shell//logout exists
+source_config(): checking if tmp/shell/logout.local exists
+source_config(): -> sourcing tmp/shell//logout
+loaded shell/logout
+source_config(): checking if tmp/shell//doesnt-exist exists
+source_config(): checking if tmp/shell/doesnt-exist.local exists
+source_config(): -> neither exists