#!/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_cycle=$(grep "BLENDER_VERSION_CYCLE\s" "$blender_version_header" | awk '{print $3}') unset blender_version_header BLENDER_VERSION=$(expr $blender_version / 100)_$(expr $blender_version % 100) 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 # Don't delete existing docs, now partial updates are used for quick builds. # # Disable ASAN error halt since it results in nonzero exit code on any minor issue. ASAN_OPTIONS=halt_on_error=0 \ $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 # in case 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 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 "Redirecting...Redirecting..." > '$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 "Redirecting...Redirecting..." > '$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/index.html ; fi if $DO_OUT_PDF ; then echo " pdf:" $SPHINX_WORKDIR/sphinx-out/blender_python_reference_$BLENDER_VERSION.pdf ; fi