Unify build-helper scripts
This commit is contained in:
parent
2f93320627
commit
d242f1e758
3 changed files with 63 additions and 454 deletions
|
@ -1,6 +1,7 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
|
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
|
# 2016-2019 Darko Poljak (darko.poljak at gmail.com)
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -18,10 +19,36 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# This file contains the heavy lifting found usually in the Makefile
|
# This file contains the heavy lifting found usually in the Makefile.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# vars for make
|
||||||
|
helper=$0
|
||||||
|
|
||||||
basedir=${0%/*}/../
|
basedir=${0%/*}/../
|
||||||
|
# run_as is used to check how the script is called (by $0 value)
|
||||||
|
# currently supported sufixes for $0 are:
|
||||||
|
# .darko - run as darko
|
||||||
|
basename=${0##*/}
|
||||||
|
run_as=${basename#*.}
|
||||||
|
|
||||||
|
to_a=cdist-configuration-management
|
||||||
|
to_d=googlegroups.com
|
||||||
|
case "$run_as" in
|
||||||
|
darko)
|
||||||
|
from_a=darko.poljak
|
||||||
|
from_d=gmail.com
|
||||||
|
ml_name="Darko Poljak"
|
||||||
|
ml_sig_name="Darko"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
from_a=nico.schottelius
|
||||||
|
from_d=ungleich.ch
|
||||||
|
ml_name="Nico Schottelius"
|
||||||
|
ml_sig_name="Nico"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
# Change to checkout directory
|
# Change to checkout directory
|
||||||
cd "$basedir"
|
cd "$basedir"
|
||||||
|
|
||||||
|
@ -30,6 +57,12 @@ version=$(git describe)
|
||||||
option=$1; shift
|
option=$1; shift
|
||||||
|
|
||||||
case "$option" in
|
case "$option" in
|
||||||
|
print-make-vars)
|
||||||
|
printf "helper: ${helper}\n"
|
||||||
|
;;
|
||||||
|
print-runas)
|
||||||
|
printf "run_as: $run_as\n"
|
||||||
|
;;
|
||||||
changelog-changes)
|
changelog-changes)
|
||||||
if [ "$#" -eq 1 ]; then
|
if [ "$#" -eq 1 ]; then
|
||||||
start=$1
|
start=$1
|
||||||
|
@ -84,19 +117,14 @@ case "$option" in
|
||||||
|
|
||||||
version=$1; shift
|
version=$1; shift
|
||||||
|
|
||||||
to_a=cdist
|
|
||||||
to_d=l.schottelius.org
|
|
||||||
to=${to_a}@${to_d}
|
to=${to_a}@${to_d}
|
||||||
|
|
||||||
from_a=nico-cdist
|
|
||||||
from_d=schottelius.org
|
|
||||||
from=${from_a}@${from_d}
|
from=${from_a}@${from_d}
|
||||||
|
|
||||||
(
|
(
|
||||||
cat << eof
|
cat << eof
|
||||||
From: Nico -telmich- Schottelius <$from>
|
From: ${ml_name} <$from>
|
||||||
To: cdist mailing list <$to>
|
To: cdist mailing list <$to>
|
||||||
Subject: cdist $version released
|
Subject: cdist $version has been released
|
||||||
|
|
||||||
Hello .*,
|
Hello .*,
|
||||||
|
|
||||||
|
@ -108,15 +136,18 @@ eof
|
||||||
cat << eof
|
cat << eof
|
||||||
|
|
||||||
Cheers,
|
Cheers,
|
||||||
|
${ml_sig_name}
|
||||||
Nico
|
|
||||||
|
|
||||||
--
|
--
|
||||||
Automatisation at its best level. With cdist.
|
Automatisation at its best level. With cdist.
|
||||||
eof
|
eof
|
||||||
) | /usr/sbin/sendmail -f "$from" "$to"
|
) > mailinglist.tmp
|
||||||
;;
|
|
||||||
|
|
||||||
|
if [ "$run_as" = "build-helper" ]
|
||||||
|
then
|
||||||
|
/usr/sbin/sendmail -f "$from" "$to" < mailinglist.tmp && rm -f mailinglist.tmp
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
release-git-tag)
|
release-git-tag)
|
||||||
target_version=$($0 changelog-version)
|
target_version=$($0 changelog-version)
|
||||||
|
@ -213,7 +244,6 @@ eof
|
||||||
"https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
|
"https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
|
||||||
|| exit 1
|
|| exit 1
|
||||||
|
|
||||||
|
|
||||||
# remove generated files (archive and asc)
|
# remove generated files (archive and asc)
|
||||||
if [ $# -eq 2 ]
|
if [ $# -eq 2 ]
|
||||||
then
|
then
|
||||||
|
@ -276,8 +306,8 @@ eof
|
||||||
|
|
||||||
# Generate documentation (man and html)
|
# Generate documentation (man and html)
|
||||||
# First, clean old generated docs
|
# First, clean old generated docs
|
||||||
make docs-clean
|
make helper=${helper} docs-clean
|
||||||
make docs
|
make helper=${helper} docs
|
||||||
|
|
||||||
#############################################################
|
#############################################################
|
||||||
# Everything green, let's do the release
|
# Everything green, let's do the release
|
||||||
|
@ -292,16 +322,27 @@ eof
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Publish git changes
|
# Publish git changes
|
||||||
make pub
|
if [ "$run_as" = "build-helper" ]
|
||||||
|
then
|
||||||
|
make helper=${helper} pub
|
||||||
|
else
|
||||||
|
# if we are not Nico :) then just push, no mirror
|
||||||
|
git push
|
||||||
|
# push also new branch and set up tracking
|
||||||
|
git push -u origin "${target_branch}"
|
||||||
|
fi
|
||||||
|
|
||||||
# Ensure that pypi release has the right version
|
# Ensure that pypi release has the right version
|
||||||
"$0" version
|
"$0" version
|
||||||
|
|
||||||
# Create and publish package for pypi
|
# Create and publish package for pypi
|
||||||
make pypi-release
|
make helper=${helper} pypi-release
|
||||||
|
|
||||||
|
if [ "$run_as" = "build-helper" ]
|
||||||
|
then
|
||||||
# Archlinux release is based on pypi
|
# Archlinux release is based on pypi
|
||||||
make archlinux-release
|
make helper=${helper} archlinux-release
|
||||||
|
fi
|
||||||
|
|
||||||
# sign git tag
|
# sign git tag
|
||||||
printf "Enter upstream repository authentication token: "
|
printf "Enter upstream repository authentication token: "
|
||||||
|
@ -309,19 +350,13 @@ eof
|
||||||
"$0" sign-git-release "${target_version}" "${token}"
|
"$0" sign-git-release "${target_version}" "${token}"
|
||||||
|
|
||||||
# Announce change on ML
|
# Announce change on ML
|
||||||
make ml-release
|
make helper=${helper} ml-release
|
||||||
|
|
||||||
cat << eof
|
cat << eof
|
||||||
Manual steps post release:
|
Manual steps post release:
|
||||||
|
|
||||||
- cdist-web
|
- cdist-web
|
||||||
- linkedin
|
|
||||||
- hackernews
|
|
||||||
- reddit
|
|
||||||
- twitter
|
- twitter
|
||||||
|
|
||||||
eof
|
eof
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
test)
|
test)
|
||||||
|
@ -366,7 +401,7 @@ eof
|
||||||
;;
|
;;
|
||||||
|
|
||||||
shellcheck)
|
shellcheck)
|
||||||
make shellcheck
|
make helper=${helper} shellcheck
|
||||||
printf "\\nPlease review shellcheck report.\\n"
|
printf "\\nPlease review shellcheck report.\\n"
|
||||||
while true
|
while true
|
||||||
do
|
do
|
||||||
|
|
1
bin/build-helper.darko
Symbolic link
1
bin/build-helper.darko
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
build-helper
|
|
@ -1,427 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
|
|
||||||
# 2016 Darko Poljak (darko.poljak at gmail.com)
|
|
||||||
#
|
|
||||||
# This file is part of cdist.
|
|
||||||
#
|
|
||||||
# cdist is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# cdist is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# This file contains the heavy lifting found usually in the Makefile
|
|
||||||
#
|
|
||||||
|
|
||||||
# vars for make
|
|
||||||
helper=$0
|
|
||||||
|
|
||||||
basedir=${0%/*}/../
|
|
||||||
# run_as is used to check how the script is called (by $0 value)
|
|
||||||
# currently supported sufixes for $0 are:
|
|
||||||
# .freebsd - run as freebsd
|
|
||||||
basename=${0##*/}
|
|
||||||
run_as=${basename#*.}
|
|
||||||
|
|
||||||
to_a=cdist-configuration-management
|
|
||||||
to_d=googlegroups.com
|
|
||||||
from_a=darko.poljak
|
|
||||||
from_d=gmail.com
|
|
||||||
ml_name="Darko Poljak"
|
|
||||||
ml_sig_name="Darko"
|
|
||||||
|
|
||||||
# Change to checkout directory
|
|
||||||
cd "$basedir"
|
|
||||||
|
|
||||||
version=$(git describe)
|
|
||||||
|
|
||||||
option=$1; shift
|
|
||||||
|
|
||||||
case "$option" in
|
|
||||||
print-make-vars)
|
|
||||||
printf "helper: ${helper}\n"
|
|
||||||
;;
|
|
||||||
print-runas)
|
|
||||||
printf "run_as: $run_as\n"
|
|
||||||
;;
|
|
||||||
changelog-changes)
|
|
||||||
if [ "$#" -eq 1 ]; then
|
|
||||||
start=$1
|
|
||||||
else
|
|
||||||
start="[[:digit:]]"
|
|
||||||
fi
|
|
||||||
|
|
||||||
end="[[:digit:]]"
|
|
||||||
|
|
||||||
awk -F: "BEGIN { start=0 }
|
|
||||||
{
|
|
||||||
if(start == 0) {
|
|
||||||
if (\$0 ~ /^$start/) {
|
|
||||||
start = 1
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (\$0 ~ /^$end/) {
|
|
||||||
exit
|
|
||||||
} else {
|
|
||||||
print \$0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}" "$basedir/docs/changelog"
|
|
||||||
;;
|
|
||||||
|
|
||||||
changelog-version)
|
|
||||||
# get version from changelog
|
|
||||||
grep '^[[:digit:]]' "$basedir/docs/changelog" | head -n1 | sed 's/:.*//'
|
|
||||||
;;
|
|
||||||
|
|
||||||
check-date)
|
|
||||||
# verify date in changelog is today
|
|
||||||
date_today="$(date +%Y-%m-%d)"
|
|
||||||
date_changelog=$(grep '^[[:digit:]]' "$basedir/docs/changelog" | head -n1 | sed 's/.*: //')
|
|
||||||
|
|
||||||
if [ "$date_today" != "$date_changelog" ]; then
|
|
||||||
echo "Date in changelog is not today"
|
|
||||||
echo "Changelog: $date_changelog"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
check-unittest)
|
|
||||||
"$0" test
|
|
||||||
;;
|
|
||||||
|
|
||||||
ml-release)
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
echo "$0 ml-release version" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
version=$1; shift
|
|
||||||
|
|
||||||
to=${to_a}@${to_d}
|
|
||||||
from=${from_a}@${from_d}
|
|
||||||
|
|
||||||
(
|
|
||||||
cat << eof
|
|
||||||
From: ${ml_name} <$from>
|
|
||||||
To: cdist mailing list <$to>
|
|
||||||
Subject: cdist $version has been released
|
|
||||||
|
|
||||||
Hello .*,
|
|
||||||
|
|
||||||
cdist $version has been released with the following changes:
|
|
||||||
|
|
||||||
eof
|
|
||||||
|
|
||||||
"$0" changelog-changes "$version"
|
|
||||||
cat << eof
|
|
||||||
|
|
||||||
Cheers,
|
|
||||||
|
|
||||||
${ml_sig_name}
|
|
||||||
|
|
||||||
--
|
|
||||||
Automatisation at its best level. With cdist.
|
|
||||||
eof
|
|
||||||
) > mailinglist.tmp
|
|
||||||
;;
|
|
||||||
|
|
||||||
release-git-tag)
|
|
||||||
target_version=$($0 changelog-version)
|
|
||||||
if git rev-parse --verify refs/tags/$target_version 2>/dev/null; then
|
|
||||||
echo "Tag for $target_version exists, aborting"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
printf "Enter tag description for ${target_version}: "
|
|
||||||
read tagmessage
|
|
||||||
|
|
||||||
# setup for signed tags:
|
|
||||||
# gpg --fulL-gen-key
|
|
||||||
# gpg --list-secret-keys --keyid-format LONG
|
|
||||||
# git config --local user.signingkey <id>
|
|
||||||
# for exporting pub key:
|
|
||||||
# gpg --armor --export <id> > pubkey.asc
|
|
||||||
# gpg --output pubkey.gpg --export <id>
|
|
||||||
# show tag with signature
|
|
||||||
# git show <tag>
|
|
||||||
# verify tag signature
|
|
||||||
# git tag -v <tag>
|
|
||||||
#
|
|
||||||
# gpg verify signature
|
|
||||||
# gpg --verify <asc-file> <file>
|
|
||||||
# gpg --no-default-keyring --keyring <pubkey.gpg> --verify <asc-file> <file>
|
|
||||||
# Ensure gpg-agent is running.
|
|
||||||
export GPG_TTY=$(tty)
|
|
||||||
gpg-agent
|
|
||||||
|
|
||||||
git tag -s "$target_version" -m "$tagmessage"
|
|
||||||
git push --tags
|
|
||||||
;;
|
|
||||||
|
|
||||||
sign-git-release)
|
|
||||||
if [ $# -lt 2 ]
|
|
||||||
then
|
|
||||||
printf "usage: $0 sign-git-release TAG TOKEN [ARCHIVE]\n"
|
|
||||||
printf " if ARCHIVE is not specified then it is created\n"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
tag="$1"
|
|
||||||
if ! git rev-parse -q --verify "${tag}" >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
printf "Tag \"${tag}\" not found.\n"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
token="$2"
|
|
||||||
if [ $# -gt 2 ]
|
|
||||||
then
|
|
||||||
archivename="$3"
|
|
||||||
else
|
|
||||||
archivename="cdist-${tag}.tar"
|
|
||||||
git archive --prefix="cdist-${tag}/" -o "${archivename}" "${tag}" \
|
|
||||||
|| exit 1
|
|
||||||
# make sure target version is generated
|
|
||||||
"$0" target-version
|
|
||||||
tar -x -f "${archivename}" || exit 1
|
|
||||||
cp cdist/version.py "cdist-${tag}/cdist/version.py" || exit 1
|
|
||||||
tar -c -f "${archivename}" "cdist-${tag}/" || exit 1
|
|
||||||
rm -r -f "cdist-${tag}/"
|
|
||||||
gzip "${archivename}" || exit 1
|
|
||||||
archivename="${archivename}.gz"
|
|
||||||
fi
|
|
||||||
gpg --armor --detach-sign "${archivename}" || exit 1
|
|
||||||
|
|
||||||
project="ungleich-public%2Fcdist"
|
|
||||||
sed_cmd='s/^.*"markdown":"\([^"]*\)".*$/\1/'
|
|
||||||
|
|
||||||
# upload archive
|
|
||||||
response_archive=$(curl -f -X POST \
|
|
||||||
--http1.1 \
|
|
||||||
-H "PRIVATE-TOKEN: ${token}" \
|
|
||||||
-F "file=@${archivename}" \
|
|
||||||
"https://code.ungleich.ch/api/v4/projects/${project}/uploads" \
|
|
||||||
| sed "${sed_cmd}") || exit 1
|
|
||||||
|
|
||||||
# upload archive signature
|
|
||||||
response_archive_sig=$(curl -f -X POST \
|
|
||||||
--http1.1 \
|
|
||||||
-H "PRIVATE-TOKEN: ${token}" \
|
|
||||||
-F "file=@${archivename}.asc" \
|
|
||||||
"https://code.ungleich.ch/api/v4/projects/${project}/uploads" \
|
|
||||||
| sed "${sed_cmd}") || exit 1
|
|
||||||
|
|
||||||
# make release
|
|
||||||
changelog=$("$0" changelog-changes "$1" | sed 's/^[[:space:]]*//')
|
|
||||||
release_notes=$(
|
|
||||||
printf "Release %s\n\n%s\n\n%s\n\n**Changelog**\n\n%s\n" \
|
|
||||||
"${tag}" "${response_archive}" "${response_archive_sig}" "${changelog}"
|
|
||||||
)
|
|
||||||
curl -f -X POST \
|
|
||||||
-H "PRIVATE-TOKEN: ${token}" \
|
|
||||||
-F "description=${release_notes}" \
|
|
||||||
"https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
|
|
||||||
|| exit 1
|
|
||||||
|
|
||||||
# remove generated files (archive and asc)
|
|
||||||
if [ $# -eq 2 ]
|
|
||||||
then
|
|
||||||
rm -f "${archivename}"
|
|
||||||
fi
|
|
||||||
rm -f "${archivename}.asc"
|
|
||||||
;;
|
|
||||||
|
|
||||||
release)
|
|
||||||
set -e
|
|
||||||
target_version=$($0 changelog-version)
|
|
||||||
target_branch=$($0 version-branch)
|
|
||||||
|
|
||||||
echo "Beginning release process for $target_version"
|
|
||||||
|
|
||||||
# First check everything is sane
|
|
||||||
"$0" check-date
|
|
||||||
"$0" check-unittest
|
|
||||||
"$0" check-pycodestyle
|
|
||||||
"$0" shellcheck
|
|
||||||
|
|
||||||
# Generate version file to be included in packaging
|
|
||||||
"$0" target-version
|
|
||||||
|
|
||||||
# Ensure the git status is clean, else abort
|
|
||||||
if ! git diff-index --name-only --exit-code HEAD ; then
|
|
||||||
echo "Unclean tree, see files above, aborting"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Ensure we are on the master branch
|
|
||||||
masterbranch=yes
|
|
||||||
if [ "$(git rev-parse --abbrev-ref HEAD)" != "master" ]; then
|
|
||||||
echo "Releases are happening from the master branch, aborting"
|
|
||||||
|
|
||||||
echo "Enter the magic word to release anyway"
|
|
||||||
read magicword
|
|
||||||
|
|
||||||
if [ "$magicword" = "iknowwhatido" ]; then
|
|
||||||
masterbranch=no
|
|
||||||
else
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$masterbranch" = yes ]; then
|
|
||||||
# Ensure version branch exists
|
|
||||||
if ! git rev-parse --verify refs/heads/$target_branch 2>/dev/null; then
|
|
||||||
git branch "$target_branch"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Merge master branch into version branch
|
|
||||||
git checkout "$target_branch"
|
|
||||||
git merge master
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Verify that after the merge everything works
|
|
||||||
"$0" check-date
|
|
||||||
"$0" check-unittest
|
|
||||||
|
|
||||||
# Generate documentation (man and html)
|
|
||||||
# First, clean old generated docs
|
|
||||||
make helper=${helper} docs-clean
|
|
||||||
make helper=${helper} docs
|
|
||||||
|
|
||||||
#############################################################
|
|
||||||
# Everything green, let's do the release
|
|
||||||
|
|
||||||
# Tag the current commit
|
|
||||||
"$0" release-git-tag
|
|
||||||
|
|
||||||
# Also merge back the version branch
|
|
||||||
if [ "$masterbranch" = yes ]; then
|
|
||||||
git checkout master
|
|
||||||
git merge "$target_branch"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Publish git changes
|
|
||||||
case "$run_as" in
|
|
||||||
freebsd)
|
|
||||||
# if we are not Nico :) then just push, no mirror
|
|
||||||
git push
|
|
||||||
# push also new branch and set up tracking
|
|
||||||
git push -u origin "${target_branch}"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
make helper=${helper} pub
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Ensure that pypi release has the right version
|
|
||||||
"$0" version
|
|
||||||
|
|
||||||
# Create and publish package for pypi
|
|
||||||
make helper=${helper} pypi-release
|
|
||||||
|
|
||||||
# sign git tag
|
|
||||||
printf "Enter upstream repository authentication token: "
|
|
||||||
read token
|
|
||||||
"$0" sign-git-release "${target_version}" "${token}"
|
|
||||||
|
|
||||||
# Announce change on ML
|
|
||||||
make helper=${helper} ml-release
|
|
||||||
|
|
||||||
cat << eof
|
|
||||||
Manual steps post release:
|
|
||||||
|
|
||||||
- cdist-web
|
|
||||||
- twitter
|
|
||||||
|
|
||||||
eof
|
|
||||||
;;
|
|
||||||
|
|
||||||
test)
|
|
||||||
export PYTHONPATH="$(pwd -P)"
|
|
||||||
|
|
||||||
if [ $# -lt 1 ]; then
|
|
||||||
python3 -m cdist.test
|
|
||||||
else
|
|
||||||
python3 -m unittest "$@"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
test-remote)
|
|
||||||
export PYTHONPATH="$(pwd -P)"
|
|
||||||
python3 -m cdist.test.exec.remote
|
|
||||||
;;
|
|
||||||
|
|
||||||
pycodestyle|pep8)
|
|
||||||
pycodestyle "${basedir}" "${basedir}/scripts/cdist" | less
|
|
||||||
;;
|
|
||||||
|
|
||||||
check-pycodestyle)
|
|
||||||
"$0" pycodestyle
|
|
||||||
printf "\\nPlease review pycodestyle report.\\n"
|
|
||||||
while true
|
|
||||||
do
|
|
||||||
echo "Continue (yes/no)?"
|
|
||||||
any=
|
|
||||||
read any
|
|
||||||
case "$any" in
|
|
||||||
yes)
|
|
||||||
break
|
|
||||||
;;
|
|
||||||
no)
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Please answer with 'yes' or 'no' explicitly."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
|
|
||||||
shellcheck)
|
|
||||||
make helper=${helper} shellcheck
|
|
||||||
printf "\\nPlease review shellcheck report.\\n"
|
|
||||||
while true
|
|
||||||
do
|
|
||||||
echo "Continue (yes/no)?"
|
|
||||||
any=
|
|
||||||
read any
|
|
||||||
case "$any" in
|
|
||||||
yes)
|
|
||||||
break
|
|
||||||
;;
|
|
||||||
no)
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Please answer with 'yes' or 'no' explicitly."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
|
|
||||||
version-branch)
|
|
||||||
"$0" changelog-version | cut -d. -f '1,2'
|
|
||||||
;;
|
|
||||||
|
|
||||||
version)
|
|
||||||
echo "VERSION = \"$(git describe)\"" > cdist/version.py
|
|
||||||
;;
|
|
||||||
|
|
||||||
target-version)
|
|
||||||
target_version=$($0 changelog-version)
|
|
||||||
echo "VERSION = \"${target_version}\"" > cdist/version.py
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown helper target $@ - aborting"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
Loading…
Reference in a new issue