It's how I like it, your mileage may vary.
Mostly, this is a collection of bash functions I have accreted.
Specific install steps at end of this document.
To keep order in my shell aliases, I wanted to put them in discrete files. So, the .rcd
directory is meant to just hold includes to be sourced by .bashrc
/.zshrc
.
#
# Auto-load shell resource files from .rcd
if [ -d ~/.rcd ]; then
for f in ~/.rcd/*
do
if [ -f "$f" ]; then
. "$f"
fi
done
fi
If you add the above to your ...rc
file, you will get most of the benefits of this repo.
Just for fun, I define a custom prompt. There are some other examples commented-out in .bashrc
, so play with it.
See the PS1=
definitions.
I can't believe how many years I went without learning the pushd/popd
shell built-ins. People have come up with pretty complicated solutions to navigating the directory structure.
See help
for pushd
, popd
, and dirs
for an introduction to the built-ins.
TL;DR - Navigate directories by "pushing" onto a stack, or ring. Rotate the ring, or pop-off entries (and change to the new top of the stack). NB: the "top" is index 0, another peculiarity of pushd
, IMO.
I have drastically customized the builtins to make them more intuitive, to me. In particular, I was confused about using indexes. "Rotating" the stack works intuitively with indexes. Rotating +1
, makes the entry at index-1 the top of the stack.
But rotating -1
broke my brain, because it is a zero-based index, not a number of positions. The dir-stack
wrapper of pushd
, subtracts 1 from reverse-indexes, so -1
references the last index in the stack, instead of the second-to-last index.
You can also use nxt
and prv
as aliases for pushd +1
and pushd -0
, respectively. By default, pushd
"exchanges the top two directories. The main wrapper preserves this, but nxt
and prv
default to rotating the ring by one index.
The core wrapper of pushd
is dir-stack
, short-form: pd
, which does:
-c
clears the stack-c
)+
needed, but optional)dir-index
)All of the commands are wrappers for the dir-stack
command, but alter the output and default arguments.
Instead of outputting the current stack, cd
, nxt
and prv
output the contents of the new directory.
Instead of defaulting to advancing one, load-dirs
loads all of the directories in the current directory.
dir-index
/dix
lists the directory stack with indexesdir-stack
/pd
push a directory or move to an index in the stack (+
is optional, -
reverses direction)nxt
/nx
advance the stack and display contentsprv
/pv
reverse the stack and display contentsload-dirs
defaults to adding all of the directories in the current directory (and clearing the previous stack).popd
is still used to remove the top of the stackchange-dir
/cd
another variant wrapper to mimic somewhat the regular cd
command. Updates the stack, instead of always adding new entries when changing to a parent or child directory. Supports the special argument, "-", and defaults to $HOME
with no args. A typical use-case, using short-aliases, could be:
# initialize the stack. (output is same as dir-index/dix)
# note that ToDo/ is de-referenced to the canonical path
mzd@penguin: ~> pd Documents Lab/website/ ToDo
0 ~/Documents/ToDo/projects/active
1 ~/Lab/website
2 ~/Documents
3 ~
# advance to index 1
# the new stack state is displayed
mzd@penguin: ~/Documents/ToDo/projects/active> pd 1
0 ~/Lab/website
1 ~/Documents
2 ~
3 ~/Documents/ToDo/projects/active
# go-back. (new dir contents are displayed in a custom format)
mzd@penguin: ~/website> pv
- /home/mzd/Documents/ToDo/projects/active -
.
├── assets
├── ACTIONS.md
├── Admin.md
├── ERRANDS.md
├── EXPEDITE.md
...
└── Website.md
2 directories, 14 files
Bonus: I recommend you install the
tree
command. This repo contains aliases forld
andlld
to list 2 or 3 levels (respectively) of directories in a formatted tree. Thepushd
wrapper usestree
to display contents, but can default tols
.
This file contains utils motivated by the need to ease working with ssh keys based on fingerprints.
use the source, Luke.
A little guidance for basic GPG key operations. Especially, clearly getting Key ID's and Fingerprints since the regular output doesn't make ID's clear. Required arguments are passed via env, and validation will tell you what is missing.
Most functions are prefixed with gpg-
, so you can discover them with completion. One exception is git-configure-signing()
which is just a friendly wrapper around git config --global
to set your signing-key.
This is just my SSH config file, but the configs in the beginning may be of general interest.
Use the configure-git.sh
script to set git global configs with prompts and defaults that I like.
It will recommend and point you to the functions to configure commit signing (create a key, and update your global config).
I'm quite fond of these. See them in the .rcd/devtools
file. Most start with "dk".
I have not tried deploying the .bashrc
file contents to Zsh, let me know how it goes!
Clone this repo to ~/.dot-profile
(or whatever you want).
You can look for dependencies and recommendations with the included ./system-chk.sh
script. If you run it with verbose (-v
) it will print positive confirmation in addition to checks that fail. You may decide whether to resolve the failed checks or not.
A full setup looks like the following, but you should pick and choose.
# see what is missing
$> source system-chk.sh
# install aliases and custom prompt
$> ln -s .dot-profile/.rcd
$> ln -s .dot-profile/.bashrc
# use ssh config
$> ln -s .dot-profile/ssh_config ~/.ssh/config
# configure git with prompts
$> .dot-profile/configure-git.sh
# generate a new signing key
$> gpg-generate-signing-key USER_NAME='Tenex Dev' EMAIL=you@domain.com
# get the new key ID
$> gpg-list-key-ids
# enable signed commits
$> configure-git-signing KEY_ID=<the-key-id>