summaryrefslogtreecommitdiff
path: root/src/third_party/wiredtiger/dist/s_docs_plantuml
blob: 43c669591a760bf59d179aed6f6dab959d1798b6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#! /bin/sh
# Usage: ./s_docs_plantuml [-d|Auto download plantuml if doesn't exist in dist/]
# This script checks for the existence of plantuml jar file (optionally
# downloading it from sourceforge) and then generates uml images from the
# plantuml templates embedded in the documentation.
# Run this script after adding new plantuml templates to generate a fresh set of
# uml images. All new images generated should be commited with the code.
# For easy prototyping, following link can be used to generate these images
# online:
# http://www.plantuml.com/plantuml

PLANTUML_URL="https://downloads.sourceforge.net/project/plantuml/plantuml.jar?r=&ts=1499750156&use_mirror=nchc"

# We require java which may not be installed.
type java > /dev/null 2>&1 || {
	echo 'skipped: java not found'
	exit 0
}

download_plantuml=0
while :
	do case "$1" in
	-d)	# Download plantuml if not already there
		download_plantuml=1
		shift;;
	*)
		break;;
	esac
done

# plantuml is needed, check if already downloaded, else download if suggested
# by an argument
test -f "../dist/plantuml.jar" || {
	echo 'dist/plantuml.jar not found. '
	if [ $download_plantuml -eq 1 ]
	then
		echo 'Downloading plantuml:'
		curl -Li $PLANTUML_URL -o ../dist/plantuml.jar
	else
		echo 'plantuml can be downloaded from:'
		echo 'https://sourceforge.net/projects/plantuml/files/plantuml.jar/download'
		echo 'To download automatically pass -d argument to the script'
		exit 1
	fi
}

# Check plantuml works as expected
java -jar ../dist/plantuml.jar -testdot > /dev/null || {
	echo 'error: plantuml installation check failed'
	exit 1
}

# Generate PlantUML docs. This command looks for plantuml template code embedded
# in files at /src/docs/ with doc or dox extension.
echo 'Generating plantuml images .. '
mkdir -p ../docs/images/plantuml_gen_img
java  -Djava.awt.headless=true -jar ../dist/plantuml.jar -o ../docs/images/plantuml_gen_img "../src/docs/**.(doc|dox)" &&
    echo 'Done'