possibilité de spécifier indépendamment type et sous-type
This commit is contained in:
parent
52a3b381a5
commit
9eb563d575
|
@ -3,7 +3,9 @@
|
||||||
|
|
||||||
# Type de script shell à générer par défaut pour la commande 'utempl -t sh'
|
# Type de script shell à générer par défaut pour la commande 'utempl -t sh'
|
||||||
# auto (par défaut), system-or-local, default, manual ou vanilla
|
# auto (par défaut), system-or-local, default, manual ou vanilla
|
||||||
#SHELL_TYPE=auto
|
# Le type d'analyse d'argument est spécifié avec un préfixe +auto (par défaut)
|
||||||
|
# ou +manual
|
||||||
|
#SHELL_TYPE=auto+auto
|
||||||
|
|
||||||
# Utilisateur par défaut pour la commande ussh
|
# Utilisateur par défaut pour la commande ussh
|
||||||
#USSH_USER=root
|
#USSH_USER=root
|
||||||
|
|
|
@ -18,6 +18,10 @@ OPTIONS
|
||||||
default, d -- utilise /etc/ulibauto et genparse()
|
default, d -- utilise /etc/ulibauto et genparse()
|
||||||
manual, m -- utilise /etc/ulib et parse_opts()
|
manual, m -- utilise /etc/ulib et parse_opts()
|
||||||
vanilla, v -- script simple
|
vanilla, v -- script simple
|
||||||
|
auto -- choisir system-or-local, default ou manual en fonction de
|
||||||
|
la présence de [lib/]ulib et/ou de /etc/ulibauto
|
||||||
|
autom -- choisir system-or-local ou manual en fonction de
|
||||||
|
la présence de [lib/]ulib
|
||||||
-e, --edit
|
-e, --edit
|
||||||
-g, --no-edit
|
-g, --no-edit
|
||||||
Editer (resp. ne pas éditer) le fichier après l'avoir généré.
|
Editer (resp. ne pas éditer) le fichier après l'avoir généré.
|
||||||
|
@ -66,6 +70,36 @@ function check_overwrite() {
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function __fixtypes() {
|
||||||
|
if [[ "$type" == *+* ]]; then
|
||||||
|
stype="${type##*+}"
|
||||||
|
type="${type%+*}"
|
||||||
|
else
|
||||||
|
stype=
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$type" in
|
||||||
|
system-or-local|sol|sl|u) type=system-or-local;;
|
||||||
|
default|def|d) type=default;;
|
||||||
|
manual|man|m) type=manual;;
|
||||||
|
vanilla|van|v) type=vanilla;;
|
||||||
|
""|auto|a) type=auto;;
|
||||||
|
autom) type=autom;;
|
||||||
|
*)
|
||||||
|
ewarn "$type: type non reconnu. sélection de la valeur 'default'"
|
||||||
|
type=default
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
case "$stype" in
|
||||||
|
manual|m) stype=manual;;
|
||||||
|
""|auto|a) stype=auto;;
|
||||||
|
*)
|
||||||
|
ewarn "$stype: sous-type non reconnu. sélection de la valeur 'auto'"
|
||||||
|
stype=auto
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
function generate_shell() {
|
function generate_shell() {
|
||||||
local file="$1"
|
local file="$1"
|
||||||
local dir="$(dirname "$file")"
|
local dir="$(dirname "$file")"
|
||||||
|
@ -73,20 +107,16 @@ function generate_shell() {
|
||||||
|
|
||||||
check_overwrite "$1" || return
|
check_overwrite "$1" || return
|
||||||
|
|
||||||
case "$type" in
|
local type="$type" stype
|
||||||
system-or-local|sol|sl|u) type=system-or-local;;
|
__fixtypes
|
||||||
default|def|d) type=default;;
|
|
||||||
manual|man|m) type=manual;;
|
|
||||||
vanilla|van|v) type=vanilla;;
|
|
||||||
auto|a) type=;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
local modeline="# -*- coding: $encoding ${mode:+mode: $mode }-*- vim:sw=4:sts=4:et:ai:si:sta:fenc=$encoding"
|
local modeline="# -*- coding: $encoding ${mode:+mode: $mode }-*- vim:sw=4:sts=4:et:ai:si:sta:fenc=$encoding"
|
||||||
if [ -n "$executable" ]; then
|
if [ -n "$executable" ]; then
|
||||||
|
# script exécutable
|
||||||
etitle "$(ppath "$file")"
|
etitle "$(ppath "$file")"
|
||||||
|
|
||||||
if [ -z "$type" ]; then
|
if [[ "$type" == auto* ]]; then
|
||||||
if [ -d "$dir/ulib" ]; then
|
if [ -d "$dir/ulib" -o -d "$dir/lib/ulib" ]; then
|
||||||
ask_yesno "\
|
ask_yesno "\
|
||||||
Le type de script 'system-or-local' a été sélectionné automatiquement
|
Le type de script 'system-or-local' a été sélectionné automatiquement
|
||||||
Une librairie ulib locale est présente. En chargeant ulib/auto, la librairie
|
Une librairie ulib locale est présente. En chargeant ulib/auto, la librairie
|
||||||
|
@ -94,7 +124,7 @@ système /etc/ulib sera utilisée si elle est disponible. Sinon, la librairie
|
||||||
locale ulib/ulib sera utilisée.
|
locale ulib/ulib sera utilisée.
|
||||||
Voulez-vous générer un script avec cette configuration?" X &&
|
Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
type=system-or-local
|
type=system-or-local
|
||||||
elif [ -f /etc/ulibauto ]; then
|
elif [ -f /etc/ulibauto -a "$type" == auto ]; then
|
||||||
ask_yesno "\
|
ask_yesno "\
|
||||||
Le type de script 'default' a été sélectionné automatiquement
|
Le type de script 'default' a été sélectionné automatiquement
|
||||||
En chargeant /etc/ulibauto, la librairie ulib système sera utilisée, et les
|
En chargeant /etc/ulibauto, la librairie ulib système sera utilisée, et les
|
||||||
|
@ -104,18 +134,18 @@ Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
else
|
else
|
||||||
ask_yesno "\
|
ask_yesno "\
|
||||||
Le type de script 'manual' a été sélectionné automatiquement
|
Le type de script 'manual' a été sélectionné automatiquement
|
||||||
Une vieille version de nutools est installée. Il faut charger /etc/ulib et
|
En chargeant /etc/ulib, la librairie ulib système sera utilisée, mais il faut
|
||||||
définir manuellement les paramètres à utiliser.
|
définir manuellement les paramètres à utiliser.
|
||||||
Voulez-vous générer un script avec cette configuration?" X &&
|
Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
type=manual
|
type=manual
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if [ -z "$type" ] && check_interaction -c; then
|
if [[ "$type" == auto* ]] && check_interaction -c; then
|
||||||
enote "Plusieurs type de scripts peuvent être générés:
|
enote "Plusieurs type de scripts peuvent être générés:
|
||||||
- Avec le type 'system-or-local', on assume qu'une librairie ulib locale est
|
- Avec le type 'system-or-local', on assume qu'une librairie ulib locale est
|
||||||
présente. Le fichier ulib/auto est chargé, ce qui a pour conséquence que la
|
présente. Le fichier [lib/]ulib/auto est chargé, ce qui a pour conséquence que
|
||||||
librairie système /etc/ulib est utilisée si elle est disponible. Sinon, la
|
la librairie système /etc/ulib est utilisée si elle est disponible. Sinon, la
|
||||||
librairie locale ulib/ulib est utilisée.
|
librairie locale [lib/]ulib/ulib est utilisée.
|
||||||
- Avec le type 'default', le fichier /etc/ulibauto est chargé. Les paramètres
|
- Avec le type 'default', le fichier /etc/ulibauto est chargé. Les paramètres
|
||||||
par défaut sont utilisés: urequire DEFAULTS et genparse() pour l'analyse des
|
par défaut sont utilisés: urequire DEFAULTS et genparse() pour l'analyse des
|
||||||
arguments.
|
arguments.
|
||||||
|
@ -129,12 +159,13 @@ Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
-t "Choix du type de script" \
|
-t "Choix du type de script" \
|
||||||
-m "Veuillez choisir le type de script à générer" \
|
-m "Veuillez choisir le type de script à générer" \
|
||||||
-d manual
|
-d manual
|
||||||
|
__fixtypes
|
||||||
fi
|
fi
|
||||||
if [ -z "$type" ]; then
|
if [[ "$type" == auto* ]]; then
|
||||||
if [ -d "$dir/ulib" -o -d "$dir/lib/ulib" ]; then
|
if [ -d "$dir/ulib" -o -d "$dir/lib/ulib" ]; then
|
||||||
enote "Le type de script 'system-or-local' a été sélectionné automatiquement"
|
enote "Le type de script 'system-or-local' a été sélectionné automatiquement"
|
||||||
type=system-or-local
|
type=system-or-local
|
||||||
elif [ -f /etc/ulibauto ]; then
|
elif [ -f /etc/ulibauto -a "$type" == auto ]; then
|
||||||
enote "Le type de script 'default' a été sélectionné automatiquement"
|
enote "Le type de script 'default' a été sélectionné automatiquement"
|
||||||
type=default
|
type=default
|
||||||
else
|
else
|
||||||
|
@ -143,6 +174,7 @@ Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# d'abord générer l'en-tête par rapport au type
|
||||||
if [ "$type" == system-or-local ]; then
|
if [ "$type" == system-or-local ]; then
|
||||||
local ulibdir
|
local ulibdir
|
||||||
if [ -d "$dir/ulib" ]; then
|
if [ -d "$dir/ulib" ]; then
|
||||||
|
@ -154,25 +186,27 @@ Voulez-vous générer un script avec cette configuration?" X &&
|
||||||
fi
|
fi
|
||||||
echo >"$file" '#!/bin/bash
|
echo >"$file" '#!/bin/bash
|
||||||
'"$modeline"'
|
'"$modeline"'
|
||||||
source "$(dirname "$0")/'"$ulibdir"'/auto" || exit 1
|
source "$(dirname "$0")/'"$ulibdir"'/auto" || exit 1'
|
||||||
#HELP_DESC="$scriptname: "
|
|
||||||
#HELP_ARG_DESC=
|
|
||||||
eval "$(genparse)"
|
|
||||||
'
|
|
||||||
elif [ "$type" == default ]; then
|
elif [ "$type" == default ]; then
|
||||||
echo >"$file" '#!/bin/bash
|
echo >"$file" '#!/bin/bash
|
||||||
'"$modeline"'
|
'"$modeline"'
|
||||||
source /etc/ulibauto || exit 1
|
source /etc/ulibauto || exit 1'
|
||||||
#HELP_DESC="$scriptname: "
|
|
||||||
#HELP_ARG_DESC=
|
|
||||||
eval "$(genparse)"
|
|
||||||
'
|
|
||||||
elif [ "$type" == manual ]; then
|
elif [ "$type" == manual ]; then
|
||||||
echo >"$file" '#!/bin/bash
|
echo >"$file" '#!/bin/bash
|
||||||
'"$modeline"'
|
'"$modeline"'
|
||||||
source /etc/ulib || exit 1
|
source /etc/ulib || exit 1
|
||||||
urequire DEFAULTS
|
urequire DEFAULTS'
|
||||||
|
elif [ "$type" == vanilla ]; then
|
||||||
|
echo >"$file" "#!/bin/bash
|
||||||
|
$modeline"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ensuite générer le code pour l'analyse des arguments en fonction du
|
||||||
|
# sous-type
|
||||||
|
if [ "$type" != vanilla ]; then
|
||||||
|
case "$stype" in
|
||||||
|
manual)
|
||||||
|
echo >>"$file" '
|
||||||
function display_help() {
|
function display_help() {
|
||||||
uecho "$scriptname:
|
uecho "$scriptname:
|
||||||
|
|
||||||
|
@ -186,16 +220,25 @@ parse_opts "${PRETTYOPTS[@]}" \
|
||||||
--help '\''$exit_with display_help'\'' \
|
--help '\''$exit_with display_help'\'' \
|
||||||
@ args -- "$@" && set -- "${args[@]}" || die "$args"
|
@ args -- "$@" && set -- "${args[@]}" || die "$args"
|
||||||
'
|
'
|
||||||
elif [ "$type" == vanilla ]; then
|
;;
|
||||||
echo >"$file" "#!/bin/bash
|
auto)
|
||||||
$modeline"
|
echo >>"$file" '#HELP_DESC="$scriptname: "
|
||||||
|
#HELP_ARG_DESC=
|
||||||
|
eval "$(genparse)"
|
||||||
|
' ;;
|
||||||
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# rendre le fichier exécutable
|
||||||
chmod +x "$file"
|
chmod +x "$file"
|
||||||
eend
|
eend
|
||||||
|
|
||||||
else
|
else
|
||||||
|
# fichier shell non exécutable
|
||||||
estep "$(ppath "$file")"
|
estep "$(ppath "$file")"
|
||||||
echo >"$file" "$modeline"
|
echo >"$file" "$modeline"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[ -n "$2" ] && array_add "$2" "$file"
|
[ -n "$2" ] && array_add "$2" "$file"
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue