#! /bin/sh # # RTEMS Tools Project (http://www.rtems.org/) # Copyright 2015,2016,2019 Chris Johns (chrisj@rtems.org) # All rights reserved. # # This file is part of the RTEMS Tools package in 'rtems-tools'. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # 1. Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # 2. Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE # POSSIBILITY OF SUCH DAMAGE. # set -e # # This worker script to build the doco. # # # Defaults. # . ${release_top}/rtems-release-defaults # Common package start. # title="RTEMS Documentation Release builder" . ./rtems-release-package-start # # Only build if sphinx-build is present on the system. # if [ "`command -v sphinx-build`"no = no ]; then if [ ${rtems_docs_required} = yes ]; then echo "error: cannot find sphinx to build documentation" else echo "warning: documentation not built" fi exit 0 fi # # # The workspace pwd # ws_pwd=${PWD} # # Get the documentation, create the tarball and stamp. # echo "git clone ${git_remote} ${git_local}" git clone ${git_remote} ${git_local} cd ${git_local} echo "git fetch origin" git fetch origin # Map the branch name to a specific package and release branch name remote_branch=$(rtems_map_branch ${package} ${version}) echo "git archive --format=tar --prefix=${prefix}/ ${remote_branch}" git archive --format=tar --prefix=${prefix}/ ${remote_branch} | \ ${comp} > ../${prefix}-unstamped.tar.${comp_ext} cd .. # # Stamp the source and package # echo "tar ${comp_tar}xf ../${prefix}-unstamped.tar.${comp_ext}" tar ${comp_tar}xf ${prefix}-unstamped.tar.${comp_ext} cd ${prefix} # # This is a hack until I add support for the VERSION file created below. # echo "] Creating VERSION: ${release}" if [ ${version} -lt 5 ]; then cat wscript | \ sed -e "s/^version[[:space:]].*=.*$/version = '${release}'/g" > wscript.tmp rm -f wscript mv wscript.tmp wscript else echo "[version]" > VERSION echo "revision = ${release}" >> VERSION d=$(date +%e) case $d in 1?) d=${d}th ;; *1) d=${d}st ;; *2) d=${d}nd ;; *3) d=${d}rd ;; *) d=${d}th ;; esac now=$(date +"${d} %B %Y") echo "date = ${now}" >> VERSION fi cd .. echo "tar cf - ${prefix}" tar cf - ${prefix} | ${comp} > ../${prefix}.tar.${comp_ext} echo "] Created: ${release}/${prefix}.tar.${comp_ext}" # # Build the docs. # mkdir install cd ${prefix} ./waf distclean configure --prefix=../install/${prefix} --pdf --singlehtml ./waf build install cd .. # # Package the docs, PDF first. # mkdir ${top}/${release}/${docs} cd install echo "] Creating DOC all rtems-${release}-docs-all.tar.${comp_ext}" tar cf - * | \ ${comp} > ${top}/${release}/${docs}/rtems-${release}-docs-all.tar.${comp_ext} for p in $(find . -name \*.pdf) do manual=$(echo $(basename $p) | sed -e "s/\\..*//") base=$(dirname $p) # # Move the PDF out of the way. # echo "] Creating PDF rtems-${release}-${manual}.pdf" mv $p ${top}/${release}/${docs}/rtems-${release}-${manual}.pdf # # Create the single html manual # echo "] Creating SingleHTML rtems-${release}-${manual}.html.${comp_ext}" mv ${base}/${manual}.html ${base}/rtems-${release}-${manual}.html ${comp} ${base}/rtems-${release}-${manual}.html mv ${base}/rtems-${release}-${manual}.html.${comp_ext} ${top}/${release}/${docs}/. # # Tar the multi-page html and install. # echo "] Creating HTML rtems-${release}-${manual}-html.tar.${comp_ext}" tar cf - ${base}/${manual} | \ ${comp} > ${top}/${release}/${docs}/rtems-${release}-${manual}-html.tar.${comp_ext} done cd .. # # Comman package end. # . ${top}/rtems-release-package-end cd ${release}/${docs} # # If doxygen information has been generate move it into the docs. # for p in ../rtems-${release}-doxygen-html.tar.${comp_ext} do if [ -e ${p} ]; then mv ${p} . fi done # # Provide the documentation and doxygen available online in the release # mkdir html cd html tar Jxf ../rtems-${release}-docs-all.tar.${comp_ext} mv rtems-docs-${release}/* . rm -rf rtems-docs-${release} tar Jxf ../rtems-${release}-doxygen-html.tar.${comp_ext} mv rtems-doxygen-${release} doxygen cd .. rm -f ${checksum}sum.txt for f in $(ls -1) do if [ ! -d ${f} ]; then csum=$(${checksum} -q ${f}) echo "${csum} ${f}" >> ${checksum}sum.txt fi done cd .. echo "] Created: ${release}/${docs}/${checksum}sum.txt" echo "] Created: ${release}/${docs}" exit 0