Сценарий, над которым я работаю, должен просмотреть каждый файл из git diff. Однако я не знаю, как бороться с пробелами в имени файла. Любые файлы, в которых есть пробел, делятся на «2 файла». Я знаю, что их нужно обернуть в " ", но я не знаю, как этого добиться, прежде чем это перейдет в параметр @.
Если в именах файлов есть пробелы, как мне перебирать файлы из
git diff --name-only $1
?
Вот простой тест, который воспроизводит ошибку:
copyfiles()
{
echo "Copying added files"
for file in $@; do
new_file=$(echo ${file##*/})
directory=$(echo ${file%/*})
echo "Full Path is is $file"
echo "File is $new_file"
echo "Directory is $directory"
cp $file $COPY_TO
done
}
COPY_TO="testDir"
DIFF_FILES=$( git diff --name-only $1)
copyfiles $DIFF_FILES
Скрипт в настоящее время работает так:
test.sh <git commit id>