]> 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 455ce0dd0eeb32b610cce470a374246cd0e99d61..7243ceb963138fbb99f7f923e0540a94f11f55dc 100644 (file)
--- a/bash/rc
+++ b/bash/rc
@@ -1,10 +1,54 @@
 # Main bash configuration file.
+#
+# Is sourced by all interactive shells and other shells like scp or rcp.
 
 
-# Use UTF-8 encoding in the terminal.
-export LC_ALL=en_US.UTF-8
+# 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
+    . ~/.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
+
+
+# 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 Vim as editor.
-export EDITOR='vim'
 # 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 host rc $host
+
+source_debug ". ~/.bash/rc (done)"
+
+# vim: ft=sh