git — исправление PHP-CS-Fixer в хуке precommit, но файл не добавляет коммит

Я хочу автоматически исправить файлы с помощью php-cs-fixer перед фиксацией, а затем зафиксировать изменения, включая эти исправления

Итак, я создал файл предварительной фиксации, но у меня есть проблемы:

1) Я не могу узнать, какой файл был изменен (возможно, просто проблема с bash)

2) Если я запускаю «git add» без условий, изменения включаются в коммит, но не в сами файлы

Я попытался ясно показать это в комментариях о хуке, так что вот оно:

#!/usr/bin/env bash

# get the list of changed files
staged_files=$(git diff --cached --name-only)

# command to fix files
cmd='vendor/bin/php-cs-fixer fix %s -q'
if [ -f 'php_cs_fixer_rules.php' ]; then
cmd='vendor/bin/php-cs-fixer fix %s -q --config=php_cs_fixer_rules.php'
fi

for staged in ${staged_files}; do # this cycle exactly works
# work only with existing files
if [[ -f ${staged} && ${staged} == *.php ]]; then # this condition exactly works
# use php-cs-fixer and get flag of correction
eval '$(printf "$cmd" "$staged")' # this command exactly works and corrects the file
correction_code=$? # but this doesn't work

# if fixer fixed the file
if [[ ${correction_code} -eq 1 ]]; then #accordingly this condition never works
$(git add "$staged") # even if the code goes here, then all changes will go into the commit, but the file itself will still be listed as an altered
fi
fi
done

exit 0 # do commit

Заранее благодарю за любую помощь

Особенно я хочу знать, почему коррекционный код не получает значения и почему
файлы после «git add» имеют идентичный контент, но все равно не зафиксированы

1

Решение

Задача ещё не решена.

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]