#! /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. # . ./rtems-release-version echo "RTEMS Release, v${rtems_release_version}" # # Global release top path. # export release_top=${PWD} # # Defaults. # . ${release_top}/rtems-release-defaults # # Usage for this tool. # usage() { echo "Usage: $0 [-u RSB-URL] version revision" 1>&2 echo " where:" 1>&2 echo " version : The version of RTEMS, eg 5" 1>&2 echo " revision : The revision, eg 0.0 or 0.0-myrev" 1>&2 echo " -u [RSB-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=${version}.${revision} build() { echo "Package: $1" ./rtems-release-package $* } # # Clean the release directory away. # rm -rf ${release} mkdir ${release} # # 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} # # Create the README.txt. # # The initial stage is done in a few steps where the release files table is cut # out of the input template file and formatted using the column command and # inserted back. # escaped_release_url=$(echo ${release_url} | sed -e 's/\//\\\//g') cat ${rtems_readme} | \ sed -e "s/@RELEASE_URL@/${escaped_release_url}/g" \ -e "s/@RELEASE@/${release}/g" \ -e "s/@VERSION@/${version}/g" \ -e "s/@REVISION@/${revision}/g" \ -e "s/@DATE@/${now}/g" > ${release}/README.1.txt cat ${release}/README.1.txt | \ sed -n '/^@TABLE-START@/,/^@TABLE-END@/p' | \ sed -e 's/@TABLE-START@//g' -e 's/@TABLE-END@//g' | \ column -s '|' -t | \ sed -e 's/$/\\/' > ${release}/README.2.txt cat ${release}/README.1.txt | \ sed -e "/@TABLE-START@/,/@TABLE-END@/c\\ $(cat ${release}/README.2.txt)" > ${release}/README.txt rm -f ${release}/README.1.txt ${release}/README.2.txt if [ -n "${rtems_readme_release_notes}" ]; then echo >> ${release}/README.txt echo "Release Notes" >> ${release}/README.txt echo "~~~~~~~~~~~~~" >> ${release}/README.txt echo >> ${release}/README.txt echo "${rtems_readme_release_notes}" >> ${release}/README.txt fi echo >> ${release}/README.txt echo "RTEMS Architectures and BSPs" >> ${release}/README.txt echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~" >> ${release}/README.txt echo >> ${release}/README.txt cat ARCH-BSP.txt >> ${release}/README.txt rm ARCH-BSP.txt # # Copy these release scripts to a contrib directory. # mkdir -p ${release}/contrib/releasing for f in README.txt \ README.txt.in \ rtems-release \ ${rtems_release_conf} \ rtems-release-docs \ rtems-release-kernel \ rtems-release-package \ rtems-release-package-end \ rtems-release-package-start \ rtems-release-rsb-version \ rtems-release-sources \ rtems-source-packages do cp ${f} ${release}/contrib/releasing/ csum=$(${checksum} -q ${f}) echo "${csum} ${f}" >> ${release}/contrib/releasing/${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