mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
Automate W32 installer building.
* doc/README.W32: Document new installer build procedure. * scripts/autogen.sh: Pass all args to the installer (regression fix). * scripts/conf-w32/README: Remove from repo. * scripts/conf-w32/bzip2-1.diff: Remove from repo. * scripts/mk-w32-dist: Rewrite. * scripts/w32installer.nsi [WITH_PATCHES]: Use constant patch file name.
This commit is contained in:
parent
cfb193a1de
commit
81839d2861
@ -101,21 +101,29 @@ directory with the changes relative to the generic version.
|
||||
|
||||
The source is distributed as a BZIP2 or GZIP compressed tar archive.
|
||||
See the instructions in file README on how to check the integrity of
|
||||
that file. Wir a properly setup build environment, you unpack the
|
||||
that file. With a properly setup build environment, you unpack the
|
||||
tarball change to the created directory and run
|
||||
|
||||
$ ./autogen.sh --build-w32
|
||||
$ make
|
||||
$ cp g10/gpg*.exe /some_windows_drive/
|
||||
|
||||
Building a version with the installer is a bit more complex and
|
||||
basically works by creating a top directory, unpacking in that top
|
||||
directory, switching to the gnupg-1.x.y directory, running
|
||||
"./autogen.sh --build-w32" and "make", switching back to the top
|
||||
directory, running a "mkdir dist-w32; mkdir iconv", copying the
|
||||
required iconv files (iconv.dll, README.iconv, COPYING.LIB) into the
|
||||
iconv directory, running gnupg-1.x.y/scripts/mk-w32-dist and voila,
|
||||
the installer package will be available in the dist-w32 directory.
|
||||
Building a version with the installer requires an install NSIS tool
|
||||
and a directory with the iconv files. The script mk-w32-dist does the
|
||||
entire build from the tarball and checks most prerequisites; example:
|
||||
|
||||
$ scripts/mk-w32-dist $(pwd)/gnupg-1.4.3.tar.gz
|
||||
|
||||
If you installed the iconv files in a non-standard place you may use
|
||||
|
||||
$ scripts/mk-w32-dist --iconv-dir /foo/bar/ $(pwd)/gnupg-1.4.3.tar.gz
|
||||
|
||||
If you need to patch the standard tarball, you can supply a patch file:
|
||||
|
||||
$ scripts/mk-w32-dist $(pwd)/gnupg-1.4.3.tar.gz mypatches
|
||||
|
||||
That patch file will then be part of the installer.
|
||||
|
||||
|
||||
|
||||
Copying:
|
||||
@ -124,7 +132,8 @@ Copying:
|
||||
GnuPG is
|
||||
|
||||
Copyright 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
||||
2005, 2006, 2007 Free Software Foundation, Inc.
|
||||
2005, 2006, 2007, 2008, 2009,
|
||||
2010, 2012 Free Software Foundation, Inc.
|
||||
|
||||
GnuPG is free software; you can redistribute it and/or modify it
|
||||
under the terms of the GNU General Public License as published by
|
||||
|
@ -94,7 +94,7 @@ if test "$1" = "--build-w32"; then
|
||||
fi
|
||||
[ $DIE = yes ] && exit 1
|
||||
|
||||
$tsdir/configure ${conf_CC} --build=${build} --host=${host}
|
||||
$tsdir/configure ${conf_CC} --build=${build} --host=${host} \
|
||||
${disable_foo_tests} $*
|
||||
exit $?
|
||||
fi
|
||||
|
@ -1,2 +0,0 @@
|
||||
Files useful for building W32 versions.
|
||||
|
@ -1,39 +0,0 @@
|
||||
To include support for BZIP2 compression in GunPG for W32, the patch
|
||||
below should be applied to a stock bzip2-1.0.6 source. The Build as
|
||||
usual using the mingw32 cross compiler package from Debian and install
|
||||
the library and header file on top of the cross compiler installation
|
||||
(/usr/i586-mingw32msvc/lib/). Note that for ease of maintenance we
|
||||
don't use a DLL. [wk 2005-03-14]
|
||||
|
||||
|
||||
diff -u orig/bzip2-1.0.2/Makefile bzip2-1.0.2/Makefile
|
||||
--- orig/bzip2-1.0.2/Makefile 2002-01-26 00:34:53.000000000 +0100
|
||||
+++ bzip2-1.0.2/Makefile 2004-11-03 14:10:45.000000000 +0100
|
||||
@@ -2,9 +2,9 @@
|
||||
SHELL=/bin/sh
|
||||
|
||||
# To assist in cross-compiling
|
||||
-CC=gcc
|
||||
-AR=ar
|
||||
-RANLIB=ranlib
|
||||
+CC=i586-mingw32msvc-gcc
|
||||
+AR=i586-mingw32msvc-ar
|
||||
+RANLIB=i586-mingw32msvc-ranlib
|
||||
LDFLAGS=
|
||||
|
||||
# Suitably paranoid flags to avoid bugs in gcc-2.7
|
||||
diff -u orig/bzip2-1.0.2/bzlib.h bzip2-1.0.2/bzlib.h
|
||||
--- orig/bzip2-1.0.2/bzlib.h 2001-12-30 03:19:45.000000000 +0100
|
||||
+++ bzip2-1.0.2/bzlib.h 2004-11-03 14:32:41.000000000 +0100
|
||||
@@ -113,7 +114,7 @@
|
||||
/* Need a definitition for FILE */
|
||||
#include <stdio.h>
|
||||
|
||||
-#ifdef _WIN32
|
||||
+#if defined( _WIN32 ) && 0
|
||||
# include <windows.h>
|
||||
# ifdef small
|
||||
/* windows.h define small to char */
|
||||
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (C) 2000, 2001, 2002, 2004, 2005 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2000, 2001, 2002, 2004, 2005,
|
||||
# 2012 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; as a special exception the author gives
|
||||
# unlimited permission to copy and/or distribute it, with or without
|
||||
@ -11,30 +12,9 @@
|
||||
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
|
||||
set -e
|
||||
cd dist-w32
|
||||
|
||||
tmp="`echo $0 | sed 's,.*gnupg-\([^/]*\)/.*,\1,'`"
|
||||
|
||||
topdir=
|
||||
bindir=..
|
||||
|
||||
if [ -f "../gnupg-$tmp/README" ]; then
|
||||
srcdir="../gnupg-$tmp"
|
||||
bindir="../gnupg-$tmp"
|
||||
topdir=".."
|
||||
elif [ -f ../README ]; then
|
||||
srcdir=..
|
||||
elif [ -f ../../README ]; then
|
||||
srcdir=../..
|
||||
bindir=..
|
||||
elif [ -f ../../gnupg-stable/README ]; then
|
||||
srcdir=../../gnupg-stable
|
||||
elif [ -f ../../../gnupg-stable/README ]; then
|
||||
srcdir=../../../gnupg-stable
|
||||
else
|
||||
echo "cannot figure out the source dir" >&2
|
||||
exit 1
|
||||
fi
|
||||
PGM="mk-w32-dist"
|
||||
[ -z "$w32root" ] && w32root="$HOME/w32root"
|
||||
|
||||
# Windows uses an internal build number. We use the last day of the
|
||||
# year concatenated with the hour. for it. If it happens that a new
|
||||
@ -49,18 +29,106 @@ else
|
||||
build_number=$(date -u '+%j%H' | sed 's/^0*\(.*\)/\1/')
|
||||
fi
|
||||
|
||||
if [ "$1" = "--iconv-dir" -a -n "$2" ]; then
|
||||
iconvdir="$2"
|
||||
shift
|
||||
shift
|
||||
else
|
||||
iconvdir="${w32root}/share/gnupg-1-extra/iconv"
|
||||
fi
|
||||
|
||||
if i586-mingw32msvc-strip --version >/dev/null 2>&1 ; then
|
||||
if [ $# -lt 1 -o $# -gt 2 -o "$1" = "--help" ]; then
|
||||
echo "usage: $PGM [options] TARBALL [PATCHFILE]" >&2
|
||||
echo " Options:" >&2
|
||||
echo " --build-number N Windows build number" >&2
|
||||
echo " --iconv-dir DIR Directory with inconv files" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
|
||||
if [ ! -d "$iconvdir" ]; then
|
||||
echo "$PGM: iconv directory does not exists (use option --iconv-dir)" >&2
|
||||
exit 1
|
||||
fi
|
||||
( set +e
|
||||
cd "${iconvdir}"
|
||||
cat <<EOF | sha1sum -c >/dev/null
|
||||
44f7289042b71631acac29b2f143330d2da2479e COPYING.LIB
|
||||
3f4262714a3b508cf20428f046d511f7bfb9fd89 README.iconv
|
||||
a21c860b81ed158e91b2b921b752f48fda6d6f1e iconv.dll
|
||||
EOF
|
||||
if [ $? != 0 ]; then
|
||||
echo "$PGM: iconv files are not available or not correct" >&2
|
||||
exit 1
|
||||
fi
|
||||
set -e
|
||||
)
|
||||
|
||||
here="$(pwd)"
|
||||
builddir=w32-build-root
|
||||
tarball="$1"
|
||||
patchfile="$2"
|
||||
|
||||
if [ ! -f "$tarball" -o "$(echo "$tarball" | head -c 1)" != "/" ]; then
|
||||
echo "$PGM: tarball does not exist or has no absolute name" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ -n "$patchfile" -a ! -f "$patchfile" ]; then
|
||||
echo "$PGM: patchfile does not exist" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! makensis -version >/dev/null 2>&1 ; then
|
||||
echo "$PGM: error: makensis is not installed" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
|
||||
if i686-w64-mingw32-strip --version >/dev/null 2>&1 ; then
|
||||
STRIP=i686-w64-mingw32-strip
|
||||
elif i586-mingw32msvc-strip --version >/dev/null 2>&1 ; then
|
||||
STRIP=i586-mingw32msvc-strip
|
||||
else
|
||||
STRIP="mingw32 strip"
|
||||
echo "$PGM: error: strip tool not found" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# If we don't have an installer we don't need to prepare for it.
|
||||
if ! makensis -version >/dev/null 2>&1 ; then
|
||||
topdir=
|
||||
echo "tarball: $tarball" >&2
|
||||
version="$(echo "$tarball" | sed 's,.*/gnupg-\(.*\)\.tar\.gz$,\1,')"
|
||||
prod_version=$(echo "$version"|awk -F'[^0-9]' '{print $1 "." $2 "." $3 }')
|
||||
prod_version="${prod_version}.${build_number}"
|
||||
echo "version: $version ($prod_version)" >&2
|
||||
|
||||
[ -n "$patchfile" ] && echo "patchfile: $patchfile" >&2
|
||||
echo "workdir: $builddir" >&2
|
||||
|
||||
echo "preparing work directory ..." >&2
|
||||
[ -d "$builddir" ] && rm -rf "$builddir"
|
||||
mkdir "$builddir"
|
||||
cd "$builddir"
|
||||
mkdir dist-w32
|
||||
|
||||
echo "unpacking tarball ..." >&2
|
||||
tar xzf "$tarball"
|
||||
cd gnupg-"$version"
|
||||
|
||||
if [ -n "$patchfile" ]; then
|
||||
echo "applying patchfile ..." >&2
|
||||
patch -p1 -t < "$patchfile"
|
||||
fi
|
||||
|
||||
echo "running configure ..." >&2
|
||||
./autogen.sh --build-w32 --silent
|
||||
|
||||
echo "running make ..." >&2
|
||||
make -s
|
||||
|
||||
|
||||
cd ../dist-w32
|
||||
srcdir="../gnupg-$version"
|
||||
bindir="../gnupg-$version"
|
||||
|
||||
|
||||
# A function to return a plain ASCII (or Latin-1) encoded description
|
||||
# text for a language identifier. We need this to display the list of
|
||||
@ -103,15 +171,7 @@ get_langname () {
|
||||
echo "$r"
|
||||
}
|
||||
|
||||
|
||||
# Figure out the version
|
||||
version=$(sed -n 's/^#[ ]*define[ ][ ]*VERSION[ ][ ]*\"\([0-9.a-z-]*\)\"/\1/p' $bindir/config.h)
|
||||
prod_version=$(echo "$version"|awk -F'[^0-9]' '{print $1 "." $2 "." $3 }')
|
||||
prod_version="${prod_version}.${build_number}"
|
||||
echo "building version $version ($prod_version)"
|
||||
|
||||
rm * >/dev/null 2>/dev/null || true
|
||||
|
||||
echo "copying files ..." >&2
|
||||
cp ${bindir}/g10/gpg.exe gpg.exe
|
||||
$STRIP gpg.exe
|
||||
cp ${bindir}/g10/gpgv.exe gpgv.exe
|
||||
@ -123,10 +183,6 @@ done
|
||||
cp ${bindir}/tools/gpgsplit.exe gpgsplit.exe
|
||||
$STRIP gpgsplit.exe
|
||||
|
||||
for i in FAQ; do
|
||||
cp ${bindir}/doc/$i $i.txt
|
||||
todos $i.txt
|
||||
done
|
||||
man -Tlatin1 -l ${srcdir}/doc/gpg.1 | sed `printf "s/_\b//g;s/\b.//g"` >gpg.man
|
||||
todos gpg.man
|
||||
man -Tlatin1 -l ${srcdir}/doc/gpgv.1 | sed `printf "s/_\b//g;s/\b.//g"` >gpgv.man
|
||||
@ -141,13 +197,14 @@ done
|
||||
cp ${srcdir}/doc/README.W32 README-W32.txt
|
||||
todos README-W32.txt
|
||||
|
||||
patches_defs=
|
||||
for i in `find "$topdir/patches" -type f \( -name '*.diff' -o -name '*.tar.gz' \)`; do
|
||||
cp $i .
|
||||
if [ -n "$patchfile" ]; then
|
||||
echo "copying patch file ..." >&2
|
||||
cp $patchfile patches.diff
|
||||
patches_defs="-DWITH_PATCHES"
|
||||
done
|
||||
fi
|
||||
|
||||
|
||||
echo "converting MO files ..." >&2
|
||||
# We must distribute the MO files in UTF-8, the conversion is done by
|
||||
# gpg at runtime. To include English at the right position in the list we
|
||||
# need a special case.
|
||||
@ -195,107 +252,26 @@ ListItems="$langdesclist"
|
||||
EOF
|
||||
|
||||
|
||||
# If we have a topdir, assume the full build environment and
|
||||
# prepare the installer
|
||||
if [ -n "$topdir" ]; then
|
||||
winpt_defs=
|
||||
src_defs=
|
||||
buildinfo="`date -u '+%Y-%m-%d %H:%M UTC'`"
|
||||
src_defs=
|
||||
buildinfo="`date -u '+%Y-%m-%d %H:%M UTC'`"
|
||||
|
||||
# iconv.dll is a hard requirement
|
||||
if [ ! -f "$topdir/iconv/iconv.dll" ]; then
|
||||
echo "iconv.dll not available" >&2
|
||||
exit 1
|
||||
fi
|
||||
ln "$topdir/iconv/iconv.dll" iconv.dll
|
||||
for i in COPYING.LIB README.iconv; do
|
||||
cp ${topdir}/iconv/$i $i.txt
|
||||
todos $i.txt
|
||||
done
|
||||
echo "copying iconv ..." >&2
|
||||
cp "${iconvdir}/iconv.dll" iconv.dll
|
||||
for i in COPYING.LIB README.iconv; do
|
||||
cp ${iconvdir}/$i $i.txt
|
||||
todos $i.txt
|
||||
done
|
||||
|
||||
# WinPT is optional
|
||||
if [ -f "$topdir/winpt/WinPT.exe" ]; then
|
||||
ln "$topdir/winpt/WinPT.exe" WinPT.exe
|
||||
ln "$topdir/winpt/PTD.dll" PTD.dll
|
||||
cp "$topdir/winpt/README-0.9.txt" README.winpt.txt
|
||||
cp "$topdir/winpt/NEWS-0.9.txt" NEWS.winpt.txt
|
||||
cp "$topdir/winpt/keyserver.conf" keyserver.conf
|
||||
winpt_defs="-DWITH_WINPT"
|
||||
fi
|
||||
|
||||
# See whether we should include the source and figure out the
|
||||
# version numbers of the source files.
|
||||
if [ -d "$topdir/tarballs" ]; then
|
||||
have_gnupg_src=no
|
||||
have_libiconv_src=no
|
||||
have_winpt_src=no
|
||||
for i in `find "$topdir/tarballs" -type f -name '*.tar.gz'`; do
|
||||
fname=$(basename "$i" .gz)
|
||||
zcat "$i" > "$fname"
|
||||
case "$fname" in
|
||||
gnupg-*)
|
||||
tmp=$(echo "$fname" | \
|
||||
sed -n 's/^[^-]*-\([0-9.a-z-]*\)\.tar$/\1/p')
|
||||
echo "gnupg source version is $tmp" >&2
|
||||
if [ "$version" != "$tmp" ]; then
|
||||
echo "gnupg source version does not match" >&2
|
||||
exit 1
|
||||
fi
|
||||
have_gnupg_src=yes
|
||||
;;
|
||||
libiconv-*)
|
||||
tmp=$(echo "$fname" | \
|
||||
sed -n 's/^[^-]*-\([0-9.a-z-]*\)\.tar$/\1/p')
|
||||
echo "libiconv source version is $tmp" >&2
|
||||
src_defs="$src_defs -DLIBICONV_VERSION=$tmp"
|
||||
have_libiconv_src=yes
|
||||
;;
|
||||
winpt-*)
|
||||
tmp=$(echo "$fname" | \
|
||||
sed -n 's/^[^-]*-\([0-9.a-z-]*\)\.tar$/\1/p')
|
||||
echo "winpt source version is $tmp" >&2
|
||||
src_defs="$src_defs -DWINPT_VERSION=$tmp"
|
||||
have_winpt_src=yes
|
||||
;;
|
||||
|
||||
*)
|
||||
echo "WARNING: unknown source file $fname ignored" >&2
|
||||
;;
|
||||
esac
|
||||
done
|
||||
if [ -n "$src_defs" ]; then
|
||||
if [ $have_gnupg_src = "no" ]; then
|
||||
echo "gnupg source missing" >&2
|
||||
exit 1
|
||||
fi
|
||||
if [ $have_libiconv_src = "no" ]; then
|
||||
echo "libiconv source missing" >&2
|
||||
exit 1
|
||||
fi
|
||||
if [ -n "$winpt_defs" ]; then
|
||||
if [ $have_winpt_src = "no" ]; then
|
||||
echo "winpt source missing" >&2
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
src_defs="$src_defs -DWITH_SOURCE"
|
||||
fi
|
||||
|
||||
fi
|
||||
|
||||
# Now run the installer
|
||||
echo "invoking installer as:"
|
||||
echo makensis -v0 -nocd -DVERSION="${version}" \
|
||||
-DPROD_VERSION="${prod_version}" \
|
||||
-DGNUPG_SRCDIR="${srcdir}" ${winpt_defs} ${src_defs} \
|
||||
${patches_defs} ${srcdir}/scripts/w32installer.nsi
|
||||
BUILDINFO=$buildinfo makensis -v0 -nocd -DVERSION="${version}" \
|
||||
-DPROD_VERSION="${prod_version}" \
|
||||
-DGNUPG_SRCDIR="${srcdir}" ${winpt_defs} ${src_defs} \
|
||||
${patches_defs} ${srcdir}/scripts/w32installer.nsi
|
||||
echo "Installer created" >&2
|
||||
else
|
||||
zip -9 "gnupg-w32cli-${version}.zip" *
|
||||
echo "ZIP archive created" >&2
|
||||
fi
|
||||
# Now run the installer
|
||||
echo "invoking installer as:"
|
||||
echo makensis -v0 -nocd -DVERSION="${version}" \
|
||||
-DPROD_VERSION="${prod_version}" \
|
||||
-DGNUPG_SRCDIR="${srcdir}" ${winpt_defs} ${src_defs} \
|
||||
${patches_defs} ${srcdir}/scripts/w32installer.nsi
|
||||
BUILDINFO=$buildinfo makensis -v0 -nocd -DVERSION="${version}" \
|
||||
-DPROD_VERSION="${prod_version}" \
|
||||
-DGNUPG_SRCDIR="${srcdir}" ${winpt_defs} ${src_defs} \
|
||||
${patches_defs} ${srcdir}/scripts/w32installer.nsi
|
||||
mv gnupg-w32cli-${version}.exe "${here}"/
|
||||
cd "${here}"
|
||||
echo "gnupg-w32cli-${version}.exe ready." >&2
|
||||
|
@ -220,7 +220,6 @@ Section "Documentation" SecDoc
|
||||
File "gpg.man"
|
||||
File "gpgv.man"
|
||||
File "NEWS.txt"
|
||||
File "FAQ.txt"
|
||||
|
||||
!ifdef WITH_WINPT
|
||||
File "NEWS.winpt.txt"
|
||||
@ -228,8 +227,7 @@ Section "Documentation" SecDoc
|
||||
|
||||
!ifdef WITH_PATCHES
|
||||
SetOutPath "$INSTDIR\Src"
|
||||
File '*.diff'
|
||||
File '*.tar.gz'
|
||||
File 'patches.diff'
|
||||
!endif
|
||||
|
||||
SectionEnd ; Section Documentation
|
||||
|
Loading…
x
Reference in New Issue
Block a user