Blame doc/ghdeploydoxy.sh

Packit Service 9402ce
#!/bin/bash
Packit Service 9402ce
################################################################################
Packit Service 9402ce
# Notes         :
Packit Service 9402ce
# Preconditions:
Packit Service 9402ce
# - Packages doxygen doxygen-doc doxygen-latex doxygen-gui graphviz
Packit Service 9402ce
#   must be installed.
Packit Service 9402ce
# - Doxygen configuration file must have the destination directory empty and
Packit Service 9402ce
#   source code directory.
Packit Service 9402ce
# - A gh-pages branch should already exist.
Packit Service 9402ce
#
Packit Service 9402ce
# Required global variables:
Packit Service 9402ce
# - DOXYFILE            : The Doxygen configuration file.
Packit Service 9402ce
# - GH_REPO_NAME        : The name of the repository.
Packit Service 9402ce
# - GH_REPO_REF         : The GitHub reference to the repository.
Packit Service 9402ce
# - GH_REPO_TOKEN       : The GitHub application token.
Packit Service 9402ce
#
Packit Service 9402ce
# This script will generate Doxygen documentation and push the documentation to
Packit Service 9402ce
# the gh-pages branch of a repository specified by GH_REPO_REF.
Packit Service 9402ce
# Before this script is used there should already be a gh-pages branch in the
Packit Service 9402ce
# repository.
Packit Service 9402ce
#
Packit Service 9402ce
################################################################################
Packit Service 9402ce
Packit Service 9402ce
################################################################################
Packit Service 9402ce
##### Setup this script and get the current gh-pages branch.               #####
Packit Service 9402ce
echo 'Setting up the script...'
Packit Service 9402ce
# Exit with nonzero exit code if anything fails
Packit Service 9402ce
set -e
Packit Service 9402ce
Packit Service 9402ce
GH_REPO_NAME=
Packit Service 9402ce
GH_REPO_REF=
Packit Service 9402ce
GH_REPO_TOKEN=
Packit Service 9402ce
Packit Service 9402ce
usage() { echo "Usage: `basename $0` options (-n value) (-r value) (-t value)" 1>&2; exit 1; }
Packit Service 9402ce
Packit Service 9402ce
if ( ! getopts ":n:r:t:" opt); then
Packit Service 9402ce
      usage
Packit Service 9402ce
fi
Packit Service 9402ce
Packit Service 9402ce
while getopts :n:r:t: opt; do
Packit Service 9402ce
  case $opt in
Packit Service 9402ce
  n)
Packit Service 9402ce
      GH_REPO_NAME=$OPTARG
Packit Service 9402ce
      ;;
Packit Service 9402ce
  r)
Packit Service 9402ce
      GH_REPO_REF=$OPTARG
Packit Service 9402ce
      ;;
Packit Service 9402ce
  t)
Packit Service 9402ce
      GH_REPO_TOKEN=$OPTARG
Packit Service 9402ce
      ;;
Packit Service 9402ce
  *)
Packit Service 9402ce
      usage
Packit Service 9402ce
      ;;
Packit Service 9402ce
  esac
Packit Service 9402ce
done
Packit Service 9402ce
Packit Service 9402ce
shift $((OPTIND - 1))
Packit Service 9402ce
Packit Service 9402ce
[ -n "$GH_REPO_NAME" ] || {
Packit Service 9402ce
    echo "ERROR: -n GH_REPO_NAME is not defined" >/dev/stderr
Packit Service 9402ce
    exit 1
Packit Service 9402ce
}
Packit Service 9402ce
Packit Service 9402ce
[ -n "$GH_REPO_REF" ] || {
Packit Service 9402ce
    echo "ERROR: -r GH_REPO_REF is not defined" >/dev/stderr
Packit Service 9402ce
    exit 1
Packit Service 9402ce
}
Packit Service 9402ce
Packit Service 9402ce
[ -n "$GH_REPO_TOKEN" ] || {
Packit Service 9402ce
    echo "ERROR: -t GH_REPO_TOKEN is not defined" >/dev/stderr
Packit Service 9402ce
    exit 1
Packit Service 9402ce
}
Packit Service 9402ce
Packit Service 9402ce
################################################################################
Packit Service 9402ce
##### Upload the documentation to the gh-pages branch of the repository.   #####
Packit Service 9402ce
# Only upload if Doxygen successfully created the documentation.
Packit Service 9402ce
# Check this by verifying that the html directory and the file html/index.html
Packit Service 9402ce
# both exist. This is a good indication that Doxygen did it's work.
Packit Service 9402ce
if [ -d "html-out" ] && [ -f "html-out/index.html" ]; then
Packit Service 9402ce
Packit Service 9402ce
    # Create a clean working directory for this script.
Packit Service 9402ce
    mkdir code_docs
Packit Service 9402ce
    cd code_docs
Packit Service 9402ce
Packit Service 9402ce
    # Get the current gh-pages branch
Packit Service 9402ce
    git clone -b gh-pages https://git@$GH_REPO_REF
Packit Service 9402ce
    cd $GH_REPO_NAME
Packit Service 9402ce
Packit Service 9402ce
    ##### Configure git.
Packit Service 9402ce
    # Set the push default to simple i.e. push only the current branch.
Packit Service 9402ce
    git config --global push.default simple
Packit Service 9402ce
Packit Service 9402ce
    # Remove everything currently in the gh-pages branch.
Packit Service 9402ce
    # GitHub is smart enough to know which files have changed and which files have
Packit Service 9402ce
    # stayed the same and will only update the changed files. So the gh-pages branch
Packit Service 9402ce
    # can be safely cleaned, and it is sure that everything pushed later is the new
Packit Service 9402ce
    # documentation.
Packit Service 9402ce
    CURRENTCOMMIT=`git rev-parse HEAD`
Packit Service 9402ce
    git reset --hard `git rev-list HEAD | tail -n 1` # Reset working tree to initial commit
Packit Service 9402ce
    git reset --soft $CURRENTCOMMIT # Move HEAD back to where it was
Packit Service 9402ce
Packit Service 9402ce
    # Move doxy files into local gh-pages branch folder
Packit Service 9402ce
    mv ../../html-out/* .
Packit Service 9402ce
Packit Service 9402ce
    # Need to create a .nojekyll file to allow filenames starting with an underscore
Packit Service 9402ce
    # to be seen on the gh-pages site. Therefore creating an empty .nojekyll file.
Packit Service 9402ce
    # Presumably this is only needed when the SHORT_NAMES option in Doxygen is set
Packit Service 9402ce
    # to NO, which it is by default. So creating the file just in case.
Packit Service 9402ce
    echo "" > .nojekyll
Packit Service 9402ce
Packit Service 9402ce
    echo 'Uploading documentation to the gh-pages branch...'
Packit Service 9402ce
    # Add everything in this directory (the Doxygen code documentation) to the
Packit Service 9402ce
    # gh-pages branch.
Packit Service 9402ce
    # GitHub is smart enough to know which files have changed and which files have
Packit Service 9402ce
    # stayed the same and will only update the changed files.
Packit Service 9402ce
    git add --all
Packit Service 9402ce
Packit Service 9402ce
    # Commit the added files with a title and description containing the Travis CI
Packit Service 9402ce
    # build number and the GitHub commit reference that issued this build.
Packit Service 9402ce
    git commit -m "Deploy code docs to GitHub Pages"
Packit Service 9402ce
Packit Service 9402ce
    # Force push to the remote gh-pages branch.
Packit Service 9402ce
    # The ouput is redirected to /dev/null to hide any sensitive credential data
Packit Service 9402ce
    # that might otherwise be exposed.
Packit Service 9402ce
    git push --force "https://${GH_REPO_TOKEN}@${GH_REPO_REF}" > /dev/null 2>&1
Packit Service 9402ce
else
Packit Service 9402ce
    echo '' >&2
Packit Service 9402ce
    echo 'Warning: No documentation (html) files have been found!' >&2
Packit Service 9402ce
    echo 'Warning: Not going to push the documentation to GitHub!' >&2
Packit Service 9402ce
    exit 1
Packit Service 9402ce
fi