diff --git a/push.sh b/push.sh index dfa8b4e..2208e80 100755 --- a/push.sh +++ b/push.sh @@ -3,15 +3,28 @@ # Author : ESHAN ROY # Author URI : https://eshanized.github.io -# NOTE : Run at your own Risk! +# NOTE : Run at your own risk! -# Define the conventional commit types with emojis -TYPES=("๐ŸŽ‰ feat" "๐Ÿž fix" "๐Ÿ“š docs" "๐Ÿ’… style" "๐Ÿ”จ refactor" "โšก๏ธ perf" "๐Ÿงช test" "๐Ÿ› ๏ธ build" "๐Ÿค– ci" "๐Ÿงน chore" "โช๏ธ revert") +# Define the conventional commit types with new emojis +TYPES=("๐Ÿš€ feat" "๐Ÿ› fix" "๐Ÿ“ docs" "โœจ style" "๐Ÿ›  refactor" "โšก๏ธ perf" "๐Ÿ”ฌ test" "๐Ÿ”ง build" "๐Ÿค– ci" "๐Ÿงน chore" "โช revert") + +# Function to display an error and exit +error_exit() { + echo -e "\033[1;31m[ERROR]\033[0m $1" + exit 1 +} + +# Ensure the script is run in a Git repository +git rev-parse --is-inside-work-tree > /dev/null 2>&1 || error_exit "This is not a Git repository." # Prompt the user to select a commit type echo "Select a commit type:" select type in "${TYPES[@]}"; do - break + if [[ -n "$type" ]]; then + break + else + echo "Invalid selection. Please try again." + fi done # Extract the commit type and emoji from the selection @@ -21,32 +34,55 @@ emoji=${type_emoji% *} # Prompt the user to enter a scope (optional) read -p "Enter a scope (optional): " scope +scope_part="" +if [ -n "$scope" ]; then + scope_part="($scope)" +fi # Prompt the user to enter a short description read -p "Enter a short description: " desc +if [ -z "$desc" ]; then + error_exit "A short description is required!" +fi # Prompt the user to enter a longer description (optional) read -p "Enter a longer description (optional): " long_desc # Create the commit message -commit_msg="$emoji $type($scope): $desc" +commit_msg="$emoji $type$scope_part: $desc" # If a longer description was provided, add it to the commit message if [ -n "$long_desc" ]; then - commit_msg+=" + commit_msg+=" $long_desc" fi # Print the commit message to the console -echo "Commit message:" -echo "$commit_msg" +echo -e "\nCommit message:" +echo -e "\033[1;36m$commit_msg\033[0m" + +# Confirm before committing +read -p "Do you want to proceed with this commit? (y/n): " confirm +if [[ "$confirm" != "y" && "$confirm" != "Y" ]]; then + echo "Commit aborted." + exit 0 +fi # Stage all changes git add . # Commit the changes with the conventional commit message -git commit -m "$commit_msg" +if git commit -m "$commit_msg"; then + echo -e "\033[1;32mCommit successful!\033[0m" +else + error_exit "Commit failed." +fi # Push the changes to the remote repository -git push origin $(git rev-parse --abbrev-ref HEAD) \ No newline at end of file +branch=$(git rev-parse --abbrev-ref HEAD) +if git push origin "$branch"; then + echo -e "\033[1;32mChanges pushed to remote branch '$branch'.\033[0m" +else + error_exit "Push failed. Please check your connection or branch permissions." +fi \ No newline at end of file