[tor-commits] [tor-messenger-build/master] Build 64bit Tor Messenger for Windows
sukhbir at torproject.org
sukhbir at torproject.org
Mon Jan 29 22:12:31 UTC 2018
commit 78bf2fd72676ca92fecfc464fb2bf494cbe19126
Author: Sukhbir Singh <sukhbir at torproject.org>
Date: Mon Jan 29 17:11:31 2018 -0500
Build 64bit Tor Messenger for Windows
Inspired by #20636, build the 64bit version of Tor Messenger
---
Makefile | 5 ++-
projects/ctypes-otr/config | 2 +-
projects/instantbird/config | 4 +++
projects/instantbird/mozconfig-windows-x86_64 | 10 ++++++
projects/libgpg-error/config | 2 +-
projects/libotr/config | 7 +++--
projects/mozilla/STL_win64.patch | 24 ++++++++++++++
projects/mozilla/config | 2 ++
projects/tor-browser/config | 2 +-
projects/tor-messenger/config | 18 +++++++----
rbm | 2 +-
rbm.conf | 45 ++++++++++++++++++++-------
tor-browser-build | 2 +-
13 files changed, 99 insertions(+), 26 deletions(-)
diff --git a/Makefile b/Makefile
index cdef67c..699ff19 100644
--- a/Makefile
+++ b/Makefile
@@ -2,7 +2,7 @@ rbm=./rbm/rbm
all: tor-messenger
-tor-messenger: tor-messenger-linux-x86_64 tor-messenger-linux-i686 tor-messenger-windows-i686 tor-messenger-osx-x86_64
+tor-messenger: tor-messenger-linux-x86_64 tor-messenger-linux-i686 tor-messenger-windows-i686 tor-messenger-windows-x86_64 tor-messenger-osx-x86_64
tor-messenger-release: submodule-update
$(rbm) build tor-messenger-release --target tormessenger-all
@@ -18,6 +18,9 @@ tor-messenger-linux-i686: submodule-update
tor-messenger-windows-i686: submodule-update
$(rbm) build tor-messenger --target tor-messenger --target tormessenger-windows-i686
+tor-messenger-windows-x86_64: submodule-update
+ $(rbm) build tor-messenger --target tor-messenger --target tormessenger-windows-x86_64
+
tor-messenger-osx-x86_64: submodule-update
$(rbm) build tor-messenger --target tor-messenger --target tormessenger-osx-x86_64
diff --git a/projects/ctypes-otr/config b/projects/ctypes-otr/config
index a3feb2a..0642a5b 100644
--- a/projects/ctypes-otr/config
+++ b/projects/ctypes-otr/config
@@ -10,7 +10,7 @@ filename: 'ctypes-otr-[% c("version") %]-[% c("var/osname") %]-[% c("var/build_i
var:
lib_glob: 'lib/*.so*'
targets:
- windows-i686:
+ windows:
var:
lib_glob: 'bin/*.dll'
osx-x86_64:
diff --git a/projects/instantbird/config b/projects/instantbird/config
index 446330c..1ab021a 100644
--- a/projects/instantbird/config
+++ b/projects/instantbird/config
@@ -21,6 +21,10 @@ targets:
var:
martools_filename: mar-tools-win32.zip
archive_suffix: zip
+ windows-x86_64:
+ var:
+ martools_filename: mar-tools-win64.zip
+ archive_suffix: zip
linux:
var:
arch_deps:
diff --git a/projects/instantbird/mozconfig-windows-x86_64 b/projects/instantbird/mozconfig-windows-x86_64
new file mode 100644
index 0000000..a8fbcc3
--- /dev/null
+++ b/projects/instantbird/mozconfig-windows-x86_64
@@ -0,0 +1,10 @@
+export CROSS_COMPILE=1
+
+mk_add_options MOZ_OBJDIR=@TOPSRCDIR@/obj-mingw
+
+ac_add_options --target=x86_64-w64-mingw32
+ac_add_options --with-toolchain-prefix=x86_64-w64-mingw32-
+
+ac_add_options --enable-default-toolkit=cairo-windows
+ac_add_options --enable-strip
+ac_add_options --disable-sandbox
diff --git a/projects/libgpg-error/config b/projects/libgpg-error/config
index a815397..512f5a8 100644
--- a/projects/libgpg-error/config
+++ b/projects/libgpg-error/config
@@ -9,7 +9,7 @@ var:
container:
use_container: 1
targets:
- windows-i686:
+ windows:
var:
arch_deps:
- gettext
diff --git a/projects/libotr/config b/projects/libotr/config
index 12cf34b..6a76aec 100644
--- a/projects/libotr/config
+++ b/projects/libotr/config
@@ -10,13 +10,16 @@ var:
container:
use_container: 1
targets:
- windows-i686:
+ windows:
var:
arch_deps:
- gettext
- configure_opt: '--host=i686-w64-mingw32 CFLAGS="[% c("var/CFLAGS_otr") %]" LDFLAGS="[% c("var/LDFLAGS_otr") %]" CC="i686-w64-mingw32-gcc -static-libgcc"'
+ configure_opt: '--host=[% c("arch") %]-w64-mingw32 CFLAGS="[% c("var/CFLAGS_otr") %]" LDFLAGS="[% c("var/LDFLAGS_otr") %]"'
CFLAGS_otr: '[% c("var/CFLAGS") %] -Wl,-Bstatic,-L/var/tmp/dist/libgcrypt/lib,-lgcrypt,-L/var/tmp/dist/libgpg-error/lib,-lgpg-error,-Bdynamic'
LDFLAGS_otr: '[% c("var/LDFLAGS") %] -Wl,-Bstatic,-L/var/tmp/dist/libgcrypt/lib,-lgcrypt,-L/var/tmp/dist/libgpg-error/lib,-lgpg-error,-Bdynamic'
+ flag_mwindows: '-mwindows'
+ compiler: mingw-w64
+
osx-x86_64:
var:
arch_deps:
diff --git a/projects/mozilla/STL_win64.patch b/projects/mozilla/STL_win64.patch
new file mode 100644
index 0000000..e528905
--- /dev/null
+++ b/projects/mozilla/STL_win64.patch
@@ -0,0 +1,24 @@
+From 8f8c1a1069d4907d3cedae578975225d8caeecaf Mon Sep 17 00:00:00 2001
+From: Nicolas Vigier <boklm at torproject.org>
+Date: Sat, 12 Aug 2017 22:00:13 +0200
+Subject: [PATCH] Bug 23231: disable STL Wrappers on Windows
+
+Workaround for:
+https://bugzilla.mozilla.org/show_bug.cgi?id=1392604
+---
+ old-configure.in | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/old-configure.in b/old-configure.in
+index f5a2f05..e247551 100644
+--- a/old-configure.in
++++ b/old-configure.in
+@@ -1338,7 +1338,7 @@ MOZ_CXX11
+ AC_LANG_C
+
+ case "${OS_TARGET}" in
+-Darwin)
++WINNT|Darwin)
+ ;;
+ *)
+ STL_FLAGS="-I${DIST}/stl_wrappers"
diff --git a/projects/mozilla/config b/projects/mozilla/config
index 39a2f81..f3c4234 100644
--- a/projects/mozilla/config
+++ b/projects/mozilla/config
@@ -11,3 +11,5 @@ input_files:
- filename: 0003-OSX-package-as-tar.bz2.patch
- filename: 0004-Updater-fixups-for-TM.patch
- filename: 0005-Permit-storing-exceptions-even-w-inPrivateBrowsingMo.patch
+ - filename: STL_win64.patch
+ enable: '[% c("var/windows-x86_64") %]'
diff --git a/projects/tor-browser/config b/projects/tor-browser/config
index 56c4171..949b048 100644
--- a/projects/tor-browser/config
+++ b/projects/tor-browser/config
@@ -11,7 +11,7 @@ input_files:
var:
base_url: "https://dist.torproject.org/torbrowser/[% c('version') %]"
targets:
- windows-i686:
+ windows:
URL: "[% c('var/base_url') %]/torbrowser-install-[% c('version') %]_en-US.exe"
osx-x86_64:
URL: "[% c('var/base_url') %]/TorBrowser-[% c('version') %]-osx64_en-US.dmg"
diff --git a/projects/tor-messenger/config b/projects/tor-messenger/config
index 92fc588..61b439a 100644
--- a/projects/tor-messenger/config
+++ b/projects/tor-messenger/config
@@ -41,6 +41,8 @@ input_files:
enable: '[% c("var/osx") %]'
- project: nsis
name: nsis
+ target:
+ - tormessenger-windows-i686
enable: '[% c("var/windows") %]'
- URL: https://people.torproject.org/~mikeperry/mirrors/sources/msvcr100.dll
sha256sum: 1221a09484964a6f38af5e34ee292b9afefccb3dc6e55435fd3aaf7c235d9067
@@ -55,16 +57,20 @@ var:
container:
use_container: 1
targets:
+ windows:
+ var:
+ arch_deps:
+ - python-pefile
windows-i686:
var:
bundle_filename: 'tormessenger-install-[% c("version") %]_en-US.exe'
mar_osname: win32
- arch_deps:
- - nsis
- - python
- - python-dev
- - build-essential
- - python-pefile
+ windows-x86_64:
+ var:
+ bundle_filename: 'tormessenger-install-[% c("version") %]_en-US.exe'
+ mar_osname: win64
+ container:
+ arch: i386
osx-x86_64:
var:
bundle_filename: 'TorMessenger-[% c("version") %]-osx64_en-US.dmg'
diff --git a/rbm b/rbm
index 5c89374..b83c74c 160000
--- a/rbm
+++ b/rbm
@@ -1 +1 @@
-Subproject commit 5c89374df7957238a9565c0b938ee3f30f880438
+Subproject commit b83c74ca4b91732f64011f0255a1594f7747b340
diff --git a/rbm.conf b/rbm.conf
index 74af21e..886d777 100644
--- a/rbm.conf
+++ b/rbm.conf
@@ -11,7 +11,7 @@ pkg_type: build
# When adding a new option to buildconf, a default value should be defined
# in var/build_id, so that changing this option does not affect the build_id.
buildconf:
- num_procs: '[% GET ENV.RBM_NUM_PROCS ? ENV.RBM_NUM_PROCS : "8" %]'
+ num_procs: '[% GET ENV.RBM_NUM_PROCS ? ENV.RBM_NUM_PROCS : "2" %]'
var:
tormessenger_version: '0.6.0b1'
@@ -24,7 +24,7 @@ var:
# in the same order. In the cases where the installation order is
# important, sort_deps should be set to 0.
sort_deps: 1
- build_id: '[% sha256(c("var/build_id_txt", { buildconf => { num_procs => 8 } })).substr(0, 6) %]'
+ build_id: '[% sha256(c("var/build_id_txt", { buildconf => { num_procs => 2 } })).substr(0, 6) %]'
build_id_txt: |
[% c("version") %]
[% IF c("git_hash") || c("hg_hash"); GET c("abbrev"); END; %]
@@ -121,18 +121,46 @@ targets:
- zip
- unzip
+ tormessenger-windows-x86_64:
+ - windows-x86_64
+ - windows
+ - tor-messenger
+
tormessenger-windows-i686:
- windows-i686
+ - windows
- tor-messenger
+
+ windows-x86_64:
+ arch: x86_64
+ var:
+ windows-x86_64: 1
+ osname: windows-x86_64
+ container:
+ arch: amd64
+ faketime_path: /usr/lib/x86_64-linux-gnu/faketime/libfaketime.so.1
+
windows-i686:
arch: i686
var:
- windows: 1
+ windows-i686: 1
osname: windows-i686
container:
- suite: precise
arch: i386
- configure_opt: '--host=i686-w64-mingw32 CFLAGS="[% c("var/CFLAGS") %]" LDFLAGS="[% c("var/LDFLAGS") %]"'
+ faketime_path: /usr/lib/i386-linux-gnu/faketime/libfaketime.so.1
+ setarch: |
+ if test -z "$RBM_SETARCH"
+ then
+ export RBM_SETARCH=1
+ exec setarch i686 ./build
+ fi
+
+ windows:
+ var:
+ windows: 1
+ container:
+ suite: jessie
+ configure_opt: '--host=[% c("arch") %]-w64-mingw32 CFLAGS="[% c("var/CFLAGS") %]" LDFLAGS="[% c("var/LDFLAGS") %]"'
CFLAGS: '[% c("var/flag_mwindows") %] -fstack-protector-all -Wstack-protector --param ssp-buffer-size=4 -fno-strict-overflow -Wno-missing-field-initializers -Wformat -Wformat-security'
LDFLAGS: '[% c("var/flag_mwindows") %] -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -lssp -L$gcclibs'
flag_mwindows: '-mwindows'
@@ -145,13 +173,6 @@ targets:
- libtool
- zip
- unzip
- faketime_path: /usr/lib/faketime/libfaketime.so.1
- setarch: |
- if test -z "$RBM_SETARCH"
- then
- export RBM_SETARCH=1
- exec setarch i686 ./build
- fi
tormessenger-osx-x86_64:
- osx-x86_64
diff --git a/tor-browser-build b/tor-browser-build
index d2dee35..62ee652 160000
--- a/tor-browser-build
+++ b/tor-browser-build
@@ -1 +1 @@
-Subproject commit d2dee352354ee77cd26ac37bef41322df2729ff8
+Subproject commit 62ee652c588858ded1aa02261510f1c05234795a
More information about the tor-commits
mailing list