cx-updatedev: remplacer --ru par -w, --ud, --ur en fonction des besoins

This commit is contained in:
Jephté Clain 2019-06-12 23:19:00 +04:00
parent 9bfd515cac
commit ae7ffeb7b1
1 changed files with 79 additions and 33 deletions

View File

@ -17,25 +17,49 @@ OPTIONS
Afficher simplement ce qui serait fait Afficher simplement ce qui serait fait
-q, --quiet -q, --quiet
Ne pas lancer rsync en mode verbose Ne pas lancer rsync en mode verbose
--rsync
Mettre à jour les répertoires dans vendor/ qui ne sont pas des liens
symboliques à partir des projets dépendants correspondants. Les liens
symboliques créés avec --link sont ignorés. C'est l'option par défaut.
-l, --link -l, --link
Transformer les clones de dépôts en liens directs vers les projets Transformer les clones de dépôts dans vendor/ en liens symboliques vers
les projets dépendants correpondants.
-k, --copy -k, --copy
Transformer les liens directs vers les projets en copies des projets Transformer les liens symboliques dans vendor/ en copies des projets
dépendants correspondants. Les répertoires qui ne sont pas des liens
symboliques sont ignorés.
Cette option peut être considérée comme le contraire de --link
-i, --install -i, --install
Supprimer les répertoires et les faire recréer par composer i Supprimer les répertoires des projets dépendants dans vendor/, qu'il
s'agisse de liens symboliques ou de répertoires normaux, puis les faire
recréer par 'composer i'
Celà permet de ramener le projet à l'état original.
-j, --reinstall-link -j, --reinstall-link
Supprimer les répertoires et les faire recréer par composer i, Supprimer les répertoires des projets dépendants dans vendor/ s'il
uniquement s'il s'agit de liens s'agit de liens symboliques, puis les faire recréer par 'composer i'
Cette variante est plus rapide que --install puisqu'on ne cherche pas à
tout recréer.
-u, --update -u, --update
Supprimer les répertoires et les faire recréer par composer u Supprimer les répertoires des projets dépendants dans vendor/, qu'il
--ru, --recursive-update s'agisse de liens symboliques ou de répertoires normaux, puis les faire
recréer par 'composer u'
Celà permet de mettre à jour le projet sans les erreurs qui résultent
des modifications faites par les autres actions.
-w, --update-commit
Mettre à jour le projet avec --update puis enregistrer les modifications
éventuelles dans git
--ud, --update-deps
Mettre à jour les projets dépendants avec --update-commit avant de
mettre à jour le projet courant.
--ur, --update-recursive
Mettre à jour de façon récursive tous les projets dépendants. Mettre à jour de façon récursive tous les projets dépendants.
NB: les modifications seront automatiquement enregistrées dans git." NB: les modifications dans les projets dépendants seront automatiquement
enregistrées dans git."
} }
fake= fake=
verbose=1 verbose=1
action= action=rsync
args=( args=(
--help '$exit_with display_help' --help '$exit_with display_help'
-d:,--project-dir: projdir= -d:,--project-dir: projdir=
@ -46,7 +70,9 @@ args=(
-i,--install action=install -i,--install action=install
-j,--reinstall-link action=reinstall-link -j,--reinstall-link action=reinstall-link
-u,--update action=update -u,--update action=update
--ru,--recursive-update action=recursive-update -w,--update-commit action=update-commit
--ud,--update-deps action=update-deps
--ur,--update-recursive action=update-recursive
) )
parse_args "$@"; set -- "${args[@]}" parse_args "$@"; set -- "${args[@]}"
@ -74,12 +100,13 @@ if [ -z "$first" ]; then
fi fi
case "$action" in case "$action" in
install|update|reinstall-link|recursive-update) install|reinstall-link|update|update-commit|update-deps|update-recursive)
[ -x ./composer.phar ] || die "Impossible de trouver composer.phar" [ -x ./composer.phar ] || die "Impossible de trouver composer.phar"
;; ;;
esac esac
if [ "$action" == recursive-update ]; then if [ "$action" == update-deps -o "$action" == update-recursive ]; then
# avec recursive-update, tous les modules doivent être considérés # avec update-deps et update-recursive, tous les modules doivent être
# considérés
set -- set --
fi fi
@ -119,6 +146,14 @@ for m in "$@"; do
check_module check_module
case "$action" in case "$action" in
rsync)
# Action par défaut: ignorer les liens et synchroniser les copies
if [ ! -L "vendor/$p" ]; then
etitle "$m"
update_with_rsync
eend
fi
;;
link) link)
# Ignorer les liens et transformer les copies en liens # Ignorer les liens et transformer les copies en liens
if [ ! -L "vendor/$p" ]; then if [ ! -L "vendor/$p" ]; then
@ -160,7 +195,7 @@ for m in "$@"; do
array_add deps "$p" array_add deps "$p"
eend eend
;; ;;
reinstall-link|recursive-update) reinstall-link)
# Supprimer les liens uniquement... # Supprimer les liens uniquement...
etitle "$m" etitle "$m"
if [ -L "vendor/$p" ]; then if [ -L "vendor/$p" ]; then
@ -170,7 +205,7 @@ for m in "$@"; do
array_add deps "$p" array_add deps "$p"
eend eend
;; ;;
update) update|update-commit|update-deps|update-recursive)
# Supprimer les liens et répertoires... # Supprimer les liens et répertoires...
etitle "$m" etitle "$m"
if [ -e "vendor/$p" ]; then if [ -e "vendor/$p" ]; then
@ -180,38 +215,49 @@ for m in "$@"; do
array_add deps "$p" array_add deps "$p"
eend eend
;; ;;
*) *) die "$action: action inconnue";;
# Action par défaut: ignorer les liens et synchroniser les copies
if [ ! -L "vendor/$p" ]; then
etitle "$m"
update_with_rsync
eend
fi
;;
esac esac
done done
case "$action" in case "$action" in
install|reinstall-link) install|reinstall-link)
# ... puis installer les dépendances # ... puis installer les dépendances
etitle "Installation des dépendances" estep "Installation des dépendances"
./composer.phar i ./composer.phar i
eend
;; ;;
update) update|update-commit)
# ... puis mettre à jour les dépendances # ... puis mettre à jour les dépendances
etitle "Mise à jour des dépendances" estep "Mise à jour des dépendances"
./composer.phar u "${deps[@]}" ./composer.phar u "${deps[@]}"
eend
if [ "$action" == update-commit ]; then
estep "Enregistrement dans git"
pci -A "maj deps"
fi
;; ;;
recursive-update) update-deps)
# mettre à jour les dépendances de façon récursives # mettre à jour les dépendances directes
for m in "${modules[@]}"; do for m in "${modules[@]}"; do
etitle "Mise à jour récursive: $m" etitle "Mise à jour projet dépendant: $m"
"$script" -d "../$m" --ru "$script" -d "../$m" -w
eend eend
done done
estep "Maj deps"
estep "Mise à jour des dépendances"
./composer.phar u
estep "Enregistrement dans git"
pci -A "maj deps"
;;
update-recursive)
# mettre à jour les dépendances de façon récursive
for m in "${modules[@]}"; do
etitle "Mise à jour récursive: $m"
"$script" -d "../$m" --ur
eend
done
estep "Mise à jour des dépendances"
./composer.phar u ./composer.phar u
estep "Enregistrement dans git" estep "Enregistrement dans git"