maj des templates

ajout de text
This commit is contained in:
Jephté Clain 2013-10-31 08:37:12 +04:00
parent a6181a92dd
commit 1e248787fd
4 changed files with 157 additions and 15 deletions

View File

@ -9,8 +9,8 @@ USAGE
OPTIONS OPTIONS
-t TEMPLATE -t TEMPLATE
Indiquer, le cas échéant, le modèle de fichier à utiliser pour la Indiquer le modèle de fichier à utiliser pour la génération. Les valeurs
génération. Les valeurs valides sont: valides sont:
${TEMPLATES[*]} ${TEMPLATES[*]}
-e, --edit -e, --edit
-g, --no-edit -g, --no-edit
@ -256,9 +256,11 @@ r=0
for file in "$@"; do for file in "$@"; do
t="$template" t="$template"
if [ -z "$t" ]; then if [ -z "$t" ]; then
# Le cas échéant, si template n'est pas spécifié, le déterminer à partir du dir="$(dirname "$file")"
# nom de fichier name="$(basename "$file")"
case "$(basename "$file")" in # Si template n'est pas spécifié, le déterminer le cas échéant à partir
# du nom de fichier. Rajouter ici le code approprié
case "$name" in
Properties) t=javaproperties;; Properties) t=javaproperties;;
esac esac
fi fi

View File

@ -12,8 +12,8 @@ USAGE
OPTIONS OPTIONS
-t TEMPLATE -t TEMPLATE
Indiquer, le cas échéant, le modèle de fichier à utiliser pour la Indiquer le modèle de fichier à utiliser pour la génération. Les valeurs
génération. Les valeurs valides sont: valides sont:
${TEMPLATES[*]} ${TEMPLATES[*]}
-e, --edit -e, --edit
-g, --no-edit -g, --no-edit
@ -64,7 +64,7 @@ function check_overwrite() {
function generate_XXX() { function generate_XXX() {
local file="$1" local file="$1"
local mode= local mode= #XXX spécifier si nécessaire
check_overwrite "$1" || return check_overwrite "$1" || return
estep "$(ppath "$file")" estep "$(ppath "$file")"
@ -74,7 +74,7 @@ function generate_XXX() {
} }
template= template=
edit= edit= #XXX modifier l'aide si cette valeur est changée
overwrite= overwrite=
encoding= encoding=
#executable= #executable=
@ -97,10 +97,10 @@ r=0
for file in "$@"; do for file in "$@"; do
t="$template" t="$template"
if [ -z "$t" ]; then if [ -z "$t" ]; then
# Le cas échéant, si template n'est pas spécifié, le déterminer à partir du
# nom de fichier
dir="$(dirname "$file")" dir="$(dirname "$file")"
name="$(basename "$file")" name="$(basename "$file")"
# Si template n'est pas spécifié, le déterminer le cas échéant à partir
# du nom de fichier. Rajouter ici le code approprié
fi fi
if [ "$t" == XXX ]; then if [ "$t" == XXX ]; then

View File

@ -9,8 +9,8 @@ USAGE
OPTIONS OPTIONS
-t TEMPLATE -t TEMPLATE
Indiquer, le cas échéant, le modèle de fichier à utiliser pour la Indiquer le modèle de fichier à utiliser pour la génération. Les valeurs
génération. Les valeurs valides sont: valides sont:
${TEMPLATES[*]} ${TEMPLATES[*]}
-T TYPE -T TYPE
Pour un script exécutable, indiquer le type de script à générer: Pour un script exécutable, indiquer le type de script à générer:
@ -213,10 +213,10 @@ r=0
for file in "$@"; do for file in "$@"; do
t="$template" t="$template"
if [ -z "$t" ]; then if [ -z "$t" ]; then
# Le cas échéant, si template n'est pas spécifié, le déterminer à partir du
# nom de fichier
dir="$(dirname "$file")" dir="$(dirname "$file")"
name="$(basename "$file")" name="$(basename "$file")"
# Si template n'est pas spécifié, le déterminer le cas échéant à partir
# du nom de fichier. Rajouter ici le code approprié
fi fi
if [ "$t" == shell ]; then if [ "$t" == shell ]; then

140
lib/templates/text Executable file
View File

@ -0,0 +1,140 @@
#!/bin/bash
# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
function display_help() {
uecho "$scriptname: générer un fichier $NAME
USAGE
$scriptname [options] <file>
OPTIONS
-t TEMPLATE
Indiquer le modèle de fichier à utiliser pour la génération. Les valeurs
valides sont:
${TEMPLATES[*]}
-e, --edit
-g, --no-edit
Editer (resp. ne pas éditer) le fichier après l'avoir généré.
Par défaut, l'éditeur est lancé après la génération.
-f, --overwrite
Ecraser le fichier s'il existe déjà
-E, --encoding ENCODING
Spécifier l'encoding à utiliser pour la génération du fichier"
}
NAME=text
TEMPLATES=(text conf sql)
NAMES=()
EXTS=(txt conf sql)
if [ $# -eq 2 ]; then
if [ "$1" == "--matches-template" ]; then
for template in "${TEMPLATES[@]}"; do
[ "$template" == "$2" ] && exit 0
done
exit 1
elif [ "$1" == "--matches-name" ]; then
for name in "${NAMES[@]}"; do
[ "$name" == "$2" ] && exit 0
done
exit 1
elif [ "$1" == "--matches-ext" ]; then
for ext in "${EXTS[@]}"; do
[ "$ext" == "$2" ] && exit 0
done
exit 1
fi
fi
#source /etc/ulib &&
source "$(dirname "$0")/../../ulib/ulib" &&
urequire DEFAULTS ||
exit 1
function check_overwrite() {
if [ -e "$1" -a -z "$overwrite" ]; then
eerror "$1: refus d'écraser un fichier déjà existant (utiliser -f)"
return 1
fi
return 0
}
function generate_text() {
local file="$1"
local mode=text
check_overwrite "$1" || return
estep "$(ppath "$file")"
echo >"$file" "# -*- coding: $encoding ${mode:+mode: $mode }-*- vim:sw=4:sts=4:et:ai:si:sta:fenc=$encoding"
[ -n "$2" ] && array_add "$2" "$file"
return 0
}
function generate_conf() {
local file="$1"
local mode=conf
check_overwrite "$1" || return
estep "$(ppath "$file")"
echo >"$file" "# -*- coding: $encoding ${mode:+mode: $mode }-*- vim:sw=4:sts=4:et:ai:si:sta:fenc=$encoding"
[ -n "$2" ] && array_add "$2" "$file"
return 0
}
function generate_sql() {
local file="$1"
local mode=sql
check_overwrite "$1" || return
estep "$(ppath "$file")"
echo >"$file" "-- -*- coding: $encoding ${mode:+mode: $mode }-*- vim:sw=4:sts=4:et:ai:si:sta:fenc=$encoding"
[ -n "$2" ] && array_add "$2" "$file"
return 0
}
template=
edit=1
overwrite=
encoding=
#executable=
parse_opts "${PRETTYOPTS[@]}" \
--help '$exit_with display_help' \
-t:,--template: template= \
-e,--edit edit=1 \
-g,--no-edit edit= \
-f,--overwrite overwrite=1 \
-E:,--encoding: encoding= \
@ args -- "$@" && set -- "${args[@]}" || die "$args"
# à rajouter ci-dessus si les fichiers peuvent être exécutables:
#-x,--executable executable=1 \
#-n,--no-executable executable= \
[ -n "$encoding" ] || encoding=utf-8
files2edit=()
r=0
for file in "$@"; do
t="$template"
if [ -z "$t" ]; then
dir="$(dirname "$file")"
name="$(basename "$file")"
# Si template n'est pas spécifié, le déterminer le cas échéant à partir
# du nom de fichier. Rajouter ici le code approprié.
fi
if [ "$t" == text ]; then
generate_text "$file" files2edit || r=$?
elif [ "$t" == conf ]; then
generate_conf "$file" files2edit || r=$?
elif [ "$t" == sql ]; then
generate_sql "$file" files2edit || r=$?
else
die "text: template invalide: $t"
fi
done
if [ -n "$edit" -a "${#files2edit[*]}" -gt 0 ]; then
"${EDITOR:-vi}" "${files2edit[@]}"
fi
exit $r