421ec97276
This was originally supported, however relative links to examples & templates made it fail. Now files in the source tree are copied to the build-dir, with ".." replaced with "__" to avoid having to mirror Blender's source-layout in the Sphinx build-dir. Also skip uploading the built docs when an SSH user-name isn't passed to sphinx_doc_gen.sh instead of aborting (so people w/o SSH access to our servers can use the shell-script).
166 lines
5.8 KiB
Bash
Executable File
166 lines
5.8 KiB
Bash
Executable File
#!/bin/sh
|
|
# run from the blender source dir
|
|
# bash doc/python_api/sphinx_doc_gen.sh
|
|
# ssh upload means you need an account on the server
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Upload vars
|
|
|
|
# disable for testing
|
|
DO_UPLOAD=true
|
|
DO_EXE_BLENDER=true
|
|
DO_OUT_HTML=true
|
|
DO_OUT_HTML_ZIP=true
|
|
DO_OUT_PDF=false
|
|
|
|
if [ -z $BLENDER_BIN ] ; then
|
|
BLENDER_BIN="./blender.bin"
|
|
fi
|
|
|
|
if [ "$1" == "" ] ; then
|
|
echo "Expected a single argument for the username on blender.org, skipping upload step!"
|
|
DO_UPLOAD=false
|
|
else
|
|
SSH_USER=$1
|
|
SSH_HOST=$SSH_USER"@blender.org"
|
|
SSH_UPLOAD="/data/www/vhosts/www.blender.org/api" # blender_python_api_VERSION, added after
|
|
fi
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Blender Version & Info
|
|
|
|
# 'Blender 2.53 (sub 1) Build' --> '2_53_1' as a shell script.
|
|
# "_".join(str(v) for v in bpy.app.version)
|
|
# custom blender vars
|
|
blender_srcdir=$(dirname -- $0)/../..
|
|
blender_version_header="$blender_srcdir/source/blender/blenkernel/BKE_blender_version.h"
|
|
blender_version=$(grep "BLENDER_VERSION\s" "$blender_version_header" | awk '{print $3}')
|
|
blender_version_char=$(grep "BLENDER_VERSION_CHAR\s" "$blender_version_header" | awk '{print $3}')
|
|
blender_version_cycle=$(grep "BLENDER_VERSION_CYCLE\s" "$blender_version_header" | awk '{print $3}')
|
|
blender_subversion=$(grep "BLENDER_SUBVERSION\s" "$blender_version_header" | awk '{print $3}')
|
|
unset blender_version_header
|
|
|
|
if [ "$blender_version_cycle" = "release" ] ; then
|
|
BLENDER_VERSION=$(expr $blender_version / 100)_$(expr $blender_version % 100)$blender_version_char"_release"
|
|
else
|
|
BLENDER_VERSION=$(expr $blender_version / 100)_$(expr $blender_version % 100)_$blender_subversion
|
|
fi
|
|
|
|
SSH_UPLOAD_FULL=$SSH_UPLOAD/"blender_python_api_"$BLENDER_VERSION
|
|
|
|
SPHINXBASE=doc/python_api
|
|
|
|
SPHINX_WORKDIR="$(mktemp --directory --suffix=.sphinx)"
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Generate reStructuredText (blender/python only)
|
|
|
|
if $DO_EXE_BLENDER ; then
|
|
# dont delete existing docs, now partial updates are used for quick builds.
|
|
$BLENDER_BIN \
|
|
--background \
|
|
-noaudio \
|
|
--factory-startup \
|
|
--python-exit-code 1 \
|
|
--python $SPHINXBASE/sphinx_doc_gen.py \
|
|
-- \
|
|
--output=$SPHINX_WORKDIR
|
|
|
|
|
|
if (($? != 0)) ; then
|
|
echo "Generating documentation failed, aborting"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Generate HTML (sphinx)
|
|
|
|
if $DO_OUT_HTML ; then
|
|
# sphinx-build -n -b html $SPHINX_WORKDIR/sphinx-in $SPHINX_WORKDIR/sphinx-out
|
|
|
|
# annoying bug in sphinx makes it very slow unless we do this. should report.
|
|
cd $SPHINX_WORKDIR
|
|
sphinx-build -b html sphinx-in sphinx-out
|
|
|
|
# XXX, saves space on upload and zip, should move HTML outside
|
|
# and zip up there, for now this is OK
|
|
rm -rf sphinx-out/.doctrees
|
|
|
|
# incase we have a zip already
|
|
rm -f blender_python_reference_$BLENDER_VERSION.zip
|
|
|
|
# ------------------------------------------------------------------------
|
|
# ZIP the HTML dir for upload
|
|
|
|
if $DO_OUT_HTML_ZIP ; then
|
|
# lame, temp rename dir
|
|
mv sphinx-out blender_python_reference_$BLENDER_VERSION
|
|
zip -r -9 blender_python_reference_$BLENDER_VERSION.zip blender_python_reference_$BLENDER_VERSION
|
|
mv blender_python_reference_$BLENDER_VERSION sphinx-out
|
|
fi
|
|
|
|
cd -
|
|
fi
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Generate PDF (sphinx/laytex)
|
|
|
|
if $DO_OUT_PDF ; then
|
|
cd $SPHINX_WORKDIR
|
|
sphinx-build -n -b latex $SPHINX_WORKDIR/sphinx-in $SPHINX_WORKDIR/sphinx-out
|
|
make -C $SPHINX_WORKDIR/sphinx-out
|
|
mv $SPHINX_WORKDIR/sphinx-out/contents.pdf \
|
|
$SPHINX_WORKDIR/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf
|
|
fi
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Upload to blender servers, comment this section for testing
|
|
|
|
if $DO_UPLOAD ; then
|
|
|
|
cp $SPHINX_WORKDIR/sphinx-out/contents.html $SPHINX_WORKDIR/sphinx-out/index.html
|
|
ssh $SSH_USER@blender.org 'rm -rf '$SSH_UPLOAD_FULL'/*'
|
|
rsync --progress -ave "ssh -p 22" $SPHINX_WORKDIR/sphinx-out/* $SSH_HOST:$SSH_UPLOAD_FULL/
|
|
|
|
## symlink the dir to a static URL
|
|
#ssh $SSH_USER@blender.org 'rm '$SSH_UPLOAD'/250PythonDoc && ln -s '$SSH_UPLOAD_FULL' '$SSH_UPLOAD'/250PythonDoc'
|
|
if [ "$blender_version_cycle" = "release" ] ; then
|
|
ssh $SSH_USER@blender.org 'rm '$SSH_UPLOAD'/blender_python_api_current && ln -s '$SSH_UPLOAD_FULL' '$SSH_UPLOAD'/blender_python_api_current'
|
|
fi
|
|
|
|
# better redirect
|
|
ssh $SSH_USER@blender.org 'echo "<html><head><title>Redirecting...</title><meta http-equiv=\"REFRESH\" content=\"0;url=../blender_python_api_'$BLENDER_VERSION'/\"></head><body>Redirecting...</body></html>" > '$SSH_UPLOAD'/250PythonDoc/index.html'
|
|
|
|
# redirect for release only so wiki can point here
|
|
if [ "$blender_version_cycle" = "release" ] ; then
|
|
ssh $SSH_USER@blender.org 'echo "<html><head><title>Redirecting...</title><meta http-equiv=\"REFRESH\" content=\"0;url=../blender_python_api_'$BLENDER_VERSION'/\"></head><body>Redirecting...</body></html>" > '$SSH_UPLOAD'/blender_python_api/index.html'
|
|
fi
|
|
|
|
if $DO_OUT_PDF ; then
|
|
# rename so local PDF has matching name.
|
|
rsync --progress -ave "ssh -p 22" \
|
|
$SPHINX_WORKDIR/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf \
|
|
$SSH_HOST:$SSH_UPLOAD_FULL/blender_python_reference_$BLENDER_VERSION.pdf
|
|
fi
|
|
|
|
if $DO_OUT_HTML_ZIP ; then
|
|
rsync --progress -ave "ssh -p 22" \
|
|
$SPHINX_WORKDIR/blender_python_reference_$BLENDER_VERSION.zip \
|
|
$SSH_HOST:$SSH_UPLOAD_FULL/blender_python_reference_$BLENDER_VERSION.zip
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Print some useful text
|
|
|
|
echo ""
|
|
echo "Finished! view the docs from: "
|
|
if $DO_OUT_HTML ; then echo " html:" $SPHINX_WORKDIR/sphinx-out/contents.html ; fi
|
|
if $DO_OUT_PDF ; then echo " pdf:" $SPHINX_WORKDIR/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf ; fi
|