You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
2.9 KiB
89 lines
2.9 KiB
1 year ago
|
#!/usr/bin/env bash
|
||
|
# Copyright © 2023 OpenIM. All rights reserved.
|
||
|
#
|
||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
# you may not use this file except in compliance with the License.
|
||
|
# You may obtain a copy of the License at
|
||
|
#
|
||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||
|
#
|
||
|
# Unless required by applicable law or agreed to in writing, software
|
||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
# See the License for the specific language governing permissions and
|
||
|
# limitations under the License.
|
||
|
#
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# init-githooks.sh
|
||
|
#
|
||
|
# This script assists in managing Git hooks for the OpenIM project.
|
||
|
# When executed:
|
||
|
# 1. It prompts the user to enable git hooks.
|
||
|
# 2. If the user accepts, it copies predefined hook scripts to the appropriate
|
||
|
# Git directory, making them executable.
|
||
|
# 3. If requested, it can delete the added hooks.
|
||
|
#
|
||
|
# This script equal runs `make init-githooks` command.
|
||
|
# Usage:
|
||
|
# ./init-githooks.sh Prompt to enable git hooks.
|
||
|
# ./init-githooks.sh --delete Delete previously added git hooks.
|
||
|
# ./init-githooks.sh --help Show the help message.
|
||
|
#
|
||
|
# Example: `scripts/build-go.sh --help`.
|
||
|
# Documentation & related context can be found at:
|
||
|
# https://gist.github.com/cubxxw/126b72104ac0b0ca484c9db09c3e5694
|
||
|
#
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
||
|
HOOKS_DIR=".git/hooks"
|
||
|
|
||
|
help_info() {
|
||
|
echo "Usage: $0 [options]"
|
||
|
echo
|
||
|
echo "This script helps to manage git hooks."
|
||
|
echo
|
||
|
echo "Options:"
|
||
|
echo " -h, --help Show this help message and exit."
|
||
|
echo " -d, --delete Delete the hooks that have been added."
|
||
|
echo " By default, it will prompt to enable git hooks."
|
||
|
}
|
||
|
|
||
|
delete_hooks() {
|
||
|
for file in scripts/githooks/*.sh; do
|
||
|
hook_name=$(basename "$file" .sh)
|
||
|
rm -f "$HOOKS_DIR/$hook_name"
|
||
|
done
|
||
|
echo "Git hooks have been deleted."
|
||
|
}
|
||
|
|
||
|
enable_hooks() {
|
||
|
echo "Would you like to enable git hooks mode? [y/n]"
|
||
|
read -r choice
|
||
|
|
||
|
if [[ $choice == "y" || $choice == "Y" ]]; then
|
||
|
for file in scripts/githooks/*.sh; do
|
||
|
cp -f "$file" "$HOOKS_DIR/$(basename "$file" .sh)"
|
||
|
done
|
||
|
|
||
|
chmod +x $HOOKS_DIR/*
|
||
|
|
||
|
echo "Git hooks mode has been enabled."
|
||
|
echo "With git hooks enabled, every time you perform a git action (e.g. git commit), the corresponding hooks script will be triggered automatically."
|
||
|
echo "This means that if the size of the file you're committing exceeds the set limit (e.g. 42MB), the commit will be rejected."
|
||
|
else
|
||
|
echo "Git hooks mode remains disabled."
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
case "$1" in
|
||
|
-h|--help)
|
||
|
help_info
|
||
|
;;
|
||
|
-d|--delete)
|
||
|
delete_hooks
|
||
|
;;
|
||
|
*)
|
||
|
enable_hooks
|
||
|
;;
|
||
|
esac
|