1
0
Fork 0
mirror of synced 2024-12-04 14:45:36 -05:00

Use git ls-files to list files to encrypt

By using git ls-files instead of bash we can support ** also on macOS where the
included bash version (3) doesn't support globstar.
This commit is contained in:
Erik Flodin 2024-11-24 22:56:07 +01:00
parent 5b44afaece
commit 4af3336c45
No known key found for this signature in database
GPG key ID: 420A7C865EE3F85F
3 changed files with 24 additions and 60 deletions

View file

@ -105,7 +105,8 @@ def create_test_encrypt_data(paths):
edata += "dirwild*\n" edata += "dirwild*\n"
paths.work.join("dirwildcard/file1").write("", ensure=True) paths.work.join("dirwildcard/file1").write("", ensure=True)
paths.work.join("dirwildcard/file2").write("", ensure=True) paths.work.join("dirwildcard/file2").write("", ensure=True)
expected.add("dirwildcard") expected.add("dirwildcard/file1")
expected.add("dirwildcard/file2")
# excludes # excludes
edata += "exclude*\n" edata += "exclude*\n"
@ -186,9 +187,7 @@ def run_parse_encrypt(runner, paths, skip_parse=False, twice=False):
YADM_WORK={paths.work} YADM_WORK={paths.work}
export YADM_WORK export YADM_WORK
{parse_cmd} {parse_cmd}
export ENCRYPT_INCLUDE_FILES echo PARSE_ENCRYPT_SHORT=$PARSE_ENCRYPT_SHORT
export PARSE_ENCRYPT_SHORT
env
echo EIF_COUNT:${{#ENCRYPT_INCLUDE_FILES[@]}} echo EIF_COUNT:${{#ENCRYPT_INCLUDE_FILES[@]}}
for value in "${{ENCRYPT_INCLUDE_FILES[@]}}"; do for value in "${{ENCRYPT_INCLUDE_FILES[@]}}"; do
echo "EIF:$value" echo "EIF:$value"

65
yadm
View file

@ -1940,65 +1940,30 @@ function parse_encrypt() {
fi fi
ENCRYPT_INCLUDE_FILES=() ENCRYPT_INCLUDE_FILES=()
ENCRYPT_EXCLUDE_FILES=()
FINAL_INCLUDE=()
[ -f "$YADM_ENCRYPT" ] || return [ -f "$YADM_ENCRYPT" ] || return
cd_work "Parsing encrypt" || return cd_work "Parsing encrypt" || return
# setting globstar to allow ** in encrypt patterns local -a exclude
# (only supported on Bash >= 4) local -a include
local unset_globstar
if ! shopt globstar &> /dev/null; then
unset_globstar=1
fi
shopt -s globstar &> /dev/null
exclude_pattern="^!(.+)" while IFS= read -r pattern; do
# parse both included/excluded if [[ $pattern =~ ^# || $pattern =~ ^[[:blank:]]*$ ]]; then
while IFS='' read -r line || [ -n "$line" ]; do continue
if [[ ! $line =~ ^# && ! $line =~ ^[[:blank:]]*$ ]] ; then fi
local IFS=$'\n' if [[ $pattern =~ ^!(.*)$ ]]; then
for pattern in $line; do exclude+=(--exclude "${pattern:1}")
if [[ "$pattern" =~ $exclude_pattern ]]; then else
for ex_file in ${BASH_REMATCH[1]}; do include+=("$pattern")
if [ -e "$ex_file" ]; then fi
ENCRYPT_EXCLUDE_FILES+=("$ex_file")
fi
done
else
for in_file in $pattern; do
if [ -e "$in_file" ]; then
ENCRYPT_INCLUDE_FILES+=("$in_file")
fi
done
fi
done
fi
done < "$YADM_ENCRYPT" done < "$YADM_ENCRYPT"
# remove excludes from the includes if [[ ${#include} -gt 0 ]]; then
#(SC2068 is disabled because in this case, we desire globbing) while IFS= read -r filename; do
#shellcheck disable=SC2068 ENCRYPT_INCLUDE_FILES+=("$filename")
for included in "${ENCRYPT_INCLUDE_FILES[@]}"; do done < <("$GIT_PROGRAM" ls-files --others "${exclude[@]}" -- "${include[@]}")
skip=
#shellcheck disable=SC2068
for ex_file in ${ENCRYPT_EXCLUDE_FILES[@]}; do
[ "$included" == "$ex_file" ] && { skip=1; break; }
done
[ -n "$skip" ] || FINAL_INCLUDE+=("$included")
done
# sort the encrypted files
#shellcheck disable=SC2207
IFS=$'\n' ENCRYPT_INCLUDE_FILES=($(LC_ALL=C sort <<<"${FINAL_INCLUDE[*]}"))
unset IFS
if [ "$unset_globstar" = "1" ]; then
shopt -u globstar &> /dev/null
fi fi
} }
function builtin_dirname() { function builtin_dirname() {

12
yadm.1
View file

@ -750,7 +750,8 @@ gpg is used by default, but openssl can be configured with the
.I yadm.cipher .I yadm.cipher
configuration. configuration.
To use this feature, a list of patterns must be created and saved as To use this feature, a list of patterns (one per line) must be created and
saved as
.IR $HOME/.config/yadm/encrypt . .IR $HOME/.config/yadm/encrypt .
This list of patterns should be relative to the configured This list of patterns should be relative to the configured
.IR work-tree \ (usually\ $HOME ). .IR work-tree \ (usually\ $HOME ).
@ -761,11 +762,10 @@ For example:
.gnupg/*.gpg .gnupg/*.gpg
.RE .RE
Standard filename expansions (*, ?, [) are supported. Standard filename expansions (*, ?, [) are supported. Two consecutive asterisks
If you have Bash version 4, you may use "**" to match all subdirectories. "**" can be used to match all subdirectories. Other shell expansions like
Other shell expansions like brace and tilde are not supported. brace and tilde are not supported. Spaces in paths are supported, and should
Spaces in paths are supported, and should not be quoted. not be quoted. If a directory is specified, its contents will be included.
If a directory is specified, its contents will be included, but not recursively.
Paths beginning with a "!" will be excluded. Paths beginning with a "!" will be excluded.
The The