#! /bin/sh # # RTEMS Tools Project (http://www.rtems.org/) # Copyright 2015,2016,2019,2020 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 is the top level RTEMS release script. Supply the version and and the # release. # # # Global release top path. # export release_top=$(realpath $(dirname $0)) cd ${release_top} # # Defaults. # . ${release_top}/rtems-release-defaults # # Usage for this tool. # usage() { echo "Usage: $0 [-u RELEASE-URL] version revision" 1>&2 echo " where:" 1>&2 echo " version : The version of RTEMS, eg 5" 1>&2 echo " revision : The revision, eg 2 or 2-myrev" 1>&2 echo " -u [RELEASE-URL] : The primary download path the RSB uses (for testing)." 1>&2 exit 1 } # # Option defaults # release_url=${rtems_release_url} # # Manage the command line. # while getopts ":u:" opt; do case "${opt}" in u) release_url=${OPTARG} ;; *) usage ;; esac done shift $((OPTIND-1)) if [ $# -ne 2 ]; then echo "error: 2 arguments must be supplied, version and revision. See -h for help" exit 1 fi version=$1 revision=$2 . ${release_top}/rtems-release-package-lists . ${release_top}/rtems-release-version echo "RTEMS Release, v${release}" # # We need pandoc so generate an error early is not available. # if [ ! $(command -v pandoc) ]; then echo "error: pandoc not found, please install" >&2 exit 1 fi # # Does the release provide release notes? # if [ -f rtems-notes-${version}.md ]; then rtems_readme_release_notes=rtems-notes-${version}.md fi # # This call lets us have smaller lines in this script. # build() { echo "] Package: $1" ./rtems-release-package $* } # # Clean the release directory away. # if [ -e ${release} ]; then echo "] Removing existing release ${release}" rm -rf ${release} mkdir ${release} fi # # Package the RSB, must be before the kernel. The kernel worker script uses the # RSB to create autoconf and automake so it can bootstrap the kernel. # build rtems-source-builder ${version} ${revision} ${release_url} build rtems-tools ${version} ${revision} ${release_url} build rtems ${version} ${revision} ${release_url} rtems-release-kernel if [ ${rtems_libbsd} = yes ]; then build rtems-libbsd ${version} ${revision} ${release_url} fi build rtems-source-builder ${version} ${revision} ${release_url} rtems-release-rsb-version if [ ${rtems_examples} = yes ]; then if [ ${version} -lt 5 ]; then build examples-v2 ${version} ${revision} ${release_url} # Hack around the repo naming. mv ${release}/examples-v2-${release}.tar.${comp_ext} \ ${release}/rtems-examples-v2-${release}.tar.${comp_ext} else build rtems-examples ${version} ${revision} ${release_url} fi fi # # Documentation. # if [ ${rtems_docs} = yes ]; then ./rtems-release-docs rtems-docs ${version} ${revision} ${release_url} fi # # Release notes. # if [ ${rtems_release_notes} = yes ]; then ./rtems-release-notes rtems-release-notes ${version} ${revision} ${release_url} fi # # The sources is always last. # echo "] Collect tools sources" ./rtems-release-sources ${version} ${revision} ${release_url} # # Make the contrib directory # mkdir -p ${release}/contrib/rtems-release # # Create the release information # echo "] Create the release information" . ${release_top}/rtems-release-info # # # Copy these release scripts to a contrib directory. # for f in README.txt \ ${rtems_readme} \ rtems-mailer \ rtems-release \ ${rtems_readme_release_notes} \ ${rtems_release_conf} \ rtems-release-cron \ rtems-release-docs \ rtems-release-defaults \ rtems-release-info \ rtems-release-kernel \ rtems-release-notes \ $(find rtems-release-notes-coverpage -type f) \ rtems-release-notes.css \ rtems-release-package \ rtems-release-package-end \ rtems-release-package-start \ rtems-release-path \ rtems-release-rsb-version \ rtems-release-sources \ rtems-release-tag \ rtems-release-version \ rtems-source-packages do if [ ! -e $(dirname ${f}) ]; then mkdir -p $(dirname ${f}) fi cp ${f} ${release}/contrib/rtems-release/ csum=$(${checksum} -q ${f}) echo "${csum} ${f}" >> ${release}/contrib/rtems-release/${checksum}sum.txt done # # Checksum the top level. # cd ${release} 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 .. exit 0