Add base configuration
- Follow XDG standard: ~/.config and ~/.local folders - Set environment variables and define aliases within ~/.config/shell - Add installation script for easy setup - Add README.md with info on the installation and general notes
This commit is contained in:
commit
f0e143242b
10 changed files with 228 additions and 0 deletions
8
.bashrc
Normal file
8
.bashrc
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
#!/bin/bash
|
||||
|
||||
# `bash`-specific configurations
|
||||
|
||||
|
||||
# Load configuration files common to all kinds of shells,
|
||||
# if not already done by a `bash` login shell
|
||||
[ -z "$PROFILE_LOADED" ] && [ -f "$HOME/.profile" ] && . "$HOME/.profile"
|
||||
3
.config/shell/README.md
Normal file
3
.config/shell/README.md
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
# Shell-related Configurations
|
||||
|
||||
This folder contains files that are sourced by `bash` and `zsh`.
|
||||
7
.config/shell/aliases
Normal file
7
.config/shell/aliases
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Aliases used in all kinds of shells
|
||||
|
||||
|
||||
# Manage the bare `git` repository in ~/ holding the dotfiles
|
||||
alias dotfiles='git --git-dir=$XDG_DATA_HOME/dotfiles --work-tree=$HOME'
|
||||
28
.config/shell/env
Normal file
28
.config/shell/env
Normal file
|
|
@ -0,0 +1,28 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Environment variables for all kinds of shells
|
||||
|
||||
|
||||
# Standard XDG base directories
|
||||
# See: https://wiki.archlinux.org/title/XDG_Base_Directory
|
||||
export XDG_CACHE_HOME="$HOME/.cache"
|
||||
export XDG_CONFIG_HOME="$HOME/.config"
|
||||
export XDG_DATA_HOME="$HOME/.local/share" # also set in ~/.local/bin/install-dotfiles
|
||||
export XDG_STATE_HOME="$HOME/.local/state"
|
||||
# Make up a XDG directory for binaries (that does not exist in the standard)
|
||||
export XDG_BIN_HOME="$HOME/.local/bin"
|
||||
|
||||
|
||||
# Convenient names for various places in the system
|
||||
export DOTFILES_DIR="$XDG_DATA_HOME/dotfiles" # also set in ~/.local/bin/install-dotfiles
|
||||
|
||||
|
||||
# Generic shell configs
|
||||
export GPG_TTY=$(tty)
|
||||
export PAGER="less --chop-long-lines --ignore-case --LONG-PROMPT --no-init --status-column --quit-if-one-screen"
|
||||
export TERM=xterm-256color
|
||||
export TZ="Europe/Berlin"
|
||||
|
||||
|
||||
# Move common tools' config and cache files into XDG directories
|
||||
export LESSHISTFILE="$XDG_STATE_HOME/less/history"
|
||||
3
.local/bin/README.md
Normal file
3
.local/bin/README.md
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
# User-local Executables
|
||||
|
||||
This folder contains executable files that are on the `$PATH`.
|
||||
74
.local/bin/install-dotfiles
Executable file
74
.local/bin/install-dotfiles
Executable file
|
|
@ -0,0 +1,74 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Installation script to make the dotfiles available in ~/
|
||||
#
|
||||
# `git` is the only dependency for this script to run (See: https://git-scm.com)
|
||||
#
|
||||
# See: https://code.webartifex.biz/alexander/dotfiles#installation
|
||||
|
||||
|
||||
set -e
|
||||
|
||||
|
||||
XDG_DATA_HOME="$HOME/.local/share" # also set in ~/.config/shell/env
|
||||
DOTFILES_DIR="$XDG_DATA_HOME/dotfiles" # also set in ~/.config/shell/env
|
||||
|
||||
|
||||
# Check if the dotfiles were installed previously
|
||||
if [ -d "$DOTFILES_DIR" ] && [ "${FORCE_INSTALL:-}" != "1" ]; then
|
||||
echo ""
|
||||
echo "The dotfiles are already installed at: $DOTFILES_DIR"
|
||||
echo ""
|
||||
echo "Options:"
|
||||
echo " - Set 'export FORCE_INSTALL=1' and run installation again"
|
||||
echo " - Update with 'dotfiles pull' and continue using them"
|
||||
echo ""
|
||||
else
|
||||
# Remove an already installed dotfiles repository
|
||||
if [ -d "$DOTFILES_DIR" ]; then
|
||||
rm -rf "$DOTFILES_DIR"
|
||||
fi
|
||||
|
||||
if [ -z "$DOTFILES_BRANCH" ]; then
|
||||
# Auto-detect if we're on a desktop system
|
||||
if [ -n "$DISPLAY" ] || [ -n "$WAYLAND_DISPLAY" ] || [ "$(systemctl --user is-active graphical-session.target 2>/dev/null)" = "active" ]; then
|
||||
export DOTFILES_BRANCH="desktop"
|
||||
else
|
||||
export DOTFILES_BRANCH="main"
|
||||
fi
|
||||
elif [ "$DOTFILES_BRANCH" != "desktop" ] && [ "$DOTFILES_BRANCH" != "main" ]; then
|
||||
echo ""
|
||||
echo "'DOTFILES_BRANCH' may only be one of: 'desktop' or 'main'"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
mkdir -p "$XDG_DATA_HOME"
|
||||
|
||||
git clone --bare https://code.webartifex.biz/alexander/dotfiles "$XDG_DATA_HOME/dotfiles"
|
||||
|
||||
# Do not checkout project documentation intended for web GUIs (e.g., GitHub)
|
||||
git --git-dir="$DOTFILES_DIR" --work-tree="$HOME" config core.sparseCheckout true
|
||||
echo "/*" > "$DOTFILES_DIR/info/sparse-checkout"
|
||||
echo "!LICENSE.txt" >> "$DOTFILES_DIR/info/sparse-checkout"
|
||||
echo "!README.md" >> "$DOTFILES_DIR/info/sparse-checkout"
|
||||
|
||||
# Put the dotfiles in the user's `$HOME` folder
|
||||
git --git-dir="$DOTFILES_DIR" --work-tree="$HOME" checkout --force "$DOTFILES_BRANCH"
|
||||
|
||||
# Do not show files not tracked in the dotfiles repository because there are simply too many
|
||||
git --git-dir="$DOTFILES_DIR" --work-tree="$HOME" config --local status.showUntrackedFiles no
|
||||
|
||||
# The author of this file prefers to use SSH to sync his machines with the origin
|
||||
git --git-dir="$DOTFILES_DIR" --work-tree="$HOME" remote set-url origin git@git.webartifex.biz:alexander/dotfiles.git
|
||||
|
||||
echo ""
|
||||
echo "The dotfiles were installed successfully"
|
||||
|
||||
# Mimic starting a new shell to get new dotfiles right away
|
||||
if [ -n "$ZSH_VERSION" ]; then
|
||||
. "$HOME/.zshrc"
|
||||
else
|
||||
. "$HOME/.profile"
|
||||
fi
|
||||
|
||||
fi
|
||||
0
.local/state/less/.gitkeep
Normal file
0
.local/state/less/.gitkeep
Normal file
54
.profile
Normal file
54
.profile
Normal file
|
|
@ -0,0 +1,54 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Main setup file executed for all kinds of shells
|
||||
|
||||
|
||||
# Prevent loading ~/.profile twice in `bash`
|
||||
export PROFILE_LOADED=1
|
||||
|
||||
|
||||
# Basic utilities
|
||||
|
||||
_command_exists() {
|
||||
command -v "$1" 1>/dev/null 2>&1
|
||||
}
|
||||
|
||||
_in_bash() {
|
||||
[ -n "$BASH_VERSION" ]
|
||||
}
|
||||
|
||||
_in_zsh() {
|
||||
[ -n "$ZSH_VERSION" ]
|
||||
}
|
||||
|
||||
_prepend_to_path () {
|
||||
if [ -d "$1" ] ; then
|
||||
case :$PATH: in
|
||||
*:$1:*) ;;
|
||||
*) PATH=$1:$PATH ;;
|
||||
esac
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
# Load configuration files common to all kinds of shells
|
||||
[ -f "$HOME/.config/shell/env" ] && . "$HOME/.config/shell/env"
|
||||
[ -f "$HOME/.config/shell/aliases" ] && . "$HOME/.config/shell/aliases"
|
||||
|
||||
|
||||
# Source ~/.profile_local, which holds machine-specific ENV variables
|
||||
[ -f "$HOME/.profile_local" ] && . "$HOME/.profile_local"
|
||||
|
||||
|
||||
# Load `bash`-specific configurations for non-login `bash` shells
|
||||
if [ -n "$BASH_VERSION" ] && [ -f "$HOME/.bashrc" ]; then
|
||||
. "$HOME/.bashrc"
|
||||
fi
|
||||
|
||||
|
||||
# Put local executables on the `$PATH`
|
||||
_prepend_to_path "$HOME/.local/bin"
|
||||
|
||||
|
||||
# Ensure ~/.profile is loaded each time `bash` starts
|
||||
unset PROFILE_LOADED
|
||||
7
.zshrc
Normal file
7
.zshrc
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
#!/bin/zsh
|
||||
|
||||
# `zsh`-specific configurations
|
||||
|
||||
|
||||
# Load configuration files common to all kinds of shells
|
||||
[ -f "$HOME/.profile" ] && . "$HOME/.profile"
|
||||
44
README.md
Normal file
44
README.md
Normal file
|
|
@ -0,0 +1,44 @@
|
|||
# Dotfiles
|
||||
|
||||
This repository contains useful (config) files.
|
||||
|
||||
It is structured into two branches:
|
||||
- [desktop](https://code.webartifex.biz/alexander/dotfiles/src/branch/desktop)
|
||||
- [main](https://code.webartifex.biz/alexander/dotfiles/src/branch/main)
|
||||
|
||||
`main` contains dotfiles intended to be used on all kinds of machines
|
||||
and can be thought of as a "minimal" or "server" version.
|
||||
`desktop` is (re-)based on top of `main`
|
||||
and adds "desktop" related dotfiles (e.g., GNOME stuff).
|
||||
|
||||
|
||||
## Installation
|
||||
|
||||
Simply run:
|
||||
|
||||
```sh
|
||||
curl https://code.webartifex.biz/alexander/dotfiles/raw/branch/main/.local/bin/install-dotfiles > install-dotfiles && . ./install-dotfiles && rm ./install-dotfiles
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```
|
||||
wget https://code.webartifex.biz/alexander/dotfiles/raw/branch/main/.local/bin/install-dotfiles -O install-dotfiles && . ./install-dotfiles && rm ./install-dotfiles
|
||||
```
|
||||
|
||||
This downloads a simple [installation script](.local/bin/install-dotfiles)
|
||||
and then executes it.
|
||||
The script has only one dependency, namely [git](https://git-scm.com).
|
||||
So, it should not be too hard to get this going.
|
||||
|
||||
Normally, I advice against executing shell scripts from the internet,
|
||||
but this one is short enough to be read even by beginners.
|
||||
So, convince yourself that it is not harmful!
|
||||
|
||||
|
||||
## Shells
|
||||
|
||||
The config files in this repository are optimized for usage with
|
||||
[GNU's Bourne again shell](https://man7.org/linux/man-pages/man1/bash.1.html),
|
||||
or `bash` for short,
|
||||
and the popular [zsh](https://www.zsh.org/).
|
||||
Loading…
Reference in a new issue