From 2a7a1e8ae03e03deace396b61ed5d08add6c6c23 Mon Sep 17 00:00:00 2001 From: Ekaitz Zarraga Date: Mon, 2 Mar 2020 11:33:03 +0100 Subject: Running in guix --- bash/.bash_aliases | 15 +++--- bash/.bash_profile | 5 -- bash/.bashrc | 149 +++++++++++------------------------------------------ 3 files changed, 38 insertions(+), 131 deletions(-) (limited to 'bash') diff --git a/bash/.bash_aliases b/bash/.bash_aliases index e9dcea3..55b8292 100644 --- a/bash/.bash_aliases +++ b/bash/.bash_aliases @@ -9,13 +9,10 @@ alias r='ssh -l root' alias fuck='COMMAND=$(history -p \!\!); echo sudo $COMMAND; sudo $COMMAND' # enable color support of ls and also add handy aliases -if [ -x /usr/bin/dircolors ]; then - test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)" - alias ls='ls --color=auto' - alias grep='grep --color=auto' - alias fgrep='fgrep --color=auto' - alias egrep='egrep --color=auto' -fi +alias ls='ls --color=auto' +alias grep='grep --color=auto' +alias fgrep='fgrep --color=auto' +alias egrep='egrep --color=auto' # some more ls aliases alias ll='ls -alF' @@ -41,3 +38,7 @@ alias pandoc-xelatex="pandoc $@ --pdf-engine=xelatex --to latex -N" alias elenqdoc-article="pandoc-xelatex $@ --standalone --template elenq-article --metadata=documentclass:article" alias elenqdoc-book="pandoc-xelatex $@ --standalone --template elenq-book --metadata=documentclass:book --top-level-division=chapter" +# Kitty +if [ $TERM = "xterm-kitty" ]; then + alias ssh="kitty +kitten ssh" +fi diff --git a/bash/.bash_profile b/bash/.bash_profile index fe92a75..7d5f3c9 100644 --- a/bash/.bash_profile +++ b/bash/.bash_profile @@ -1,8 +1,3 @@ -# Create .config if it doesn't exist and set XDG vars if they are unset -mkdir -p $HOME/.config -export XDG_CONFIG_HOME=${XDG_CONFIG_HOME:=$HOME/.config} -export XDG_DATA_HOME=${XDG_DATA_HOME:=$HOME/.config} - # Load bashrc to mantain only one file if [ -f "$HOME/.bashrc" ]; then source "$HOME/.bashrc" diff --git a/bash/.bashrc b/bash/.bashrc index defe7ff..df74698 100644 --- a/bash/.bashrc +++ b/bash/.bashrc @@ -1,89 +1,20 @@ -# ~/.bashrc: executed by bash(1) for non-login shells. -# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) -# for examples +# Bash initialization for interactive non-login shells and +# for remote shells (info "(bash) Bash Startup Files"). -# If not running interactively, don't do anything -case $- in - *i*) ;; - *) return;; -esac +export SHELL -# don't put duplicate lines or lines starting with space in the history. -# See bash(1) for more options -HISTCONTROL=ignoreboth - -# append to the history file, don't overwrite it -shopt -s histappend - -# for setting history length see HISTSIZE and HISTFILESIZE in bash(1) -HISTSIZE=1000 -HISTFILESIZE=2000 - -# check the window size after each command and, if necessary, -# update the values of LINES and COLUMNS. -shopt -s checkwinsize - -# If set, the pattern "**" used in a pathname expansion context will -# match all files and zero or more directories and subdirectories. -#shopt -s globstar - -# make less more friendly for non-text input files, see lesspipe(1) -[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)" - -# set variable identifying the chroot you work in (used in the prompt below) -if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then - debian_chroot=$(cat /etc/debian_chroot) -fi - -# set a fancy prompt (non-color, unless we know we "want" color) -case "$TERM" in - xterm-color|*-256color) color_prompt=yes;; -esac - -# uncomment for a colored prompt, if the terminal has the capability; turned -# off by default to not distract the user: the focus in a terminal window -# should be on the output of commands, not on the prompt -#force_color_prompt=yes - -if [ -n "$force_color_prompt" ]; then - if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then - # We have color support; assume it's compliant with Ecma-48 - # (ISO/IEC-6429). (Lack of such support is extremely rare, and such - # a case would tend to support setf rather than setaf.) - color_prompt=yes - else - color_prompt= - fi -fi +if [[ $- != *i* ]] +then + # We are being invoked from a non-interactive shell. If this + # is an SSH session (as in "ssh host command"), source + # /etc/profile so we get PATH and other essential variables. + [[ -n "$SSH_CLIENT" ]] && source /etc/profile -if [ "$color_prompt" = yes ]; then - PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ ' -else - PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ ' + # Don't do anything else. + return fi -unset color_prompt force_color_prompt - -# If this is an xterm set the title to user@host:dir -case "$TERM" in -xterm*|rxvt*) - PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1" - ;; -*) - ;; -esac -# colored GCC warnings and errors -export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01' - - -# enable programmable completion features -if ! shopt -oq posix; then - if [ -f /usr/share/bash-completion/bash_completion ]; then - . /usr/share/bash-completion/bash_completion - elif [ -f /etc/bash_completion ]; then - . /etc/bash_completion - fi -fi +source /etc/bashrc # VARIABLE EXPORTS ###################################################################### @@ -99,19 +30,30 @@ export COLOR_DEFAULT="\[\033[0;39m\]" export COLOR_WHITE=$COLOR_DEFAULT export EDITOR=nvim +PATH=$PATH:$HOME/.local/bin + +# PROMPT +PS1BASE="$COLOR_BLUE\u$COLOR_GREY@\h $COLOR_YELLOW\w\[\033[00m\]" -# Guile (guix) -export GUILE_LOAD_PATH="$HOME/.guix-profile/share/guile/site/2.2${GUILE_LOAD_PATH:+:}$GUILE_LOAD_PATH" -export GUILE_LOAD_COMPILED_PATH="$HOME/.guix-profile/lib/guile/2.2/site-ccache${GUILE_LOAD_COMPILED_PATH:+:}$GUILE_LOAD_COMPILED_PATH" +#PS1BASE="$COLOR_CYAN\u $COLOR_YELLOW\w\[\033[m\]" +PS1GIT="$COLOR_BLUE\$(__git_ps1)$COLOR_DEFAULT" +PS1END="$COLOR_DEFAULT\$ " +export PS1="${PS1BASE}${PS1GIT}${PS1END}" -export PATH="$HOME/.config/guix/current/bin${PATH:+:}$PATH" -export PATH="$HOME/.guix-profile/bin${PATH:+:}$PATH" -export GUIX_LOCPATH="$HOME/.guix-profile/lib/locale" # Locale directory +# GUIX +###################################################################### +# Adjust the prompt depending on whether we're in 'guix environment'. +if [ -n "$GUIX_ENVIRONMENT" ] +then + PS1="$PS1BASE$PS1GIT [env]$PS1END" +fi ###################################################################### # Pandoc bash completion -eval "$(pandoc --bash-completion)" +if hash pandoc 2>/dev/null; then + eval "$(pandoc --bash-completion)" +fi # Load in the git branch prompt script. source ~/.git-prompt.sh @@ -121,34 +63,3 @@ if [ -f ~/.bash_aliases ] ; then . ~/.bash_aliases fi -# PROMPT -PS1BASE="\[\e]0;\u: \w\a\]${debian_chroot:+($debian_chroot)}$COLOR_BLUE\u\[\033[00m\] $COLOR_YELLOW\w\[\033[00m\]" - -#PS1BASE="$COLOR_CYAN\u $COLOR_YELLOW\w\[\033[m\]" -PS1GIT="$COLOR_BLUE\$(__git_ps1)$COLOR_DEFAULT" -PS1END="$COLOR_DEFAULT\$ " -export PS1="${PS1BASE}${PS1GIT}${PS1END}" - -# Guix -if [ -n "$GUIX_ENVIRONMENT" ] # Change prompt if shell is in an environment -then - PS1GUIXENV="$COLOR_RED(guixenv)$COLOR_DEFAULT" - PS1="${PS1BASE}${PS1GIT}${PS1GUIXENV}${PS1END}" -fi -export SSL_CERT_DIR="$HOME/.guix-profile/etc/ssl/certs" -export SSL_CERT_FILE="$HOME/.guix-profile/etc/ssl/certs/ca-certificates.crt" - -# Python virtualenvwrapper -export WORKON_HOME=~/Envs -mkdir -p $WORKON_HOME -source /usr/local/bin/virtualenvwrapper.sh - -# Microchip -export PATH="$PATH:/opt/microchip/xc8/v1.44/bin" - -# Rust -export PATH="$HOME/.cargo/bin:$PATH" - -# Direnv -eval "$(direnv hook bash)" - -- cgit v1.2.3