mirror of
https://github.com/roles-ansible/ansible_role_dotfiles.git
synced 2024-08-16 16:09:49 +02:00
137 lines
4.1 KiB
Text
137 lines
4.1 KiB
Text
# /etc/bashrc
|
||
{% raw %}
|
||
|
||
# System wide functions and aliases
|
||
# Environment stuff goes in /etc/profile
|
||
|
||
# It's NOT a good idea to change this file unless you know what you
|
||
# are doing. It's much better to create a custom.sh shell script in
|
||
# /etc/profile.d/ to make custom changes to your environment, as this
|
||
# will prevent the need for merging in future updates.
|
||
|
||
# This file may be overwritten by ansible. Please think about commiting
|
||
# changes you want to keep persistent.
|
||
|
||
# Prevent doublesourcing
|
||
if [ -z "$BASHRCSOURCED" ]; then
|
||
BASHRCSOURCED="Y"
|
||
|
||
# are we an interactive shell?
|
||
if [ "$PS1" ]; then
|
||
if [ -z "$PROMPT_COMMAND" ]; then
|
||
case $TERM in
|
||
xterm*|vte*)
|
||
if [ -e /etc/sysconfig/bash-prompt-xterm ]; then
|
||
PROMPT_COMMAND=/etc/sysconfig/bash-prompt-xterm
|
||
elif [ "${VTE_VERSION:-0}" -ge 3405 ]; then
|
||
PROMPT_COMMAND="__vte_prompt_command"
|
||
else
|
||
PROMPT_COMMAND='printf "\033]0;%s@%s:%s\007" "${USER}" "${HOSTNAME%%.*}" "${PWD/#$HOME/\~}"'
|
||
fi
|
||
;;
|
||
screen*)
|
||
if [ -e /etc/sysconfig/bash-prompt-screen ]; then
|
||
PROMPT_COMMAND=/etc/sysconfig/bash-prompt-screen
|
||
else
|
||
PROMPT_COMMAND='printf "\033k%s@%s:%s\033\\" "${USER}" "${HOSTNAME%%.*}" "${PWD/#$HOME/\~}"'
|
||
fi
|
||
;;
|
||
*)
|
||
[ -e /etc/sysconfig/bash-prompt-default ] && PROMPT_COMMAND=/etc/sysconfig/bash-prompt-default
|
||
;;
|
||
esac
|
||
fi
|
||
# Turn on parallel history
|
||
shopt -s histappend
|
||
history -a
|
||
# Turn on checkwinsize
|
||
shopt -s checkwinsize
|
||
[ "$PS1" = "\\s-\\v\\\$ " ] && PS1="[\u@\h \W]\\$ "
|
||
# You might want to have e.g. tty in prompt (e.g. more virtual machines)
|
||
# and console windows
|
||
# If you want to do so, just add e.g.
|
||
if [ "$PS1" ]; then
|
||
{% endraw %}
|
||
PS1="{{ bash['keyboard'] }}"
|
||
{% raw %}
|
||
fi
|
||
# to your custom modification shell script in /etc/profile.d/ directory
|
||
fi
|
||
|
||
if ! shopt -q login_shell ; then # We're not a login shell
|
||
# Need to redefine pathmunge, it gets undefined at the end of /etc/profile
|
||
pathmunge () {
|
||
case ":${PATH}:" in
|
||
*:"$1":*)
|
||
;;
|
||
*)
|
||
if [ "$2" = "after" ] ; then
|
||
PATH=$PATH:$1
|
||
else
|
||
PATH=$1:$PATH
|
||
fi
|
||
esac
|
||
}
|
||
|
||
# By default, we want umask to get set. This sets it for non-login shell.
|
||
# Current threshold for system reserved uid/gids is 200
|
||
# You could check uidgid reservation validity in
|
||
# /usr/share/doc/setup-*/uidgid file
|
||
if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
|
||
umask 002
|
||
else
|
||
umask 022
|
||
fi
|
||
{% endraw %}
|
||
|
||
SHELL="{{ bash['shell'] }}"
|
||
{% raw %}
|
||
|
||
# Only display echos from profile.d scripts if we are no login shell
|
||
# and interactive - otherwise just process them to set envvars
|
||
for i in /etc/profile.d/*.sh; do
|
||
if [ -r "$i" ]; then
|
||
if [ "$PS1" ]; then
|
||
. "$i"
|
||
else
|
||
. "$i" >/dev/null
|
||
fi
|
||
fi
|
||
done
|
||
|
||
unset i
|
||
unset -f pathmunge
|
||
fi
|
||
|
||
fi
|
||
alias ls='ls --color=auto'
|
||
alias dir='dir --color=auto'
|
||
alias vdir='vdir --color=auto'
|
||
|
||
alias grep='grep --color=auto'
|
||
alias fgrep='fgrep --color=auto'
|
||
alias egrep='egrep --color=auto'
|
||
|
||
# colored GCC warnings and errors
|
||
export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'
|
||
|
||
# some more ls aliases
|
||
alias ll='ls -la'
|
||
alias la='ls -A'
|
||
alias l='ls -CF'
|
||
{% endraw %}
|
||
|
||
# default editor
|
||
alias EDITOR='{{ dotfiles_default_editor }}'
|
||
alias VISUAL='{{ dotfiles_default_visual }}'
|
||
|
||
{% if git_typo_alias | bool -%}
|
||
alias got='git'
|
||
{% endif %}
|
||
{% if git_pull_alias | bool -%}
|
||
alias gitsubpull='git submodule foreach "(git checkout master; git pull)"'
|
||
{% endif %}
|
||
|
||
{% if bash['pwgen'] %}alias pwgen="/usr/bin/pwgen --num-passwords=3000 --numerals --capitalize --secure --no-vowels --symbols 42 | grep -v '0' | grep -v 'o' | grep -v 'O' | grep -v '\"' | grep -v 'I' | grep -v 'l' | grep -v '1' | grep -v '´' | grep -v '@' | tail -1 "{% endif %}
|
||
|
||
# vim:ts=4:sw=4
|