summaryrefslogtreecommitdiff
path: root/admin/build-doc
blob: 81854640edf0a69ab40c322e9827c323f18e8284 (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
#!/bin/sh
set -e
cd "$(dirname "$0")"
cd ..

install -d -m0755 build-doc

if command -v dpkg >/dev/null; then
    for package in python-dev python-pip python-virtualenv doxygen ditaa; do
	if [ "$(dpkg --status -- $package|sed -n 's/^Status: //p')" != "install ok installed" ]; then
            # add a space after old values
	    missing="${missing:+$missing }$package"
	fi
    done
    if [ -n "$missing" ]; then
	echo "$0: missing required packages, please install them:" 1>&2
	echo "sudo apt-get install $missing"
	exit 1
    fi
else
    for command in virtualenv doxygen ditaa; do
	if ! command -v "$command" >/dev/null; then
            # add a space after old values
	    missing="${missing:+$missing }$package"
	fi
    done
    if [ -n "$missing" ]; then
	echo "$0: missing required command, please install them:" 1>&2
	echo "$missing"
	exit 1
    fi
fi

if [ ! -e build-doc/doxygen/xml ]; then
    doxygen
fi

cat src/osd/PG.h src/osd/PG.cc | doc/scripts/gen_state_diagram.py > doc/dev/peering_graph.generated.dot

cd build-doc

[ -z "$vdir" ] && vdir="./virtualenv"

if [ ! -e $vdir ]; then
    virtualenv --no-site-packages $vdir
fi
$vdir/bin/pip install --quiet -r ../admin/doc-requirements.txt

install -d -m0755 \
    output/html \
    output/man
PYTHONPATH=`pwd`/../src/pybind $vdir/bin/sphinx-build -a -b dirhtml -d doctrees ../doc output/html
$vdir/bin/sphinx-build -a -b man -d doctrees ../doc output/man