]> ruderich.org/simon Gitweb - config/dotfiles.git/blobdiff - bash/rc
Improve source_debug() output.
[config/dotfiles.git] / bash / rc
diff --git a/bash/rc b/bash/rc
index 9f84fc78f7b3385e016429f9242199a516c5141f..7243ceb963138fbb99f7f923e0540a94f11f55dc 100644 (file)
--- a/bash/rc
+++ b/bash/rc
@@ -1,29 +1,54 @@
 # Main bash configuration file.
+#
+# Is sourced by all interactive shells and other shells like scp or rcp.
 
 
 # Get the current hostname (first part before a dot).
 host=$(echo $(hostname) | sed -e 's/\..*$//')
 
 # Load environmental related settings used by all shells.
-if [ -f ~/.shell/env ]; then
-    source ~/.shell/env
+if [[ -f ~/.shell/env ]]; then
+    . ~/.shell/env
+# Fallback functions as ~/.shell/env couldn't be loaded.
 else
+    function source_debug() {
+        echo $@
+    }
     function source_config() {
         echo "Couldn't load source_config(), can't source files." >&2
     }
 fi
 
+source_debug ". ~/.bash/rc"
+
 # Load global env file for current hostname (first part before a dot) or
 # global env.local.
 source_config ~/.shell "" env $host
 
-# Set the prompt; hostname and current working directory are displayed.
-PS1="\h:\w \$ "
+
+# Check if this is an interactive shell. Abort if not to prevent problems with
+# scp and rcp. Taken from default Debian bashrc. Thanks.
+if [[ $- != *i* ]]; then
+    return
+fi
 
 
+# Set the prompt; hostname and current working directory are displayed.
+# Hostname is displayed in green, current directory in blue.
+PS1='\[\033[01;32m\]\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\] \$ '
+
 # Use Vi(m) style in bash.
 set -o vi
 
+# Load aliases and similar functions also used by other shells.
+if [[ -f ~/.shell/aliases ]]; then
+    . ~/.shell/aliases
+fi
+
 
 # Load rc file for current hostname (first part before a dot) or rc.local.
-source_config ~/.bash "" rc $host
+source_config ~/.bash host rc $host
+
+source_debug ". ~/.bash/rc (done)"
+
+# vim: ft=sh