summaryrefslogtreecommitdiffstats
path: root/config-model/src/main/make-xsd-files.sh
diff options
context:
space:
mode:
authorArne H Juul <arnej27959@users.noreply.github.com>2022-03-28 22:23:13 +0200
committerGitHub <noreply@github.com>2022-03-28 22:23:13 +0200
commit40878abd238247380fbc97213b2234fa66a15da1 (patch)
tree02c24ab3b59fde938a85efb1bea3c2c1c1204176 /config-model/src/main/make-xsd-files.sh
parent827e0b55a041101de1155671775de182c8965969 (diff)
parentf6617efb03a02ba0680b544c12d8ba43eaf5811a (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-xconfig-model/src/main/make-xsd-files.sh45
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