#!/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] 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 n'est pas 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=java TEMPLATES=(javaproperties java woapi wosrc wosrccomp) NAMES=(Properties) EXTS=(properties java api wosrc) 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_javaproperties() { local file="$1" local encoding=iso-8859-1 local mode= check_overwrite "$file" || 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 guess_package() { local dir="$(abspath "$1")" local -a files local file array_lsfiles files "$dir" "*.java" if [ ${#files[*]} -gt 0 ]; then # récupérer le package dans un fichier existant file="${files[0]}" awk <"$file" ' /^[ \t]*package[ \t]/ { if (match($0, /[ \t]*package[ \t]*(.*)[ \t]*;/, vs) != 0) { print vs[1]; exit 0 } } # stop quand on arrive à import ou class /^(import|class)/ { exit 0 }' elif [[ "$dir" == */Sources/* ]]; then local package="${dir##*/Sources/}" package="${package//\//.}" echo "$package" fi } function generate_java() { local file="$1" local dir="$(dirname "$file")" local name="$(basename "$file")" local basename="${name%.*}" local mode= [ -n "$package" ] || local package="$(guess_package "$dir")" local packline [ -n "$package" ] && packline="package $package;" local -a implines for import in "${imports[@]}"; do array_add implines "import $import;" done implines="$(array_to_lines implines)" local exts [ -n "$extends" ] && exts=" extends $extends" local impls if [ "${#implements[*]}" -gt 0 ]; then impls=" implements $(array_join implements ", ")" fi check_overwrite "$file" || return estep "$(ppath "$file")" cat >"$file" <"$file" < EOF [ -n "$2" ] && array_add "$2" "$file" return 0 } function generate_wosrc() { local file="$1" local dtattr [ -n "$doctype" ] && dtattr=" doctype=\"$doctype\"" check_overwrite "$file" || return estep "$(ppath "$file")" cat >"$file" < EOF if [ -n "$html" ]; then cat >>"$file" < head> title> body> h1> EOF fi if [ -n "$blueprint" ]; then cat >>"$file" < menu="menu" q:title="" EOF fi [ -n "$2" ] && array_add "$2" "$file" return 0 } function generate_wosrccomp() { local file="$1" local dir="$(dirname "$file")" local name="$(basename "$file")" local basename="${name%.*}" local ext="${name##*.}" case "$ext" in wosrc|api|java|"") file="$dir/$basename";; *) die "Destination name should not have an extension" esac etitle "$(ppath "$file")" generate_wosrc "$file.wosrc"; [ -n "$2" ] && array_add "$2" "$file.wosrc" generate_woapi "$file.api"; [ -n "$2" ] && array_add "$2" "$file.api" local -a imports implements local extends body imports=(com.webobjects.appserver.WOComponent com.webobjects.appserver.WOContext) extends=WOComponent implements=() body="\ private static final long serialVersionUID = 1L; public ${basename}(WOContext context) { super(context); }" generate_java "$file.java"; [ -n "$2" ] && array_add "$2" "$file.java" eend return 0 } template= edit= overwrite= encoding= package= imports=() extends= implements=() body= doctype= html= blueprint=1 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= \ --package: package= \ --imports: imports \ --extends: extends= \ --implements: implements \ --body: body= \ --doctype: doctype= \ --html '$html=1; doctype=html4; blueprint=' \ --blueprint,--bp '$blueprint=1; html=' \ @ args -- "$@" && set -- "${args[@]}" || die "$args" [ -n "$encoding" ] || encoding=utf-8 array_fix_paths imports array_fix_paths implements 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é case "$name" in Properties) t=javaproperties;; esac fi case "$t" in javaproperties|properties|jprops|props) generate_javaproperties "$file" files2edit || r=$?;; java|j) generate_java "$file" files2edit || r=$?;; woapi|api) generate_woapi "$file" files2edit || r=$?;; wosrc) generate_wosrc "$file" files2edit || r=$?;; wosrccomp|wc) generate_wosrccomp "$file" files2edit || r=$?;; *) die "$NAME: template invalide: $t";; esac done if [ -n "$edit" -a "${#files2edit[*]}" -gt 0 ]; then "${EDITOR:-vi}" "${files2edit[@]}" fi exit $r