From eb66ea3e334098872690c2f02d5ea975e4c0a8a8 Mon Sep 17 00:00:00 2001 From: Iagho Cristian Date: Wed, 30 Oct 2024 19:20:02 +0100 Subject: [PATCH 1/2] Add a function to clean and update local repositories --- home/dot_bash_aliases.tmpl | 6 ++++++ scripts/clean-local-repos.sh | 22 ++++++++++++++++++++++ 2 files changed, 28 insertions(+) create mode 100755 scripts/clean-local-repos.sh diff --git a/home/dot_bash_aliases.tmpl b/home/dot_bash_aliases.tmpl index edfb167..8b871dc 100644 --- a/home/dot_bash_aliases.tmpl +++ b/home/dot_bash_aliases.tmpl @@ -59,3 +59,9 @@ cdw() { cd "${win_home}" } # {{ end }} + +clean-repos() { + local exclude_dir=("$@") + cd "${HOME}/repos/dotfiles" || { echo "Fail to access dotfiles"; return; } + ./scripts/clean-local-repos.sh "${exclude_dir[@]}" +} \ No newline at end of file diff --git a/scripts/clean-local-repos.sh b/scripts/clean-local-repos.sh new file mode 100755 index 0000000..ab46bc5 --- /dev/null +++ b/scripts/clean-local-repos.sh @@ -0,0 +1,22 @@ +#!/bin/bash + +repos_dir="${HOME}/repos" +exclude_dir=("$@") + +folders=$(find "${repos_dir}" -maxdepth 1 -mindepth 1 -type d -exec basename {} \;) +if [[ ${#exclude_dir[@]} -ne 0 ]]; then + folders=$(echo "${folders}" | grep -v -E "$(IFS="|"; echo "${exclude_dir[*]}")") +fi + +for folder in ${folders}; do + echo "Updating folder: ${folder}" + + cd "${repos_dir}/${folder}" || { echo "Fail to access ${folder}"; continue; } + + branch=$(git remote show origin | grep 'HEAD branch' | cut -d' ' -f5) + git reset --hard origin/"${branch}" + git checkout "${branch}" + git pull + + echo "Update finished for: ${folder}" +done \ No newline at end of file From dda4d9dcdcc21dab880895b64106242891562694 Mon Sep 17 00:00:00 2001 From: Iagho Cristian Date: Wed, 30 Oct 2024 19:20:02 +0100 Subject: [PATCH 2/2] Add a function to reset and update local repositories --- home/dot_bash_aliases.tmpl | 5 +- .../bin/executable_clean-local-repos.sh | 119 ++++++++++++++++++ 2 files changed, 121 insertions(+), 3 deletions(-) create mode 100755 home/dot_local/bin/executable_clean-local-repos.sh diff --git a/home/dot_bash_aliases.tmpl b/home/dot_bash_aliases.tmpl index 8b871dc..e42c392 100644 --- a/home/dot_bash_aliases.tmpl +++ b/home/dot_bash_aliases.tmpl @@ -60,8 +60,7 @@ cdw() { } # {{ end }} -clean-repos() { +git-reset-all-repos() { local exclude_dir=("$@") - cd "${HOME}/repos/dotfiles" || { echo "Fail to access dotfiles"; return; } - ./scripts/clean-local-repos.sh "${exclude_dir[@]}" + ./home/dot_local/bin/executable_clean-local-repos.sh "${exclude_dir[@]}" } \ No newline at end of file diff --git a/home/dot_local/bin/executable_clean-local-repos.sh b/home/dot_local/bin/executable_clean-local-repos.sh new file mode 100755 index 0000000..67ec2b2 --- /dev/null +++ b/home/dot_local/bin/executable_clean-local-repos.sh @@ -0,0 +1,119 @@ +#!/bin/bash +# ARG_OPTIONAL_SINGLE([repos_dir],[r],[Directory containing repositories],[.]) +# ARG_OPTIONAL_REPEATED([exclude],[e],[Directories to exclude]) +# ARG_HELP([Script to clean local git repositories]) +# ARG_DEFAULTS_POS([]) +# ARGBASH_GO() +# needed because of Argbash --> m4_ignore([ +### START OF CODE GENERATED BY Argbash v2.10.0 one line above ### +# Argbash is a bash code generator used to get arguments parsing right. +# Argbash is FREE SOFTWARE, see https://argbash.io for more info + + +die() +{ + local _ret="${2:-1}" + test "${_PRINT_HELP:-no}" = yes && print_help >&2 + echo "$1" >&2 + exit "${_ret}" +} + + +begins_with_short_option() +{ + local first_option all_short_options='reh' + first_option="${1:0:1}" + test "$all_short_options" = "${all_short_options/$first_option/}" && return 1 || return 0 +} + +# THE DEFAULTS INITIALIZATION - OPTIONALS +_arg_repos_dir="." +_arg_exclude=() + + +print_help() +{ + printf '%s\n' "Script to clean local git repositories" + printf 'Usage: %s [-r|--repos_dir ] [-e|--exclude ] [-h|--help]\n' "$0" + printf '\t%s\n' "-r, --repos_dir: Directory containing repositories (default: '.')" + printf '\t%s\n' "-e, --exclude: Directories to exclude (empty by default)" + printf '\t%s\n' "-h, --help: Prints help" +} + + +parse_commandline() +{ + while test $# -gt 0 + do + _key="$1" + case "$_key" in + -r|--repos_dir) + test $# -lt 2 && die "Missing value for the optional argument '$_key'." 1 + _arg_repos_dir="$2" + shift + ;; + --repos_dir=*) + _arg_repos_dir="${_key##--repos_dir=}" + ;; + -r*) + _arg_repos_dir="${_key##-r}" + ;; + -e|--exclude) + test $# -lt 2 && die "Missing value for the optional argument '$_key'." 1 + _arg_exclude+=("$2") + shift + ;; + --exclude=*) + _arg_exclude+=("${_key##--exclude=}") + ;; + -e*) + _arg_exclude+=("${_key##-e}") + ;; + -h|--help) + print_help + exit 0 + ;; + -h*) + print_help + exit 0 + ;; + *) + _PRINT_HELP=yes die "FATAL ERROR: Got an unexpected argument '$1'" 1 + ;; + esac + shift + done +} + +parse_commandline "$@" + +# OTHER STUFF GENERATED BY Argbash + +### END OF CODE GENERATED BY Argbash (sortof) ### ]) +# [ <-- needed because of Argbash + + +set -eu + +repos_dir="${_arg_repos_dir}" +exclude=("${_arg_exclude[@]}") + +folders=$(find "${repos_dir}" -maxdepth 1 -mindepth 1 -type d -exec basename {} \;) +if [[ ${#exclude[@]} -ne 0 ]]; then + folders=$(echo "${folders}" | grep -v -E "$(IFS="|"; echo "${exclude[*]}")") +fi + +for folder in ${folders}; do + echo "Updating folder: ${folder}" + + cd "${repos_dir}/${folder}" || { echo "Fail to access ${folder}"; continue; } + + branch=$(git remote show origin | grep 'HEAD branch' | cut -d' ' -f5) + git reset --hard origin/"${branch}" + git checkout "${branch}" + git pull + + echo "Update finished for: ${folder}" +done + +# ] <-- needed because of Argbash