tvl-depot/configs/shared/.profile

66 lines
2.5 KiB
Text
Raw Normal View History

# Some programs read from ~/.profile for values. It's best to set environment
# variables here instead of in ~/.zshrc or similar files, which are sourced
# everytime a new shell is created. The ~/.profile, on the other hand, is
# typically sourced only once at login.
# TODO: Consider getting rid of all of these variables and prefer using lorri.
PATH+=":$HOME/bin" # personal
PATH+=":$HOME/.local/bin" # personal
PATH+=":$HOME/.cargo/bin" # Rust
PATH+=":$HOME/.rvm/bin" # Ruby
PATH+=":$HOME/n/bin" # JavaScript, et al
PATH+=":$HOME/.yarn/bin" # JavaScript, et al
PATH+=":$HOME/.yarn/global/node_modules/.bin" # JavaScript, et al
export PATH
systemctl --user import-environment PATH
# Taken from the EXWM configuration documentation.
if [ -z "$DISPLAY" -a "$(tty)" = '/dev/tty5' ]; then
exec xinit -- vt05
fi
# Application preferences
export BROWSER=google-chrome-stable
export TERMINAL=alacritty
export VISUAL=emacsclient
export EDITOR=emacsclient
export ALTERNATE_EDITOR=nvim
# Rust integration. Keep here so programs like Emacs can read this value.
export RUST_SRC_PATH="$(rustc --print sysroot)/lib/rustlib/src/rust/src"
# Application configuration
export FZF_DEFAULT_COMMAND='fd --hidden --follow --exclude ".git"'
export FZF_CTRL_T_COMMAND="$FZF_DEFAULT_COMMAND"
# Prevent compton from fading to the lock screen. This also prevents the white
# overlay that compton was causing to appear. Still unsure why that was
# happening.
# For more information, see the following GitHub issue:
# https://github.com/google/xsecurelock/issues/28
export XSECURELOCK_NO_COMPOSITE=1
# This fixes nixpkgs that rely on glibc-2.27, which allegedly breaks locale
# issues.
# See this thread for more details: https://github.com/NixOS/nixpkgs/issues/8398
export LOCALE_ARCHIVE="$(readlink ~/.nix-profile/lib/locale)/locale-archive"
# Start ssh-agent
eval "$(ssh-agent -s)"
# TODO: Prefer `systemctl start docker.service`
dockerd &
# Set environment variables for Nix. Don't run this for systems running NixOS.
Rename dotfiles -> briefcase Renaming my mono-repo briefcase. I first introduced this commit in master, but it introduced a bug where one of two things would happen: 1. Emacs wouldn't start and would crash X. 2. Emacs would start but my keyboard wouldn't work. I learned some valuable debugging skills in the process. Here are some of them: When my keyboard was broken, I wanted to control my computer using my laptop. Thankfully this is possible by using `x2x`, which forward X events from the SSH client to the SSH host. ```shell > # I'm unsure if this is the *exact* command > ssh -X desktop x2x -west :0.0 ``` Git commit-local bisecting. I didn't need to do a `git bisect` because I knew which commit introduced the bug; it was HEAD, master. But -- as you can see from the size of this commit -- there are many changes involved. I wanted to binary search through the changes, so I did the following workflow using `magit`: - git reset --soft HEAD^ - git stash 1/2 of the files changed - re-run `nix-env -f ~/briefcase/emacs -i` - restart X session - If the problem persists, the bug exists in the non-stashed files. Repeat the process until you find the bug. In my case, the bug was pretty benign. Calling `(exwm/switch "Dotfiles")` at the bottom of `window-manager.el` was failing because "Dotfiles" is the name of a non-existent workspace; it should've been `(exwm/switch "Briefcase")`. There may have been more problems. I changed a few other things along the way, including exposing the env vars BRIEFCASE to `wpcarros-emacs` inside of `emacs/default.nix`. The important part is that this was a valuable learning opportunity, and I'm glad that I'm walking away from the two days of "lost productivity" feeling actually productive.
2020-01-31 16:27:48 +01:00
# TODO: Learn why I can't use the variables from ~/briefcase/.envrc.
case $(hostname) in
zeno.lon.corp.google.com) . ~/.nix-profile/etc/profile.d/nix.sh;;
seneca) . ~/.nix-profile/etc/profile.d/nix.sh;;
wpcarro.c.googlers.com) . ~/.nix-profile/etc/profile.d/nix.sh;;
esac
# NOTE: `lorri` needs to be below the calls to source Nix environment since it's
# installed with `nix-env -iA nixpkgs.lorri`.
# Start lorri daemon
lorri daemon &