From ade93e8b72b3eb4ce579bc00bdd76ff32559e7a8 Mon Sep 17 00:00:00 2001 From: Rasmus Steinke Date: Sat, 10 Sep 2016 18:07:20 +0200 Subject: [PATCH] read password file into array before building fields --- rofi-pass | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/rofi-pass b/rofi-pass index 476732d..4f678ff 100755 --- a/rofi-pass +++ b/rofi-pass @@ -250,18 +250,22 @@ Run ${default_do} with Enter. For more help hit exit fi # generate Array of fields - password_temp=$(PASSWORD_STORE_DIR="${root}" pass "$selected_password") - password="${password_temp%%$'\n'*}" - fields="$(echo "${password_temp}" | tail -n +2)" - pass_key_value=$(echo "${fields}" | awk '$1 ~ /:$/{$1=$1;print}') +# password_temp=$(PASSWORD_STORE_DIR="${root}" pass "$selected_password") +# password="${password_temp%%$'\n'*}" +# fields="$(echo "${password_temp}" | tail -n +2)" +# pass_key_value=$(echo "${fields}" | awk '$1 ~ /:$/{$1=$1;print}') + mapfile -t password_temp < <(PASSWORD_STORE_DIR="${root}" pass "$selected_password") + password=${password_temp[0]} + fields=$(printf '%s\n' "${password_temp[@]:1}" | awk '$1 ~ /:$/{$1=$1;print}') + declare -A stuff stuff["pass"]=${password} - if [[ -n $pass_key_value ]]; then + if [[ -n $fields ]]; then while read -r LINE; do _id="${LINE%%: *}" _val="${LINE#* }" stuff["${_id}"]=${_val} - done < <(echo "${pass_key_value}") + done < <(echo "${fields}") if test "${stuff['autotype']+autotype}" then :