From f5b1ec25e7d0469940b9d3904d64919f2c109d00 Mon Sep 17 00:00:00 2001 From: Ian Henry Date: Sat, 26 Feb 2022 16:06:17 -0800 Subject: [PATCH] set the SD environment variable $SD is now a shorthand for $(dirname "$0") --- README.md | 7 +++++++ sd | 2 +- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index e573b4c..cdca0ec 100644 --- a/README.md +++ b/README.md @@ -183,6 +183,12 @@ Will invoke: $ ~/sd/foo/bar --help --really +# Context + +When a script is invoked, `sd` will set the environment variable `SD` to the directory that the script was found in -- in other words, `$(dirname "$0")`. + +This makes it slightly more convenient to refer to shared helper files or other scripts relative to the executing script. + # Options `sd` respects some environment variables: @@ -263,6 +269,7 @@ There are no *releases* of `sd`, per se, but I have occasionally made changes. ## 2021-02-26 +- scripts now run with the `SD` environment variable set to the directory they were found in - autocompletion now completes arguments to commands instead of just commands - only completes positional file arguments and the built-in flags (like `--help`) - `sd` now only forks a subshell when invoked as a function diff --git a/sd b/sd index 51c9eb5..f587be0 100755 --- a/sd +++ b/sd @@ -248,7 +248,7 @@ __sd() { exit 1 fi elif [[ -x "$target" ]]; then - exec "$target" "$@" + SD="$(dirname "$target")" exec "$target" "$@" else __sd_cat "$@" fi