Skip to content
Snippets Groups Projects
Commit 119a077d authored by Allan Blanchard's avatar Allan Blanchard Committed by Andre Maroneze
Browse files

[release] Prepare version

parent 66d62887
No related branches found
No related tags found
No related merge requests found
#!/bin/sh
#! /bin/bash
##########################################################################
# #
# This file is part of Frama-C. #
......@@ -21,12 +21,76 @@
# #
##########################################################################
next=$1
NEXT=$1
if test -z "$next"; then
if ! test -f VERSION; then
echo "This script must be run from Frama-C root directory"
exit 2
fi
if test -z "$NEXT"; then
echo "Missing argument. Usage is:"
echo "\$ ./bin/update_api_doc.sh <NEXT>"
echo "\$ ./dev/set-version.sh <NN.M>"
echo "See the Release Management Documentation for an example."
else
find src -name '*.ml*' -exec sed -i -e "s/Frama-C+dev/${next}/gI" '{}' ';'
exit 2
fi
NEXT_MAJOR=$(echo "$NEXT" | sed -e s/\\\([0-9]*\\\).[0-9]*.*/\\1/)
NEXT_MINOR=$(echo "$NEXT" | sed -e s/[0-9]*.\\\([0-9]*\\\).*/\\1/)
NEXT_CODENAME=$(grep "$NEXT_MAJOR " ./doc/release/periodic-elements.txt | cut -d " " -f2)
CURRENT=$(cat VERSION)
CURRENT_MAJOR=$(echo "$CURRENT" | sed -e s/\\\([0-9]*\\\).[0-9]*.*/\\1/)
CURRENT_MINOR=$(echo "$CURRENT" | sed -e s/[0-9]*.\\\([0-9]*\\\).*/\\1/)
CURRENT_CODENAME=$(grep "$CURRENT_MAJOR " ./doc/release/periodic-elements.txt | cut -d " " -f2)
echo "NEXT VERSION is:"
echo "- MAJOR: $NEXT_MAJOR"
echo "- MINOR: $NEXT_MINOR"
echo "- CODENAME: $NEXT_CODENAME"
echo ""
echo "Continue? [y/N] "
read CHOICE
case "${CHOICE}" in
"Y"|"y") ;;
*) exit 1 ;;
esac
# Version
echo "$NEXT" > VERSION
echo "$NEXT_CODENAME" > VERSION_CODENAME
# Opam file
sed -i "s/^version: .*/version: \"$NEXT_MAJOR.$NEXT_MINOR\"/g" opam
sed -i "s/\(.*\)$CURRENT_MAJOR.$CURRENT_MINOR-$CURRENT_CODENAME\(.*\)/\1$NEXT_MAJOR.$NEXT_MINOR-$NEXT_CODENAME\2/g" opam
# Changelogs
FC_CL_MSG_FUTURE="Open Source Release <next-release>"
FC_CL_MSG_NEXT="Open Source Release $NEXT_MAJOR.$NEXT_MINOR ($NEXT_CODENAME)"
FC_CL_LIN="###############################################################################"
sed -i -z "s/\($FC_CL_LIN\n$FC_CL_MSG_FUTURE\n\)/\1$FC_CL_LIN\n\n$FC_CL_LIN\n$FC_CL_MSG_NEXT\n/g" Changelog
EA_CL_MSG_FUTURE="Plugin E-ACSL <next-release>"
EA_CL_MSG_NEXT="Plugin E-ACSL $NEXT_MAJOR.$NEXT_MINOR ($NEXT_CODENAME)"
sed -i -z "s/\($FC_CL_LIN\n$EA_CL_MSG_FUTURE\n\)/\1$FC_CL_LIN\n\n$FC_CL_LIN\n$EA_CL_MSG_NEXT\n/g" src/plugins/e-acsl/doc/Changelog
WP_CL_MSG_FUTURE="Plugin WP <next-release>"
WP_CL_MSG_NEXT="Plugin WP $NEXT_MAJOR.$NEXT_MINOR ($NEXT_CODENAME)"
sed -i -z "s/\($FC_CL_LIN\n$WP_CL_MSG_FUTURE\n\)/\1$FC_CL_LIN\n\n$FC_CL_LIN\n$WP_CL_MSG_NEXT\n/g" src/plugins/wp/Changelog
# API doc
find src -name '*.ml*' -exec sed -i -e "s/Frama-C+dev/${NEXT}-${NEXT_CODENAME}/gI" '{}' ';'
# Manuals changes
sed -i "s/\(^\\\\section\*{Frama-C+dev}\)/%\1\n\n\\\\section\*{$NEXT_MAJOR.$NEXT_MINOR ($NEXT_CODENAME)}/g" \
doc/userman/user-changes.tex
sed -i "s/\(^\\\\section\*{Frama-C+dev}\)/%\1\n\n\\\\section\*{$NEXT_MAJOR.$NEXT_MINOR ($NEXT_CODENAME)}/g" \
doc/developer/changes.tex
sed -i "s/\(^\\\\section\*{E-ACSL \\\\eacslpluginversion \\\\eacslplugincodename}\)/%\1\n\n\\\\section\*{E-ACSL $NEXT_MAJOR.$NEXT_MINOR $NEXT_CODENAME}/g" \
src/plugins/e-acsl/doc/userman/changes.tex
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment