62 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| # -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
 | |
| source "$(dirname "$0")/lib/ulib/ulib" || exit 1
 | |
| urequire DEFAULTS ptools
 | |
| 
 | |
| function display_help() {
 | |
|     uecho "$scriptname: basculer sur une branche de hotfix
 | |
| 
 | |
| USAGE
 | |
|     $scriptname [options] [HOTFIX [SOURCE]]
 | |
| 
 | |
| - Vérifier s'il n'y a pas de modifications locales. Sinon, proposer de faire un
 | |
|   commit ou un stash.
 | |
| - Si TOPIC est spécifié, et si on n'est pas déjà sur cette branche, basculer
 | |
|   vers cette nouvelle branche. S'il s'agit d'une nouvelle branche, la baser sur
 | |
|   la branche SOURCE, qui vaut par défaut master
 | |
| - Si TOPIC n'est pas spécifié, afficher un menu pour choisir la branche de
 | |
|   destination.
 | |
| 
 | |
| OPTIONS
 | |
|     -C, --projdir PROJDIR
 | |
|         Spécifier le répertoire de base du projet qui est dans git. Par défaut,
 | |
|         on travaille dans le répertoire courant et on laisse git trouver le
 | |
|         répertoire de base du projet. Avec cette option, le répertoire courant
 | |
|         est modifié avant de lancer les commandes git.
 | |
|     -O, --origin ORIGIN
 | |
|         Spécifier le nom de l'origine. Par défaut, utiliser 'origin'
 | |
|     -o, --offline
 | |
|         En cas de création d'une branche, ne pas pousser vers l'origine; ne pas
 | |
|         tenter le cas échéant de traquer la branche dans l'origine; ne pas
 | |
|         supprimer une branche dans l'origine. Cette option est automatiquement
 | |
|         activée si la variable UTOOLS_VCS_OFFLINE est définie.
 | |
|     --online
 | |
|         Annuler l'effet de la variable UTOOLS_VCS_OFFLINE: forcer le mode online
 | |
|     -m, --merge
 | |
|         Si la branche actuelle est une branche de hotfix, la merger dans master
 | |
|         (ou dans la branche de release), et dans develop, puis la supprimer.
 | |
|         Puis basculer sur la branche master.
 | |
|     -l, --log
 | |
|         Afficher les modifications actuellement effectuée dans la branche de
 | |
|         hotfix par rapport à master.
 | |
|     -d, --diff
 | |
|         Afficher les modifications actuellement effectuée dans la branche de
 | |
|         hotfix par rapport à master, sous forme de diff."
 | |
| }
 | |
| 
 | |
| projdir=
 | |
| origin=origin
 | |
| parse_opts "${PRETTYOPTS[@]}" \
 | |
|     --help '$exit_with display_help' \
 | |
|     -C:,--projdir: projdir= \
 | |
|     -O:,--origin: origin= \
 | |
|     -o,--offline UTOOLS_VCS_OFFLINE=1 \
 | |
|     --online UTOOLS_VCS_OFFLINE= \
 | |
|     @ args -- "$@" && set -- "${args[@]}" || die "$args"
 | |
| 
 | |
| if [ -n "$projdir" ]; then
 | |
|     cd "$projdir" || die
 | |
| fi
 | |
| 
 | |
| git_ensure_gitvcs
 |