build: also build a "source-only" linux-packager-friendly tarball
We now distribute two tarballs, a "normal" one (the default, recommended for users), and a new strictly source-only one (for Linux distro packagers). The normal tarball, in addition to including everything from the source-only one, also includes: - compiled (`.mo`) locale files (in addition to source `.po` locale files) - compiled (`_pb2.py`) protobuf files (in addition to source `.proto` files) - the `packages/` folder containing source-only pure-python runtime dependencies merges https://github.com/spesmilo/electrum/pull/7594 with follow-ups
This commit is contained in:
@@ -88,6 +88,14 @@ else
|
||||
./contrib/build-linux/sdist/build.sh
|
||||
fi
|
||||
|
||||
# create source-only tarball
|
||||
srctarball="Electrum-sourceonly-$VERSION.tar.gz"
|
||||
if test -f "dist/$srctarball"; then
|
||||
info "file exists: $srctarball"
|
||||
else
|
||||
OMIT_UNCLEAN_FILES=1 ./contrib/build-linux/sdist/build.sh
|
||||
fi
|
||||
|
||||
# appimage
|
||||
appimage="electrum-$REV-x86_64.AppImage"
|
||||
if test -f "dist/$appimage"; then
|
||||
@@ -186,15 +194,17 @@ if [ -z "$RELEASEMANAGER" ] ; then
|
||||
bye
|
||||
!
|
||||
# check we have each binary
|
||||
test -f "$tarball" || fail "tarball not found among sftp downloads"
|
||||
test -f "$appimage" || fail "appimage not found among sftp downloads"
|
||||
test -f "$win1" || fail "win1 not found among sftp downloads"
|
||||
test -f "$win2" || fail "win2 not found among sftp downloads"
|
||||
test -f "$win3" || fail "win3 not found among sftp downloads"
|
||||
test -f "$apk1" || fail "apk1 not found among sftp downloads"
|
||||
test -f "$apk2" || fail "apk2 not found among sftp downloads"
|
||||
test -f "$dmg" || fail "dmg not found among sftp downloads"
|
||||
test -f "$tarball" || fail "tarball not found among sftp downloads"
|
||||
test -f "$srctarball" || fail "srctarball not found among sftp downloads"
|
||||
test -f "$appimage" || fail "appimage not found among sftp downloads"
|
||||
test -f "$win1" || fail "win1 not found among sftp downloads"
|
||||
test -f "$win2" || fail "win2 not found among sftp downloads"
|
||||
test -f "$win3" || fail "win3 not found among sftp downloads"
|
||||
test -f "$apk1" || fail "apk1 not found among sftp downloads"
|
||||
test -f "$apk2" || fail "apk2 not found among sftp downloads"
|
||||
test -f "$dmg" || fail "dmg not found among sftp downloads"
|
||||
test -f "$PROJECT_ROOT/dist/$tarball" || fail "tarball not found among built files"
|
||||
test -f "$PROJECT_ROOT/dist/$srctarball" || fail "srctarball not found among built files"
|
||||
test -f "$PROJECT_ROOT/dist/$appimage" || fail "appimage not found among built files"
|
||||
test -f "$CONTRIB/build-wine/dist/$win1" || fail "win1 not found among built files"
|
||||
test -f "$CONTRIB/build-wine/dist/$win2" || fail "win2 not found among built files"
|
||||
@@ -203,8 +213,9 @@ if [ -z "$RELEASEMANAGER" ] ; then
|
||||
test -f "$PROJECT_ROOT/dist/$apk2" || fail "apk2 not found among built files"
|
||||
test -f "$PROJECT_ROOT/dist/$dmg" || fail "dmg not found among built files"
|
||||
# compare downloaded binaries against ones we built
|
||||
cmp --silent "$tarball" "$PROJECT_ROOT/dist/$tarball" || fail "files are different. tarball."
|
||||
cmp --silent "$appimage" "$PROJECT_ROOT/dist/$appimage" || fail "files are different. appimage."
|
||||
cmp --silent "$tarball" "$PROJECT_ROOT/dist/$tarball" || fail "files are different. tarball."
|
||||
cmp --silent "$srctarball" "$PROJECT_ROOT/dist/$srctarball" || fail "files are different. srctarball."
|
||||
cmp --silent "$appimage" "$PROJECT_ROOT/dist/$appimage" || fail "files are different. appimage."
|
||||
rm -rf "$CONTRIB/build-wine/signed/" && mkdir --parents "$CONTRIB/build-wine/signed/"
|
||||
cp -f "$win1" "$win2" "$win3" "$CONTRIB/build-wine/signed/"
|
||||
"$CONTRIB/build-wine/unsign.sh" || fail "files are different. windows."
|
||||
@@ -214,7 +225,7 @@ if [ -z "$RELEASEMANAGER" ] ; then
|
||||
# all files matched. sign them.
|
||||
rm -rf "$PROJECT_ROOT/dist/sigs/"
|
||||
mkdir --parents "$PROJECT_ROOT/dist/sigs/"
|
||||
for fname in "$tarball" "$appimage" "$win1" "$win2" "$win3" "$apk1" "$apk2" "$dmg" ; do
|
||||
for fname in "$tarball" "$srctarball" "$appimage" "$win1" "$win2" "$win3" "$apk1" "$apk2" "$dmg" ; do
|
||||
signame="$fname.$GPGUSER.asc"
|
||||
gpg --sign --armor --detach $PUBKEY --output "$PROJECT_ROOT/dist/sigs/$signame" "$fname"
|
||||
done
|
||||
|
||||
Reference in New Issue
Block a user