Doc generator now makes 'bpy.context' api reference.
[blender-staging.git] / doc / python_api / sphinx_doc_gen.sh
1 #!/bin/sh
2 # run from the blender source dir
3 #   bash source/blender/python/doc/sphinx_doc_gen.sh
4 # ssh upload means you need an account on the server
5
6 BLENDER="./blender.bin"
7 SSH_USER="ideasman42"
8 SSH_HOST=$SSH_USER"@emo.blender.org"
9 SSH_UPLOAD="/data/www/vhosts/www.blender.org/documentation" # blender_python_api_VERSION, added after
10
11 # 'Blender 2.53 (sub 1) Build' --> '2_53_1' as a shell script.
12 # "_".join(str(v) for v in bpy.app.version)
13 # custom blender vars
14 blender_srcdir=$(dirname $0)/../../
15 blender_version=$(grep BLENDER_VERSION $blender_srcdir/source/blender/blenkernel/BKE_blender.h | tr -dc 0-9)
16 blender_subversion=$(grep BLENDER_SUBVERSION $blender_srcdir/source/blender/blenkernel/BKE_blender.h | tr -dc 0-9)
17 BLENDER_VERSION=$(expr $blender_version / 100)_$(expr $blender_version % 100)_$blender_subversion
18
19 SSH_UPLOAD_FULL=$SSH_UPLOAD/"blender_python_api_"$BLENDER_VERSION
20
21 SPHINXBASE=doc/python_api/
22
23 # dont delete existing docs, now partial updates are used for quick builds.
24 $BLENDER --background --factory-startup --python $SPHINXBASE/sphinx_doc_gen.py
25
26 # html
27 sphinx-build $SPHINXBASE/sphinx-in $SPHINXBASE/sphinx-out
28 cp $SPHINXBASE/sphinx-out/contents.html $SPHINXBASE/sphinx-out/index.html
29 ssh $SSH_USER@emo.blender.org 'rm -rf '$SSH_UPLOAD_FULL'/*'
30 rsync --progress -avze "ssh -p 22" $SPHINXBASE/sphinx-out/* $SSH_HOST:$SSH_UPLOAD_FULL/
31
32 # symlink the dir to a static URL
33 ssh $SSH_USER@emo.blender.org 'rm '$SSH_UPLOAD'/250PythonDoc && ln -s '$SSH_UPLOAD_FULL' '$SSH_UPLOAD'/250PythonDoc'
34
35 # pdf
36 sphinx-build -b latex $SPHINXBASE/sphinx-in $SPHINXBASE/sphinx-out
37 cd $SPHINXBASE/sphinx-out
38 make
39 cd -
40
41 # rename so local PDF has matching name.
42 mv $SPHINXBASE/sphinx-out/contents.pdf $SPHINXBASE/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf
43 rsync --progress -avze "ssh -p 22" $SPHINXBASE/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf $SSH_HOST:$SSH_UPLOAD_FULL/blender_python_reference_$BLENDER_VERSION.pdf