From 83f64f57435a000d19cc90ae402a5e5a8f832b99 Mon Sep 17 00:00:00 2001 From: alokify Date: Tue, 17 Dec 2024 23:28:45 +0530 Subject: [PATCH] =?UTF-8?q?=F0=9F=A7=B9=20chore(bump):=20v2.1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- push.sh | 107 ++++++++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 80 insertions(+), 27 deletions(-) diff --git a/push.sh b/push.sh index c3cb084..2208e80 100755 --- a/push.sh +++ b/push.sh @@ -1,35 +1,88 @@ #!/bin/bash -# Author : Eshanized -# Author URI : https://tonmoyinfrastructure.github.io/eshanized/ +# Author : ESHAN ROY +# Author URI : https://eshanized.github.io -################################ NOTE ################################ -#!!!!!!!!!!!!! Exexcute all the scripts at your own risk !!!!!!!!!!!!! -# I have written the push script for Arch Linux and other Arch Based # -# Linux Distribution. So this script will only work in ArchLinux and # -# Arch based Linux Distribution. You may customize it according to # -# your Distribution. # -###################################################################### +# NOTE : Run at your own risk! -# ---> First We will check for commitizen is installed or not -check_commitizen() { - if ! pacman -Qq commitizen-go &> /dev/null; then - echo "Commitizen is not installed. Please install it using 'yay -S commitizen-go'." >&2 - exit 1 +# 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 + if [[ -n "$type" ]]; then + break + else + echo "Invalid selection. Please try again." fi -} +done -# Function to stage, commit, and push changes -push_to_github() { - git add . - git cz - git push origin master -} +# Extract the commit type and emoji from the selection +type_emoji=${type} +type=${type_emoji#* } +emoji=${type_emoji% *} -# Main Function -main() { - check_commitizen - push_to_github -} +# 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 -main \ No newline at end of file +# 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_part: $desc" + +# If a longer description was provided, add it to the commit message +if [ -n "$long_desc" ]; then + commit_msg+=" + +$long_desc" +fi + +# Print the commit message to the console +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 +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 +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