# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8 ##@require instinc/prefixes ##@require instinc/wobase ##@require instinc/wofunctions function get_default_configfile() { # $1=resdir (woadir/Contents/Resources ou fwkdir/Resources) local configs configfile array_from_lines configs "$(list_files "$1" "*.config")" if [ ${#configs[*]} -eq 0 ]; then array_from_lines configs "$(list_files "$1" "config.xml")" fi echo "${configs:-Properties}" } function set_config_property() { # Modifier la propriété $2 avec la valeur $3 du fichier de configuration par # défaut de l'application $1. On peut préciser le nom du fichier de # configuration à utiliser avec $4. Par défaut, il s'agit du premier fichier # ayant l'extension .config. Il doit s'agir d'un fichier de propriétés java. # si $2 vaut "-", $3 doit être de la forme "[configfile/]prop=value" ou # ">configfile[:srcfile]" local action=setprop local bundir="$1" prop="$2" value="$3" configfile="$4" local srvresdir="$APP_SRVRESDIR" if is_wofwdir "$bundir"; then srvresdir="$FW_SRVRESDIR" fi if [ "$prop" == "-" ]; then if beginswith "$value" ">"; then # choix d'un fichier de configuration par défaut action=setconfigfile configfile="${value#>}" prop= if [ "${configfile//:/}" != "$configfile" ]; then # on a donné un fichier source prop="copysrcfile" value="${configfile##*:}" configfile="${configfile%:*}" fi else # modification de la valeur d'une propriété prop="${value%%=*}" if [ "${prop//\//}" != "$prop" ]; then # on a donné le nom du fichier de propriété configfile="${prop%/*}" prop="${prop##*/}" fi value="${value#*=}" fi fi if [ -z "$configfile" ]; then if [ -n "$DEFAULT_CONFIGFILE" ]; then configfile="$DEFAULT_CONFIGFILE" else configfile="$(get_default_configfile "$bundir/$srvresdir")" fi fi if [ "$action" == "setprop" ]; then dest="$configfile" first_char_is "$dest" "/" || dest="$bundir/$srvresdir/$dest" mkdirof "$dest" file_set_properties -c "$dest" "$prop" "$value" elif [ "$action" == "setconfigfile" ]; then if [ "$prop" == "copysrcfile" ]; then src="$value" dest="$configfile" # chemin absolus first_char_is "$src" "/" || src="$bundir/$srvresdir/$src" first_char_is "$dest" "/" || dest="$bundir/$srvresdir/$dest" mkdirof "$dest" /bin/cp -f "$src" "$dest" fi DEFAULT_CONFIGFILE="$configfile" fi } function set_eomodel_property() { : } function woconf_display_help() { echo "$scriptname: vérifier et modifier la configuration d'une application ou d'un framework USAGE $scriptname <fw.framework|app.woa> \"conf_cmds\" Les lignes de configuration peuvent être: #commentaire -- un commentaire (ignoré) v[erify] -- vérifier et corriger la consistance. Cette action est faite automatiquement sauf avec l'option --noverify. c>configfile -- changer le fichier de configuration par défaut c>configfile:srcfile -- copier le fichier de configuration srcfile sur configfile et choisir ce fichier comme fichier de configuration par défaut c[configfile/]prop=value -- modifier une propriété du fichier de configuration. === les options suivantes ne sont pas encore implémentées ================= eprofile:user:password -- configurer l'eomodel par défaut selon le profil ehost:port:instance:user:passwd -- configurer l'eomodel par défaut avec les valeurs données Ename.eomodeld:profile:user:password -- configurer l'eomodel donné selon le profil Ename.eomodeld:host:port:instance:user:password -- configurer l'eomodel donné avec les valeurs données Les lignes de configuration suivantes sont spécifiques aux application (.woa) aMyFramework[.framework] -- ajouter un framework rMyFramework[.framework] -- enlever un framework sbefore:after -- faire un recherche/remplacement f[ix_case] -- corriger la casse du classpath selon les frameworks installés" } function woconf() { local noverify= local end_of_options ##@include sysinc/begingetopt -h|--help) woconf_display_help exit 0 ;; --no-verify) # ne pas effectuer automatiquement la vérification du bundle noverify=1 ;; ##@include sysinc/endgetopt local tagdir="$1" srcdir bundir if [ -z "$tagdir" ]; then die "Il faut spécifier l'application ou le framework à modifier" fi tagdir="$(abspath "$1")" if is_wosrcdir "$tagdir"; then srcdir="$tagdir" set_wobindir "$srcdir" bundir desc elif is_woappdir "$tagdir"; then bundir="$tagdir" elif is_wofwdir "$tagdir"; then bundir="$tagdir" else die "Le bundle doit être un framework ou une application" fi [ -w "$bundir" ] || die "Répertoire de bundle non accessible en écriture." bundir="${bundir%/}" if [ -z "$noverify" ]; then verifix_bundle "$bundir" fi array_from_lines conf_cmds "$2" for conf_cmd in "${conf_cmds[@]}"; do action="$(first_char "$conf_cmd")" option="$(last_chars "$conf_cmd")" if [ "$action" == "#" ]; then : # commentaire ignoré elif [ "$action" == "v" ]; then verifix_bundle "$bundir" elif [ "$action" == "c" ]; then set_config_property "$bundir" - "$option" elif [ "$action" == "e" ]; then set_eomodel_property "$bundir" - "$option" elif [ "$action" == "a" ]; then add_framework "$bundir" "$option" elif [ "$action" == "r" ]; then remove_framework "$bundir" "$option" elif [ "$action" == "s" ]; then search="${option%%:*}" replace="${option#*:}" searchreplace_classpath "$bundir" "$search" "$replace" elif [ "$action" == "f" ]; then fix_jars_case "$bundir" else eerror "Commande inconnue: $action" fi done }