diff options
author | Arne H Juul <arnej27959@users.noreply.github.com> | 2022-03-28 22:23:13 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-28 22:23:13 +0200 |
commit | 40878abd238247380fbc97213b2234fa66a15da1 (patch) | |
tree | 02c24ab3b59fde938a85efb1bea3c2c1c1204176 /config-model/src/main/make-xsd-files.sh | |
parent | 827e0b55a041101de1155671775de182c8965969 (diff) | |
parent | f6617efb03a02ba0680b544c12d8ba43eaf5811a (diff) |
Merge pull request #21852 from vespa-engine/arnej/avoid-using-makev7.566.21
replace call to "make" with a simple script
Diffstat (limited to 'config-model/src/main/make-xsd-files.sh')
-rwxr-xr-x | config-model/src/main/make-xsd-files.sh | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/config-model/src/main/make-xsd-files.sh b/config-model/src/main/make-xsd-files.sh new file mode 100755 index 00000000000..27057a9599d --- /dev/null +++ b/config-model/src/main/make-xsd-files.sh @@ -0,0 +1,45 @@ +#!/bin/sh + +set -e + +srcdir=resources/schema +outputdir=../../target/generated-sources/trang/resources/schema + +trangjar=../../target/trang.jar + +outputs="services hosts container-include deployment validation-overrides" + +gen_xsd() { + echo "Generating XML schema: $1.rnc -> $1.rng -> $1.xsd" + java -jar ${trangjar} -I rnc -O rng ${srcdir}/$1.rnc ${outputdir}/$1.rng + java -jar ${trangjar} -I rng -O xsd ${outputdir}/$1.rng ${outputdir}/$1.xsd + echo "generated ok." +} + +regenall() { + mkdir -p $outputdir + for x in $outputs; do gen_xsd $x; done +} + +need_regen() { + for out in $outputs; do + outfile=${outputdir}/${out}.xsd + if [ -f ${outfile} ]; then + for infile in ${srcdir}/*.*; do + if [ ${infile} -nt ${outfile} ]; then + echo "Updated input: ${infile} - regenerating all" + return 0 + fi + done + else + echo "Missing output: ${outfile} - regenerating all" + return 0 + fi + done + echo "No updates for schema files" + return 1 +} + +if need_regen; then + regenall +fi |