Compare commits
3 Commits
master
...
wip/dkbuil
Author | SHA1 | Date |
---|---|---|
Jephté Clain | 17aa9c2d1f | |
Jephté Clain | 898f553ea9 | |
Jephté Clain | 21583617bf |
25
CHANGES.md
25
CHANGES.md
|
@ -1,28 +1,3 @@
|
||||||
## Version 11.3.1 du 31/12/2024-15:05
|
|
||||||
|
|
||||||
* `b9f264f` bug avec dkbuild -e
|
|
||||||
* `737179b` modifs.mineures sans commentaires
|
|
||||||
* `2687e72` support minimal runphp
|
|
||||||
|
|
||||||
## Version 11.3.0 du 24/09/2024-16:02
|
|
||||||
|
|
||||||
* `625d5f1` bug mineur
|
|
||||||
* `e308202` dkbuild: améliorer from_glob()
|
|
||||||
* `5c03184` lgrep, lless: modifier la doc pour ne parler que d'un fichier
|
|
||||||
|
|
||||||
## Version 11.2.0 du 21/06/2024-20:34
|
|
||||||
|
|
||||||
* `21042e4` bug
|
|
||||||
* `e4176df` reginc: possibilité de renommer des fichiers
|
|
||||||
* `1787aa2` bug
|
|
||||||
* `d1f77aa` dkbuild: support dist none et tag LATEST
|
|
||||||
* `c2cfd77` bug
|
|
||||||
* `e7745c2` dk: support --plain-output
|
|
||||||
* `ce8f541` dkbuild: -g pour --profile
|
|
||||||
* `30594aa` maj distributions
|
|
||||||
* `2df175e` dkbuild: cosmetic
|
|
||||||
* `fbb05f8` support des versions AMUE
|
|
||||||
|
|
||||||
## Version 11.1.0 du 01/02/2024-20:59
|
## Version 11.1.0 du 01/02/2024-20:59
|
||||||
|
|
||||||
* `8570d12` pff: les répertoires liés peuvent contenir des fichiers
|
* `8570d12` pff: les répertoires liés peuvent contenir des fichiers
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
# TODO
|
||||||
|
|
||||||
|
* [ ] réordonner les versions: version la plus récente en premier, pour être cohérent avec setdists
|
||||||
|
* [ ] gestion de la version de façon incrémentale
|
||||||
|
~~~
|
||||||
|
addversion "$DIST" # est implicite
|
||||||
|
addversion j11
|
||||||
|
addversion 75
|
||||||
|
# donne les tags suivants:
|
||||||
|
# - latest $DIST j11 75 j11-$DIST 75-j11-$DIST
|
||||||
|
|
||||||
|
addversion d12 d11 # est implicite
|
||||||
|
addversion j11 j8
|
||||||
|
addversion 89
|
||||||
|
# donne les tags suivants:
|
||||||
|
# - latest d12 j11 89 j11-d12 89-j11-d12
|
||||||
|
# - j8-d12 89-j8-d12
|
||||||
|
# - d11 j11-d11 89-j11-d11
|
||||||
|
# - j8-d11 89-j8-d11
|
||||||
|
~~~
|
||||||
|
* [ ] supprimer le support des versions avec les profils et les distributions
|
||||||
|
* en définitive:
|
||||||
|
* les versions sont indépendantes des profils et des distributions
|
||||||
|
* la distribution est rajoutée implicitement à la version sauf avis contraire
|
||||||
|
* pour compatibilité, les deux lignes suivantes sont équivalentes:
|
||||||
|
~~~
|
||||||
|
setversion a-b-c
|
||||||
|
# équivalent à
|
||||||
|
addversion c; addversion b; addversion a
|
||||||
|
~~~
|
||||||
|
* la version est utilisée pour construire les tags (faut-il renommer addversion en addtag?)
|
||||||
|
* [ ] faire tourner chaque build dans un sous-shell pour améliorer la gestion des variables
|
||||||
|
* [ ] comme dans runs, faire une section run: ?
|
||||||
|
ATTENTION! build() déclenche AUTOBUILD=, et si on fait une section run:,
|
||||||
|
cette commande ne sera pas lancée, et donc le build sera fait en deux fois
|
||||||
|
|
||||||
|
* [ ] setversion peut prendre la version depuis la branche git d'un dépôt
|
||||||
|
* un argument permettrait de spécifier comment la version est calculée à
|
||||||
|
partir du dépôt
|
||||||
|
* [ ] si cela a du sens, une commande setlatest qui permet de désigner quelle
|
||||||
|
distribution/version est la dernière
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-*- coding: utf-8 mode: markdown -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8:noeol:binary
|
25
TODO.md
25
TODO.md
|
@ -1,25 +0,0 @@
|
||||||
# TODO
|
|
||||||
|
|
||||||
dkbuild
|
|
||||||
* setversion peut prendre la version depuis la branche git d'un dépôt
|
|
||||||
* un argument permettrait de spécifier comment la version est calculée à
|
|
||||||
partir du dépôt
|
|
||||||
* si cela a du sens, une commande setlatest qui permet de désigner quelle
|
|
||||||
distribution/version est la dernière
|
|
||||||
|
|
||||||
|
|
||||||
git push
|
|
||||||
* ajouter le support pour le mode DEBUG
|
|
||||||
~~~
|
|
||||||
export GIT_TRACE=1
|
|
||||||
export GIT_TRANSFER_TRACE=1
|
|
||||||
export GIT_CURL_VERBOSE=1
|
|
||||||
~~~
|
|
||||||
* ajouter le support http basique pour git lfs en cas de problème pour upload de certains fichiers
|
|
||||||
~~~
|
|
||||||
git config --add lfs.basictransfersonly true
|
|
||||||
~~~
|
|
||||||
ou le mettre dans un fichier .lfsconfig
|
|
||||||
cf https://github.com/git-lfs/git-lfs/blob/main/docs/man/git-lfs-config.adoc
|
|
||||||
|
|
||||||
-*- coding: utf-8 mode: markdown -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8:noeol:binary
|
|
|
@ -1 +1 @@
|
||||||
11.3.1
|
11.1.0
|
||||||
|
|
33
dk
33
dk
|
@ -336,8 +336,6 @@ OPTIONS build
|
||||||
deploy, by, bpy et update impliquent --stack
|
deploy, by, bpy et update impliquent --stack
|
||||||
-j, --no-cache
|
-j, --no-cache
|
||||||
Ne pas utiliser le cache lors du build
|
Ne pas utiliser le cache lors du build
|
||||||
--plain-output
|
|
||||||
Afficher la sortie complète des containers lors du build
|
|
||||||
-U, --pull
|
-U, --pull
|
||||||
Essayer de récupérer une version plus récente de l'image source
|
Essayer de récupérer une version plus récente de l'image source
|
||||||
-g, --ug, --no-update-apps
|
-g, --ug, --no-update-apps
|
||||||
|
@ -1247,7 +1245,6 @@ function default_compose_build() {
|
||||||
"${replace_env_args[@]}" "${env_args[@]}" \
|
"${replace_env_args[@]}" "${env_args[@]}" \
|
||||||
build \
|
build \
|
||||||
${NO_CACHE:+--no-cache} \
|
${NO_CACHE:+--no-cache} \
|
||||||
${PROGRESS:+--progress "$PROGRESS"} \
|
|
||||||
${PULL:+--pull} \
|
${PULL:+--pull} \
|
||||||
"${replace_build_args[@]}" "${build_args[@]}" \
|
"${replace_build_args[@]}" "${build_args[@]}" \
|
||||||
"$@"
|
"$@"
|
||||||
|
@ -1259,7 +1256,6 @@ function default_docker_build() {
|
||||||
done
|
done
|
||||||
${FAKE:+qvals} "$DOCKER" build \
|
${FAKE:+qvals} "$DOCKER" build \
|
||||||
${NO_CACHE:+--no-cache} \
|
${NO_CACHE:+--no-cache} \
|
||||||
${PROGRESS:+--progress "$PROGRESS"} \
|
|
||||||
${PULL:+--pull} \
|
${PULL:+--pull} \
|
||||||
"${replace_env_args[@]}" "${env_args[@]}" \
|
"${replace_env_args[@]}" "${env_args[@]}" \
|
||||||
"${replace_build_args[@]}" "${build_args[@]}" \
|
"${replace_build_args[@]}" "${build_args[@]}" \
|
||||||
|
@ -1309,7 +1305,6 @@ function auto_build() {
|
||||||
done
|
done
|
||||||
${FAKE:+qvals} "$DOCKER" build \
|
${FAKE:+qvals} "$DOCKER" build \
|
||||||
${NO_CACHE:+--no-cache} \
|
${NO_CACHE:+--no-cache} \
|
||||||
${PROGRESS:+--progress "$PROGRESS"} \
|
|
||||||
${PULL:+--pull} \
|
${PULL:+--pull} \
|
||||||
"${replace_build_args[@]}" "$@"
|
"${replace_build_args[@]}" "$@"
|
||||||
fi
|
fi
|
||||||
|
@ -2099,10 +2094,8 @@ function auto_composer() {
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
local use_runphp use_image
|
local use_image
|
||||||
if [ "$COMPOSER_PHP" == runphp ]; then
|
if [ "$COMPOSER_PHP" == force -o "$COMPOSER_PHP" == any ]; then
|
||||||
use_runphp=1
|
|
||||||
elif [ "$COMPOSER_PHP" == force -o "$COMPOSER_PHP" == any ]; then
|
|
||||||
use_image=1
|
use_image=1
|
||||||
elif [ "$COMPOSER_PHP" == none -o "$COMPOSER_PHP" == system ]; then
|
elif [ "$COMPOSER_PHP" == none -o "$COMPOSER_PHP" == system ]; then
|
||||||
COMPOSER_PHP=none
|
COMPOSER_PHP=none
|
||||||
|
@ -2123,7 +2116,7 @@ exit((PHP_VERSION_ID > $version)? 0: 1);
|
||||||
*) ewarn "Erreur lors du lancement de PHP: est-il installé? Vous pouvez utiliser COMPOSER_PHP=any";;
|
*) ewarn "Erreur lors du lancement de PHP: est-il installé? Vous pouvez utiliser COMPOSER_PHP=any";;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
if [ -n "$use_runphp" -o -n "$use_image" -o "$COMPOSER_PHP" == none ]; then
|
if [ -n "$use_image" -o "$COMPOSER_PHP" == none ]; then
|
||||||
: # ok, on a déjà décidé
|
: # ok, on a déjà décidé
|
||||||
elif [ -z "$COMPOSER_PHP" ]; then
|
elif [ -z "$COMPOSER_PHP" ]; then
|
||||||
# pas de version minimum, tester simplement la valeur de COMPOSER_IMAGE
|
# pas de version minimum, tester simplement la valeur de COMPOSER_IMAGE
|
||||||
|
@ -2145,23 +2138,7 @@ exit((PHP_VERSION_ID < $version)? 0: 1);
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$use_runphp" ]; then
|
if [ -n "$use_image" ]; then
|
||||||
(
|
|
||||||
export PROJDIR="$(pwd)"
|
|
||||||
export RUNPHP_STANDALONE=
|
|
||||||
RUNPHP=; DIST=; REGISTRY=
|
|
||||||
if [ -f "$PROJDIR/.runphp.conf" ]; then
|
|
||||||
source "$PROJDIR/.runphp.conf"
|
|
||||||
[ -n "$RUNPHP" ] && exec "$PROJDIR/$RUNPHP" composer "$@"
|
|
||||||
elif [ -f "$PROJDIR/sbin/runphp" ]; then
|
|
||||||
exec "$PROJDIR/sbin/runphp" composer "$@"
|
|
||||||
elif [ -f "$PROJDIR/runphp" ]; then
|
|
||||||
exec "$PROJDIR/runphp" composer "$@"
|
|
||||||
fi
|
|
||||||
exec runphp composer "$@"
|
|
||||||
)
|
|
||||||
|
|
||||||
elif [ -n "$use_image" ]; then
|
|
||||||
[ "$COMPOSER_IMAGE" != none ] || die "Vous devez spécifier l'image à utiliser pour composer"
|
[ "$COMPOSER_IMAGE" != none ] || die "Vous devez spécifier l'image à utiliser pour composer"
|
||||||
|
|
||||||
local PREVIOUS_DOCKER_MACHINE_NAME="$DOCKER_MACHINE_NAME"
|
local PREVIOUS_DOCKER_MACHINE_NAME="$DOCKER_MACHINE_NAME"
|
||||||
|
@ -2522,7 +2499,6 @@ FAKE=
|
||||||
VARS=()
|
VARS=()
|
||||||
FORCE=
|
FORCE=
|
||||||
NO_CACHE=
|
NO_CACHE=
|
||||||
PROGRESS=
|
|
||||||
PULL=
|
PULL=
|
||||||
HOST=
|
HOST=
|
||||||
WITH_REGISTRY_AUTH=1
|
WITH_REGISTRY_AUTH=1
|
||||||
|
@ -2546,7 +2522,6 @@ args=(
|
||||||
-e:,--build-arg:,--env: VARS
|
-e:,--build-arg:,--env: VARS
|
||||||
-f,--force FORCE=1
|
-f,--force FORCE=1
|
||||||
-j,--no-cache NO_CACHE=1
|
-j,--no-cache NO_CACHE=1
|
||||||
--plain-output PROGRESS=plain
|
|
||||||
-U,--pull PULL=1
|
-U,--pull PULL=1
|
||||||
-h:,--host: HOST=
|
-h:,--host: HOST=
|
||||||
-g,--ug,--no-update-apps update_apps_mode=b
|
-g,--ug,--no-update-apps update_apps_mode=b
|
||||||
|
|
64
dkbuild
64
dkbuild
|
@ -100,7 +100,7 @@ $scriptname build [OPTIONS] [BUILDVARS...]
|
||||||
le build pour toutes les distributions définies. Si la distribution
|
le build pour toutes les distributions définies. Si la distribution
|
||||||
sélectionnée n'est pas valide pour ce build, elle est ignorée
|
sélectionnée n'est pas valide pour ce build, elle est ignorée
|
||||||
|
|
||||||
-g, --profile PROFILE
|
--profile PROFILE
|
||||||
-P, --prod
|
-P, --prod
|
||||||
-T, --test
|
-T, --test
|
||||||
-E, --dtest
|
-E, --dtest
|
||||||
|
@ -224,13 +224,9 @@ construites. Une version est définie en ajoutant un préfixe à la distribution
|
||||||
La commande 'setdists' permet de lister explicitement les distributions valides
|
La commande 'setdists' permet de lister explicitement les distributions valides
|
||||||
(et les versions associées le cas échéant). Si la distribution sélectionnée par
|
(et les versions associées le cas échéant). Si la distribution sélectionnée par
|
||||||
l'utilisateur n'est pas dans la liste fournie, le script s'arrête sans erreur.
|
l'utilisateur n'est pas dans la liste fournie, le script s'arrête sans erreur.
|
||||||
|
|
||||||
La première distribution listée est spéciale: c'est la distribution la plus
|
La première distribution listée est spéciale: c'est la distribution la plus
|
||||||
récente, celle qui reçoit le tag :latest
|
récente, celle qui reçoit le tag :latest
|
||||||
|
|
||||||
La distribution 'none' est spéciale aussi: elle n'est pas mentionnée dans les
|
|
||||||
tags automatiquement attribués aux images.
|
|
||||||
|
|
||||||
La commande 'dist' permet de tester si la distribution spécifiée en argument a
|
La commande 'dist' permet de tester si la distribution spécifiée en argument a
|
||||||
été sélectionnée par l'utilisateur. L'argument 'LATEST' permet de tester la
|
été sélectionnée par l'utilisateur. L'argument 'LATEST' permet de tester la
|
||||||
dernière distribution.
|
dernière distribution.
|
||||||
|
@ -682,8 +678,7 @@ Les paramètres optionnels sont
|
||||||
* set-tag=TAGS... ou set-tags=TAGS...
|
* set-tag=TAGS... ou set-tags=TAGS...
|
||||||
spécifier des tags à rajouter au nom de l'image, séparés par un espace. cette
|
spécifier des tags à rajouter au nom de l'image, séparés par un espace. cette
|
||||||
liste remplace celle calculée automatiquement. ce paramètre est ignoré pour
|
liste remplace celle calculée automatiquement. ce paramètre est ignoré pour
|
||||||
les noms d'images comportant un tag.
|
les noms d'images comportant un tag
|
||||||
Utiliser le tag spécial LATEST pour rajouter :latest si c'est approprié
|
|
||||||
* add-tag=TAGS... ou add-tags=TAGS...
|
* add-tag=TAGS... ou add-tags=TAGS...
|
||||||
spécifier des tags à rajouter à la liste calculée automatiquement, séparés par
|
spécifier des tags à rajouter à la liste calculée automatiquement, séparés par
|
||||||
un espace. ce paramètre est ignoré pour les noms d'images comportant un tag
|
un espace. ce paramètre est ignoré pour les noms d'images comportant un tag
|
||||||
|
@ -946,8 +941,8 @@ SHARED_ARGS2=(
|
||||||
-d:,--dist: DIST=
|
-d:,--dist: DIST=
|
||||||
-0,--d10 DIST=d10
|
-0,--d10 DIST=d10
|
||||||
-1,--d11 DIST=d11
|
-1,--d11 DIST=d11
|
||||||
-2,--d12 DIST=d12
|
-2,--d12 DIST=d11
|
||||||
-3,--d13 DIST=d13
|
-3,--d13 DIST=d11
|
||||||
--r7,--rhel7 DIST=rhel7
|
--r7,--rhel7 DIST=rhel7
|
||||||
--r8,--rhel8 DIST=rhel8
|
--r8,--rhel8 DIST=rhel8
|
||||||
--r9,--rhel9 DIST=rhel9
|
--r9,--rhel9 DIST=rhel9
|
||||||
|
@ -955,7 +950,7 @@ SHARED_ARGS2=(
|
||||||
--ol8,--oracle8 DIST=ol8
|
--ol8,--oracle8 DIST=ol8
|
||||||
--ol9,--oracle9 DIST=ol9
|
--ol9,--oracle9 DIST=ol9
|
||||||
|
|
||||||
-g:,--profile: PROFILE=
|
-p:,--profile: PROFILE=
|
||||||
-P,--prod PROFILE=prod
|
-P,--prod PROFILE=prod
|
||||||
-T,--test PROFILE=test
|
-T,--test PROFILE=test
|
||||||
-E,--dtest PROFILE=dtest
|
-E,--dtest PROFILE=dtest
|
||||||
|
@ -1083,13 +1078,12 @@ function reset_functions() {
|
||||||
function include() {
|
function include() {
|
||||||
edebug "include $(qvals "$@")"
|
edebug "include $(qvals "$@")"
|
||||||
|
|
||||||
local file="$1" cwd="$(pwd)"
|
local file="$1"
|
||||||
[ -d "$file" ] && file="$file/dkbuild"
|
[ -d "$file" ] && file="$file/dkbuild"
|
||||||
[ -f "$file" ] || die "$file: fichier introuvable"
|
[ -f "$file" ] || die "$file: fichier introuvable"
|
||||||
setx file=abspath "$file"
|
setx file=abspath "$file"
|
||||||
cd "$(dirname "$file")"
|
cd "$(dirname "$file")"
|
||||||
source "$file"
|
source "$file"
|
||||||
cd "$cwd"
|
|
||||||
}
|
}
|
||||||
function machine() {
|
function machine() {
|
||||||
local machine version
|
local machine version
|
||||||
|
@ -1188,14 +1182,12 @@ function load_environ() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function from_glob() {
|
function from_glob() {
|
||||||
local vvalue=value value vfile=file file
|
local var=value value
|
||||||
[[ "$1" != *=* ]] && { vvalue="$1"; shift; }
|
[[ "$1" != *=* ]] && { var="$1"; shift; }
|
||||||
[[ "$1" != *=* ]] && { vfile="$1"; shift; }
|
|
||||||
|
|
||||||
local basedir path extract add_prefix add_suffix
|
local path extract add_prefix add_suffix
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
basedir=*) basedir="${1#basedir=}";;
|
|
||||||
path=*) path="${1#path=}";;
|
path=*) path="${1#path=}";;
|
||||||
extract=*) extract="${1#extract=}";;
|
extract=*) extract="${1#extract=}";;
|
||||||
add-prefix=*) add_prefix="${1#add-prefix=}";;
|
add-prefix=*) add_prefix="${1#add-prefix=}";;
|
||||||
|
@ -1205,9 +1197,7 @@ function from_glob() {
|
||||||
esac
|
esac
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
[ -n "$basedir" ] || basedir=.
|
value="$(list_all . "$path" | sort -rn | head -1)"
|
||||||
value="$(list_all "$basedir" "$path" | sort -rn | head -1)"
|
|
||||||
file="$basedir/$value"
|
|
||||||
[ -n "$extract" ] || extract="${path//\*/(.*)}"
|
[ -n "$extract" ] || extract="${path//\*/(.*)}"
|
||||||
if [ -n "$extract" ]; then
|
if [ -n "$extract" ]; then
|
||||||
extract="${extract//\//\\/}"
|
extract="${extract//\//\\/}"
|
||||||
|
@ -1217,7 +1207,7 @@ function from_glob() {
|
||||||
}")$add_suffix"
|
}")$add_suffix"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local "$vvalue" "$vfile"; upvars "$vvalue" "$value" "$vfile" "$file"
|
local "$var"; upvar "$var" "$value"
|
||||||
}
|
}
|
||||||
function define_functions_env() {
|
function define_functions_env() {
|
||||||
function setversion() {
|
function setversion() {
|
||||||
|
@ -1603,10 +1593,6 @@ function resolve_dists_profiles() {
|
||||||
edebug "Calcul de la version par défaut"
|
edebug "Calcul de la version par défaut"
|
||||||
reset_functions
|
reset_functions
|
||||||
define_functions_env
|
define_functions_env
|
||||||
|
|
||||||
setenv "${TMPENVIRON[@]}"
|
|
||||||
setarg "${TMPARGS[@]}"
|
|
||||||
setarg "$@"
|
|
||||||
load_dkbuild
|
load_dkbuild
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2056,14 +2042,6 @@ function define_functions_cmd() {
|
||||||
imagetags+=("$imagetag")
|
imagetags+=("$imagetag")
|
||||||
else
|
else
|
||||||
for tag in "${set_tags[@]}" "${add_tags[@]}"; do
|
for tag in "${set_tags[@]}" "${add_tags[@]}"; do
|
||||||
if [ "$tag" == LATEST ]; then
|
|
||||||
if [ -n "$HAVE_VERSION" -a "$VERSION" == "$LAST_VERSION" ]; then
|
|
||||||
tag=latest
|
|
||||||
else
|
|
||||||
# ignorer le tag LATEST s'il n'est pas applicable
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
imagetags+=("$imagetag:$tag")
|
imagetags+=("$imagetag:$tag")
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
@ -2076,16 +2054,10 @@ function define_functions_cmd() {
|
||||||
imagetags+=("$imagetag")
|
imagetags+=("$imagetag")
|
||||||
else
|
else
|
||||||
for tag in "${add_tags[@]}"; do
|
for tag in "${add_tags[@]}"; do
|
||||||
if [ "$tag" == LATEST ]; then
|
|
||||||
# toujours ignorer le tag LATEST dans add_tags
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
imagetags+=("$imagetag:$tag")
|
imagetags+=("$imagetag:$tag")
|
||||||
done
|
done
|
||||||
[ -n "$VERSION" ] && imagetags+=("$imagetag:$VERSION-$DIST")
|
[ -n "$VERSION" ] && imagetags+=("$imagetag:$VERSION-$DIST")
|
||||||
if [ -n "$DIST" -a "$DIST" != none -a -z "$HAVE_VERSION" ]; then
|
[ -n "$DIST" -a -z "$HAVE_VERSION" ] && imagetags+=("$imagetag:$DIST")
|
||||||
imagetags+=("$imagetag:$DIST")
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
@ -2094,7 +2066,7 @@ function define_functions_cmd() {
|
||||||
if [ -z "$HAVE_VERSION" ]; then
|
if [ -z "$HAVE_VERSION" ]; then
|
||||||
dist LATEST && imagetags+=("$imagetag:latest")
|
dist LATEST && imagetags+=("$imagetag:latest")
|
||||||
elif [ "$VERSION" == "$LAST_VERSION" ]; then
|
elif [ "$VERSION" == "$LAST_VERSION" ]; then
|
||||||
[ "$DIST" != none ] && imagetags+=("$imagetag:$DIST")
|
imagetags+=("$imagetag:$DIST")
|
||||||
dist LATEST && imagetags+=("$imagetag:latest")
|
dist LATEST && imagetags+=("$imagetag:latest")
|
||||||
fi
|
fi
|
||||||
elif [ -n "$PROFILE" ]; then
|
elif [ -n "$PROFILE" ]; then
|
||||||
|
@ -2977,7 +2949,10 @@ function build_action() {
|
||||||
set_machine "$machine"
|
set_machine "$machine"
|
||||||
|
|
||||||
ensure_projdir
|
ensure_projdir
|
||||||
resolve_dists_profiles "$@"
|
resolve_dists_profiles
|
||||||
|
setenv "${TMPENVIRON[@]}"
|
||||||
|
setarg "${TMPARGS[@]}"
|
||||||
|
setarg "$@"
|
||||||
|
|
||||||
if [ -n "$clean_update" ]; then
|
if [ -n "$clean_update" ]; then
|
||||||
edebug "clean"
|
edebug "clean"
|
||||||
|
@ -3146,7 +3121,10 @@ function dump_action() {
|
||||||
set_machine "$machine"
|
set_machine "$machine"
|
||||||
|
|
||||||
ensure_projdir
|
ensure_projdir
|
||||||
resolve_dists_profiles "$@"
|
resolve_dists_profiles
|
||||||
|
setenv "${TMPENVIRON[@]}"
|
||||||
|
setarg "${TMPARGS[@]}"
|
||||||
|
setarg "$@"
|
||||||
|
|
||||||
foreach_dists_profiles _dump_each _dump_before _dump_after
|
foreach_dists_profiles _dump_each _dump_before _dump_after
|
||||||
}
|
}
|
||||||
|
|
4
lgrep
4
lgrep
|
@ -3,10 +3,10 @@
|
||||||
source "$(dirname "$0")/lib/ulib/auto" || exit 1
|
source "$(dirname "$0")/lib/ulib/auto" || exit 1
|
||||||
|
|
||||||
function display_help() {
|
function display_help() {
|
||||||
uecho "$scriptname: frontend de grep pour chercher dans un fichier encodé en latin1
|
uecho "$scriptname: frontend de grep pour lire des fichiers encodés en latin1
|
||||||
|
|
||||||
USAGE
|
USAGE
|
||||||
$scriptname [options] FILE
|
$scriptname [options] files...
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
options de grep qui sont reprises telles quelles"
|
options de grep qui sont reprises telles quelles"
|
||||||
|
|
|
@ -8,7 +8,7 @@ info "A=$A, B=$B"
|
||||||
if [ "$A" != x ]; then
|
if [ "$A" != x ]; then
|
||||||
note "\
|
note "\
|
||||||
Essayer de relancer avec
|
Essayer de relancer avec
|
||||||
$(qvals "$0" -j "$(relpath "$DKBUILD")" -e A=x -e B=y)
|
$(qvals dkbuild -j "$(relpath "$DKBUILD")" -e A=x -e B=y)
|
||||||
on ne devrait pas pouvoir modifier la valeur de B"
|
on ne devrait pas pouvoir modifier la valeur de B"
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -1,15 +0,0 @@
|
||||||
# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
|
|
||||||
|
|
||||||
setenv dne=1
|
|
||||||
setenv de=
|
|
||||||
|
|
||||||
info "dne=$dne de=$de"
|
|
||||||
if [ -n "$dne" -o -z "$de" ]; then
|
|
||||||
note "\
|
|
||||||
Relancer avec
|
|
||||||
$(qvals "$0" -j "$(relpath "$DKBUILD")" -e dne= -e de=1)
|
|
||||||
pour vérifier qu'on peut changer la valeur avec les options en ligne de commande"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# pas de build automatique
|
|
||||||
AUTOBUILD=
|
|
|
@ -154,7 +154,7 @@ function ctmatch_one(ctval, ref, parts, part, i, j, start, end, ste
|
||||||
#print "final: is " ref " ~ " ctval " ? " (ok? "yes": "no") #DEBUG
|
#print "final: is " ref " ~ " ctval " ? " (ok? "yes": "no") #DEBUG
|
||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
function ctmatch_all(M, H, dom, mon, dow, refM, refH, refdom, refmon, refdow, Mok, Hok, alldom, domok, monok, alldow, dowok, doxok) {
|
function ctmatch_all(M, H, dom, mon, dow, refM, refH, refdom, refmon, refdow, Mok, Hok, domok, monok, dowok) {
|
||||||
if (refM == "**ANY**") return 1
|
if (refM == "**ANY**") return 1
|
||||||
|
|
||||||
gsub(/\*/, "0-59", M)
|
gsub(/\*/, "0-59", M)
|
||||||
|
@ -163,28 +163,16 @@ function ctmatch_all(M, H, dom, mon, dow, refM, refH, refdom, refmon, refdow,
|
||||||
gsub(/\*/, "0-23", H)
|
gsub(/\*/, "0-23", H)
|
||||||
Hok = ctmatch_one(H, refH)
|
Hok = ctmatch_one(H, refH)
|
||||||
|
|
||||||
alldom = dom == "*"
|
|
||||||
gsub(/\*/, "1-31", dom)
|
gsub(/\*/, "1-31", dom)
|
||||||
domok = ctmatch_one(dom, refdom)
|
domok = ctmatch_one(dom, refdom)
|
||||||
|
|
||||||
gsub(/\*/, "1-12", mon)
|
gsub(/\*/, "1-12", mon)
|
||||||
monok = ctmatch_one(mon, refmon)
|
monok = ctmatch_one(mon, refmon)
|
||||||
|
|
||||||
alldow = dow == "*"
|
|
||||||
gsub(/\*/, "1-7", dow)
|
gsub(/\*/, "1-7", dow)
|
||||||
dowok = ctmatch_one(dow, refdow)
|
dowok = ctmatch_one(dow, refdow)
|
||||||
|
|
||||||
if (alldom && alldow) {
|
return Mok && Hok && monok && (domok || dowok)
|
||||||
doxok = 1
|
|
||||||
} else if (alldom) {
|
|
||||||
doxok = dowok
|
|
||||||
} else if (alldow) {
|
|
||||||
doxok = domok
|
|
||||||
} else {
|
|
||||||
doxok = domok || dowok
|
|
||||||
}
|
|
||||||
|
|
||||||
return Mok && Hok && monok && doxok
|
|
||||||
}
|
}
|
||||||
function print_cmd(cmd) {
|
function print_cmd(cmd) {
|
||||||
print "__ctexec " quote_value(cmd)
|
print "__ctexec " quote_value(cmd)
|
||||||
|
|
|
@ -213,7 +213,7 @@ function tl_modifyattr() {
|
||||||
dn = ""
|
dn = ""
|
||||||
}
|
}
|
||||||
sub(/:+$/, "", attr)
|
sub(/:+$/, "", attr)
|
||||||
if (tolower(lastattr) != tolower(attr)) {
|
if (lastattr != attr) {
|
||||||
if (lastattr != "") {
|
if (lastattr != "") {
|
||||||
print "-"
|
print "-"
|
||||||
}
|
}
|
||||||
|
@ -248,7 +248,7 @@ function tl_deleteattr() {
|
||||||
dn = ""
|
dn = ""
|
||||||
}
|
}
|
||||||
sub(/:+$/, "", attr)
|
sub(/:+$/, "", attr)
|
||||||
if (tolower(lastattr) != tolower(attr)) {
|
if (lastattr != attr) {
|
||||||
if (lastattr != "") {
|
if (lastattr != "") {
|
||||||
print "-"
|
print "-"
|
||||||
}
|
}
|
||||||
|
|
4
lless
4
lless
|
@ -3,10 +3,10 @@
|
||||||
source "$(dirname "$0")/lib/ulib/auto" || exit 1
|
source "$(dirname "$0")/lib/ulib/auto" || exit 1
|
||||||
|
|
||||||
function display_help() {
|
function display_help() {
|
||||||
uecho "$scriptname: frontend de less pour lire un fichier encodé en latin1
|
uecho "$scriptname: frontend de less pour lire des fichiers encodés en latin1
|
||||||
|
|
||||||
USAGE
|
USAGE
|
||||||
$scriptname [options] FILE
|
$scriptname [options] files...
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
-S, --chop-long-lines
|
-S, --chop-long-lines
|
||||||
|
|
81
reginc
81
reginc
|
@ -12,29 +12,24 @@ remplacer les nombres de FROMmin à FROMmax par leur valeur correspondante,
|
||||||
sachant que FROMmin doit être remplacé par TO. On peut mentionner autant de
|
sachant que FROMmin doit être remplacé par TO. On peut mentionner autant de
|
||||||
couples (FROM, TO) que nécessaire: ils seront traités dans l'ordre
|
couples (FROM, TO) que nécessaire: ils seront traités dans l'ordre
|
||||||
|
|
||||||
$scriptname -r FROMmin-FROMmax TO FILEs...
|
|
||||||
|
|
||||||
renommer les fichiers en remplaçant les nombres de FROMmin à FROMmax par leur
|
|
||||||
valeur correspondante, sachant que FROMmin doit être remplacé par TO
|
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
-n, --fake
|
-n, --fake
|
||||||
Afficher le fichier tel qu'il serait modifié au lieu de le modifier en
|
Afficher le fichier tel qu'il serait modifié au lieu de le modifier en
|
||||||
place
|
place"
|
||||||
-r, --rename
|
|
||||||
Renommer les fichiers au lieu de modifier le texte à l'intérieur du
|
|
||||||
fichier. Attention, l'ordre des arguments est différent avec cette
|
|
||||||
option"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function process_file() {
|
fake=
|
||||||
local file from to fromb frome seds r
|
args=(
|
||||||
|
--help '$exit_with display_help'
|
||||||
|
-n,--fake fake=1
|
||||||
|
)
|
||||||
|
parse_args "$@"; set -- "${args[@]}"
|
||||||
|
|
||||||
file="$1"; shift
|
file="$1"; shift
|
||||||
[ -n "$file" ] || die "vous devez spécifier le fichier à modifier"
|
[ -n "$file" ] || die "vous devez spécifier le fichier à modifier"
|
||||||
|
|
||||||
seds=
|
seds=
|
||||||
while [ $# -ge 2 ]; do
|
while [ $# -ge 2 ]; do
|
||||||
from="$1"
|
from="$1"
|
||||||
if [[ "$from" == *-* ]]; then
|
if [[ "$from" == *-* ]]; then
|
||||||
let fromb="${from%-*}"
|
let fromb="${from%-*}"
|
||||||
|
@ -69,54 +64,10 @@ function process_file() {
|
||||||
let to=to-1
|
let to=to-1
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
edebug "Script sed: $seds"
|
edebug "Script sed: $seds"
|
||||||
|
|
||||||
[ -n "$Fake" ] && args=() || args=(-i)
|
[ -n "$fake" ] && args=() || args=(-i)
|
||||||
args+=("$seds" "$file")
|
args+=("$seds" "$file")
|
||||||
sed "${args[@]}"; r=$?
|
sed "${args[@]}"
|
||||||
|
|
||||||
[ -z "$Fake" -a $r -eq 0 ]
|
|
||||||
}
|
|
||||||
|
|
||||||
Fake=
|
|
||||||
rename=
|
|
||||||
args=(
|
|
||||||
--help '$exit_with display_help'
|
|
||||||
-n,--Fake Fake=1
|
|
||||||
-r,--rename rename=1
|
|
||||||
)
|
|
||||||
parse_args "$@"; set -- "${args[@]}"
|
|
||||||
|
|
||||||
if [ -n "$rename" ]; then
|
|
||||||
from="$1"; to="$2"; shift 2
|
|
||||||
|
|
||||||
froms=("$@")
|
|
||||||
ac_set_tmpfile tmptos
|
|
||||||
echo "tos=(" >>"$tmptos"
|
|
||||||
for file in "${froms[@]}"; do
|
|
||||||
qval "$file" >>"$tmptos"
|
|
||||||
done
|
|
||||||
echo ")" >>"$tmptos"
|
|
||||||
|
|
||||||
Fake= process_file "$tmptos" "$from" "$to"
|
|
||||||
eval "$(<"$tmptos")"
|
|
||||||
|
|
||||||
i=0
|
|
||||||
count=${#froms[*]}
|
|
||||||
while [ $i -lt $count ]; do
|
|
||||||
from="${froms[$i]}"
|
|
||||||
to="${tos[$i]}"
|
|
||||||
if [ "$to" == "$from" ]; then
|
|
||||||
ewarn "$from: renommage non nécessaire"
|
|
||||||
else
|
|
||||||
estep "$from --> $to"
|
|
||||||
[ -z "$Fake" ] && mv "$from" "$to"
|
|
||||||
fi
|
|
||||||
let i=i+1
|
|
||||||
done
|
|
||||||
|
|
||||||
else
|
|
||||||
process_file "$@"
|
|
||||||
fi
|
|
||||||
|
|
Loading…
Reference in New Issue