mirror of
https://github.com/mandiant/capa.git
synced 2025-12-22 07:10:29 -08:00
If the style checker of the rule linter failed, the stashed changes were not restored. There is no reason to exist with an error code in a post hook. In pre hooks this causes the action to be aborted.
37 lines
1.1 KiB
Bash
Executable File
37 lines
1.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# doesn't matter if this gets repeated later on in a hooks file
|
|
|
|
# Use a console with emojis support for a better experience
|
|
|
|
# Stash uncommited changes
|
|
MSG="post-commit-$(date +%s)";
|
|
git stash push -kqum "$MSG";
|
|
STASH_LIST=$(git stash list);
|
|
if [[ "$STASH_LIST" == *"$MSG"* ]]; then
|
|
echo "Uncommited changes stashed with message '$MSG', if you abort before they are restored run \`git stash pop\`";
|
|
fi
|
|
|
|
# Run style checker and print state (it doesn't block the commit)
|
|
pycodestyle --config=./ci/tox.ini ./capa/ > style-checker-output.log 2>&1;
|
|
if [ $? == 0 ]; then
|
|
echo 'Style checker succeeds!! 💘';
|
|
else
|
|
echo 'Style checker failed 😭';
|
|
echo 'Check style-checker-output.log for details';
|
|
fi
|
|
|
|
# Run rule linter and print state (it doesn't block the commit)
|
|
python ./scripts/lint.py ./rules/ > rule-linter-output.log 2>&1;
|
|
if [ $? == 0 ]; then
|
|
echo 'Rule linter succeeds!! 💖';
|
|
else
|
|
echo 'Rule linter failed 😭';
|
|
echo 'Check rule-linter-output.log for details';
|
|
fi
|
|
|
|
# Restore stashed changes
|
|
if [[ "$STASH_LIST" == *"$MSG"* ]]; then
|
|
git stash pop -q --index;
|
|
echo "Stashed changes '$MSG' restored";
|
|
fi
|