diff options
author | chriseth <c@ethdev.com> | 2016-08-05 23:56:42 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2016-08-10 20:46:59 +0800 |
commit | 7aa344a5e83de7214b1201647e665bc493c96cdb (patch) | |
tree | 3205ea7e733d47a62f57eb3820a437cb0f05ea08 /scripts | |
parent | cacc3b6bca65b93bb9315bd1b9e42bebec6ed58b (diff) | |
download | dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar.gz dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar.bz2 dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar.lz dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar.xz dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.tar.zst dexon-solidity-7aa344a5e83de7214b1201647e665bc493c96cdb.zip |
PPA release script, still work in progress.
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/release_ppa.sh | 212 |
1 files changed, 212 insertions, 0 deletions
diff --git a/scripts/release_ppa.sh b/scripts/release_ppa.sh new file mode 100755 index 00000000..e29443b9 --- /dev/null +++ b/scripts/release_ppa.sh @@ -0,0 +1,212 @@ +#!/usr/bin/env bash +############################################################################## +## This is used to package .deb packages and upload them to the launchpad +## ppa servers for building. +## +## The gnupg key for "build@ethdev.com" has to be present in order to sign +## the package. +## +## It will clone the Solidity git from github, determine the version, +## create a source archive and push it to the ubuntu ppa servers. +## +## A version, tag or commit hash can be given as argument. +## +############################################################################## + +set -ev + +keyid=703F83D0 +email=builds@ethereum.org +packagename=solc + +# TODO determine whether to use dev or not +pparepo=ethereum/ethereum-dev +ppafilesurl=https://launchpad.net/~ethereum/+archive/ubuntu/ethereum-dev/+files + +for distribution in trusty vivid wily xenial yakkety +do +cd /tmp/ +mkdir $distribution +cd $distribution + +# Fetch source +git clone --recursive https://github.com/ethereum/solidity.git -b $1 +mv solidity solc + +# Determine version +cd solc +version=`grep -oP "PROJECT_VERSION \"?\K[0-9.]+(?=\")"? CMakeLists.txt` +commithash=`git rev-parse --short HEAD` +committimestamp=`git show --format=%ci HEAD | head -n 1` +commitdate=`git show --format=%ci HEAD | head -n 1 | cut - -b1-10` + +# TODO determine if we are on a "release" (tagged commit?) and push to non-dev in that case +# TODO store the commit hash in a file so that the build info mechanism can pick it up even without git + +debversion="$version-nightly-$commitdate-ffi-$commithash" +tar --mtime "$committimestamp" --exclude .git -czf ../${packagename}_${debversion}.orig.tar.gz . + +# Create debian package information + +case $distribution in + trusty) + jsoncpplib=libjsoncppv0 + ;; + vivid) + jsoncpplib=libjsoncppv0 + ;; + wily) + jsoncpplib=libjsoncppv0v5 + ;; + *) + jsoncpplib=libjsoncpp1 + ;; +esac + +mkdir debian +echo 9 > debian/compat +cat <<EOF > debian/control +Source: solc +Section: science +Priority: extra +Maintainer: Christian (Buildserver key) <builds@ethereum.org> +Build-Depends: debhelper (>= 9.0.0), + dh_sphinxdoc, + libcryptopp-dev, + cmake, + g++-4.8, + git, + libgmp-dev, + libboost-all-dev, + automake, + libtool, + scons, + libjsoncpp-dev +Standards-Version: 3.9.5 +Homepage: https://ethereum.org +Vcs-Git: git://github.com/ethereum/solidity.git +Vcs-Browser: https://github.com/ethereum/solidity + +Package: solc +Architecture: any-i386 any-amd64 +Multi-Arch: same +Depends: \${shlibs:Depends}, \${misc:Depends}, $jsoncpplib +Description: Solidity compiler. + The commandline interface to the Solidity smart contract compiler. +EOF +cat <<EOF > debian/rules +#!/usr/bin/make -f +# -*- makefile -*- +# Sample debian/rules that uses debhelper. +# +# This file was originally written by Joey Hess and Craig Small. +# As a special exception, when this file is copied by dh-make into a +# dh-make output file, you may use that output file without restriction. +# This special exception was added by Craig Small in version 0.37 of dh-make. +# +# Modified to make a template file for a multi-binary package with separated +# build-arch and build-indep targets by Bill Allombert 2001 + +# Uncomment this to turn on verbose mode. +export DH_VERBOSE=1 + +# This has to be exported to make some magic below work. +export DH_OPTIONS + + +%: + dh \$@ --buildsystem=cmake --with sphinxdoc + +override_dh_auto_test: + +override_dh_installdocs: + make -C docs html + dh_installdocs docs/_build/html + +override_dh_shlibdeps: + dh_shlibdeps --dpkg-shlibdeps-params=--ignore-missing-info +EOF +cat <<EOF > debian/copyright +Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ +Upstream-Name: solc +Source: https://github.com/ethereum/solidity + +Files: * +Copyright: 2014-2016 Ethereum +License: GPL-3.0+ + +Files: debian/* +Copyright: 2016 Ethereum +License: GPL-3.0+ + +License: GPL-3.0+ + This program 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. + . + This package 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 this program. If not, see <http://www.gnu.org/licenses/>. + . + On Debian systems, the complete text of the GNU General + Public License version 3 can be found in "/usr/share/common-licenses/GPL-3". +EOF +cat <<EOF > debian/changelog +solc (0.0.1-0ubuntu1) saucy; urgency=low + + * Initial release. + + -- Christian <build@ethereum.org> Mon, 03 Feb 2016 14:50:20 +0000 +EOF +echo docs > debian/docs +mkdir debian/source +echo "3.0 (quilt)" > debian/source/format +chmod +x debian/rules + +versionsuffix=0ubuntu4~${distribution} +# bump version / add entry to changelog +EMAIL="$email" dch -v 1:${debversion}-${versionsuffix} "git build of ${commithash}" + + +# build source package +# If packages is rejected because original source is already present, add +# -sd to remove it from the .changes file +debuild -S -sa -us -uc + +# prepare .changes file for Launchpad +sed -i -e s/UNRELEASED/${distribution}/ -e s/urgency=medium/urgency=low/ ../*.changes + +# check if ubuntu already has the source tarball +( +cd .. +orig=${packagename}_${debversion}.orig.tar.gz +orig_size=$(ls -l $orig | cut -d ' ' -f 5) +orig_sha1=$(sha1sum $orig | cut -d ' ' -f 1) +orig_sha256=$(sha256sum $orig | cut -d ' ' -f 1) +orig_md5=$(md5sum $orig | cut -d ' ' -f 1) + +if wget --quiet -O $orig-tmp "$ppafilesurl/$orig" +then + echo "[WARN] Original tarball found in Ubuntu archive, using it instead" + mv $orig-tmp $orig + new_size=$(ls -l *.orig.tar.gz | cut -d ' ' -f 5) + new_sha1=$(sha1sum $orig | cut -d ' ' -f 1) + new_sha256=$(sha256sum $orig | cut -d ' ' -f 1) + new_md5=$(md5sum $orig | cut -d ' ' -f 1) + sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.dsc + sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.changes +fi +) + +# sign the package +debsign --re-sign -k ${keyid} ../${packagename}_${debversion}-${versionsuffix}_source.changes + +# upload +dput ppa:${pparepo} ../${packagename}_${debversion}-${versionsuffix}_source.changes + +done |