summaryrefslogtreecommitdiff
path: root/plugins/dotenv
diff options
context:
space:
mode:
authorMarc Cornellà <hello@mcornella.com>2021-06-28 15:54:24 +0200
committerMarc Cornellà <hello@mcornella.com>2021-07-07 10:41:14 +0200
commitc44b99e901d7ef58f60247995152de1b937e2e9c (patch)
treec6b14b85c1d2bfacc5f078585339658bae4d2de1 /plugins/dotenv
parent0e7d7b87f33b5ec8c75a3a0a9b16fae082d06348 (diff)
downloadzsh-c44b99e901d7ef58f60247995152de1b937e2e9c.tar.gz
zsh-c44b99e901d7ef58f60247995152de1b937e2e9c.tar.bz2
zsh-c44b99e901d7ef58f60247995152de1b937e2e9c.zip
fix(dotenv): draw confirmation prompt in next empty line
Without this fix the confirmation prompt appears wherever the cursor is, which means that it might appear in the command line when using a widget that changes the directory without redrawing the prompt (an example of this are the dircycle and dirhistory plugins).
Diffstat (limited to 'plugins/dotenv')
-rw-r--r--plugins/dotenv/dotenv.plugin.zsh72
1 files changed, 41 insertions, 31 deletions
diff --git a/plugins/dotenv/dotenv.plugin.zsh b/plugins/dotenv/dotenv.plugin.zsh
index 24f285df5..40ec5c46f 100644
--- a/plugins/dotenv/dotenv.plugin.zsh
+++ b/plugins/dotenv/dotenv.plugin.zsh
@@ -11,41 +11,51 @@
## Functions
source_env() {
- if [[ -f $ZSH_DOTENV_FILE ]]; then
- if [[ "$ZSH_DOTENV_PROMPT" != false ]]; then
- local confirmation dirpath="${PWD:A}"
-
- # make sure there is an (dis-)allowed file
- touch "$ZSH_DOTENV_ALLOWED_LIST"
- touch "$ZSH_DOTENV_DISALLOWED_LIST"
-
- # early return if disallowed
- if grep -q "$dirpath" "$ZSH_DOTENV_DISALLOWED_LIST" &>/dev/null; then
- return;
- fi
-
- # check if current directory's .env file is allowed or ask for confirmation
- if ! grep -q "$dirpath" "$ZSH_DOTENV_ALLOWED_LIST" &>/dev/null; then
- # print same-line prompt and output newline character if necessary
- echo -n "dotenv: found '$ZSH_DOTENV_FILE' file. Source it? ([Y]es/[n]o/[a]lways/n[e]ver) "
- read -k 1 confirmation; [[ "$confirmation" != $'\n' ]] && echo
-
- # check input
- case "$confirmation" in
- [nN]) return ;;
- [aA]) echo "$dirpath" >> "$ZSH_DOTENV_ALLOWED_LIST" ;;
- [eE]) echo "$dirpath" >> "$ZSH_DOTENV_DISALLOWED_LIST"; return ;;
- *) ;; # interpret anything else as a yes
- esac
- fi
+ if [[ ! -f "$ZSH_DOTENV_FILE" ]]; then
+ return
+ fi
+
+ if [[ "$ZSH_DOTENV_PROMPT" != false ]]; then
+ local confirmation dirpath="${PWD:A}"
+
+ # make sure there is an (dis-)allowed file
+ touch "$ZSH_DOTENV_ALLOWED_LIST"
+ touch "$ZSH_DOTENV_DISALLOWED_LIST"
+
+ # early return if disallowed
+ if command grep -q "$dirpath" "$ZSH_DOTENV_DISALLOWED_LIST" &>/dev/null; then
+ return
fi
- # test .env syntax
- zsh -fn $ZSH_DOTENV_FILE || echo "dotenv: error when sourcing '$ZSH_DOTENV_FILE' file" >&2
+ # check if current directory's .env file is allowed or ask for confirmation
+ if ! command grep -q "$dirpath" "$ZSH_DOTENV_ALLOWED_LIST" &>/dev/null; then
+ # get cursor column and print new line before prompt if not at line beginning
+ local column
+ echo -ne "\e[6n" > /dev/tty
+ read -t 1 -s -d R column < /dev/tty
+ column="${column##*\[*;}"
+ [[ $column -eq 1 ]] || echo
- setopt localoptions allexport
- source $ZSH_DOTENV_FILE
+ # print same-line prompt and output newline character if necessary
+ echo -n "dotenv: found '$ZSH_DOTENV_FILE' file. Source it? ([Y]es/[n]o/[a]lways/n[e]ver) "
+ read -k 1 confirmation
+ [[ "$confirmation" = $'\n' ]] || echo
+
+ # check input
+ case "$confirmation" in
+ [nN]) return ;;
+ [aA]) echo "$dirpath" >> "$ZSH_DOTENV_ALLOWED_LIST" ;;
+ [eE]) echo "$dirpath" >> "$ZSH_DOTENV_DISALLOWED_LIST"; return ;;
+ *) ;; # interpret anything else as a yes
+ esac
+ fi
fi
+
+ # test .env syntax
+ zsh -fn $ZSH_DOTENV_FILE || echo "dotenv: error when sourcing '$ZSH_DOTENV_FILE' file" >&2
+
+ setopt localoptions allexport
+ source $ZSH_DOTENV_FILE
}
autoload -U add-zsh-hook