[tor-commits] [builders/tor-browser-build] 05/05: Bug 40439: Add option for macos single-arch non-universal testbuild

gitolite role git at cupani.torproject.org
Tue Nov 15 09:35:07 UTC 2022


This is an automated email from the git hooks/post-receive script.

boklm pushed a commit to branch main
in repository builders/tor-browser-build.

commit 0553b695c83b9a61abca6ff3b7b42507993f265b
Author: Nicolas Vigier <boklm at torproject.org>
AuthorDate: Fri Oct 28 20:36:47 2022 +0200

    Bug 40439: Add option for macos single-arch non-universal testbuild
    
    `make torbrowser-testbuild-macos-x86_64`
      and
    `make torbrowser-testbuild-macos-aarch64` can be used to do non-universal
    testbuilds for a single arch.
---
 Makefile                |  6 ++++++
 doc/MAKEFILE.txt        | 13 +++++++++++++
 projects/browser/build  | 24 ++++++++++++++----------
 projects/browser/config | 14 +++++++++++---
 projects/release/build  |  6 ++++++
 projects/release/config | 22 ++++++++++++++++++++++
 rbm.conf                | 13 +++++++++++++
 7 files changed, 85 insertions(+), 13 deletions(-)

diff --git a/Makefile b/Makefile
index fa5220ed..6be00da3 100644
--- a/Makefile
+++ b/Makefile
@@ -171,6 +171,12 @@ torbrowser-testbuild-windows-i686: submodule-update
 torbrowser-testbuild-macos: submodule-update
 	$(rbm) build release --target testbuild --target browser-macos --target torbrowser
 
+torbrowser-testbuild-macos-x86_64: submodule-update
+	$(rbm) build release --target testbuild --target browser-macos-x86_64 --target torbrowser
+
+torbrowser-testbuild-macos-aarch64: submodule-update
+	$(rbm) build release --target testbuild --target browser-macos-aarch64 --target torbrowser
+
 torbrowser-testbuild-src: submodule-update
 	$(rbm) build release --target testbuild --target browser-src-testbuild --target torbrowser
 
diff --git a/doc/MAKEFILE.txt b/doc/MAKEFILE.txt
index 0eec68ff..21704936 100644
--- a/doc/MAKEFILE.txt
+++ b/doc/MAKEFILE.txt
@@ -49,6 +49,19 @@ By default it is based on the alpha channel, but you can change that by
 editing rbm.local.conf. The resulting build can be found in directory
 testbuild.
 
+torbrowser-testbuild-{linux-x86_64,linux-i686,windows-i686,macos,
+                    android-armv7,android-x86,android-x86_64,
+                    android-aarch64,desktop,android}
+-----------------------------------------------------------------
+Same as torbrowser-testbuild, for the selected platform only.
+
+
+torbrowser-testbuild-macos-{x86_64,aarch64}
+-------------------------------------------
+By default, macos builds are universal (targeting x86_64 and aarch64).
+With this special testbuild target, you can do a build for a specific
+arch only.
+
 torbrowser-{release,alpha,nightly,testbuild}-linux-x86_64-asan
 --------------------------------------------------------------
 Create a build for Linux x86_64 with Address Sanitizer enabled.
diff --git a/projects/browser/build b/projects/browser/build
index 34be146a..8cbbc20d 100644
--- a/projects/browser/build
+++ b/projects/browser/build
@@ -21,8 +21,12 @@ touch "$GENERATEDPREFSPATH"
 
 [% IF c("var/macos") %]
   TBDIR="$TB_STAGE_DIR/[% c("var/Project_Name") %].app"
-  TBDIR_AARCH64="$TB_STAGE_DIR/[% c("var/Project_Name") %]-aarch64.app"
-  TBDIRS=("$TBDIR" "$TBDIR_AARCH64")
+  [% IF c("var/macos_universal") %]
+    TBDIR_AARCH64="$TB_STAGE_DIR/[% c("var/Project_Name") %]-aarch64.app"
+    TBDIRS=("$TBDIR" "$TBDIR_AARCH64")
+  [% ELSE -%]
+    TBDIRS=("$TBDIR")
+  [% END -%]
 
   DOCSPATH=Contents/Resources/[% c('var/ProjectName') %]/Docs
   EXTSPATH=Contents/Resources/distribution/extensions
@@ -60,7 +64,7 @@ mv [% c('input_files_by_name/noscript') %] "$TBDIR/$EXTSPATH/{73a6fe31-595d-460b
     local dest="${args[-1]}"
     unset args[-1]
     mv ${args[@]} "$TBDIR/$dest"
-    [% IF c("var/macos") -%]
+    [% IF c("var/macos_universal") -%]
       for src in ${args[@]}
       do
         mv "aarch64/$src" "$TBDIR_AARCH64/$dest"
@@ -69,27 +73,27 @@ mv [% c('input_files_by_name/noscript') %] "$TBDIR/$EXTSPATH/{73a6fe31-595d-460b
   }
 
   tar -xvf [% c('input_files_by_name/tor-expert-bundle') %]
-  [% IF c("var/macos") -%]
+  [% IF c("var/macos_universal") -%]
     mkdir aarch64
     tar -C aarch64 -xf [% c('input_files_by_name/tor-expert-bundle-aarch64') %]
   [% END -%]
 
   # geoip(6) and anything else that belongs in the data dir from the expert bundle
-  mkdir -p "$TBDIR/$TORCONFIGPATH" [% IF c("var/macos") %]"$TBDIR_AARCH64/$TORCONFIGPATH"[% END %]
+  mkdir -p "$TBDIR/$TORCONFIGPATH" [% IF c("var/macos_universal") %]"$TBDIR_AARCH64/$TORCONFIGPATH"[% END %]
   mv_tbdir data/{geoip,geoip6} "$TORCONFIGPATH"
 
   # Bridge lists will be consumed later in `bridges_conf`
   mv tor/pluggable_transports/bridges_list.*.txt $rootdir
-  [% IF c("var/macos") %]
+  [% IF c("var/macos_universal") %]
     rm -f aarch64/tor/pluggable_transports/bridges_list.*.txt
   [% END -%]
 
   # Snowflake's README is the only documentation shipped in tor-expert-bundle
-  mkdir -p "$TBDIR/$DOCSPATH/snowflake" [% IF c("var/macos") %]"$TBDIR_AARCH64/$DOCSPATH/snowflake"[% END %]
+  mkdir -p "$TBDIR/$DOCSPATH/snowflake" [% IF c("var/macos_universal") %]"$TBDIR_AARCH64/$DOCSPATH/snowflake"[% END %]
   mv_tbdir tor/pluggable_transports/README.SNOWFLAKE.md "$DOCSPATH/snowflake/README.md"
 
   # Move the PTs to where TB expects them
-  mkdir -p "$TBDIR/$TORBINPATH" [% IF c("var/macos") %]"$TBDIR_AARCH64/$TORBINPATH"[% END %]
+  mkdir -p "$TBDIR/$TORBINPATH" [% IF c("var/macos_universal") %]"$TBDIR_AARCH64/$TORBINPATH"[% END %]
   mv_tbdir tor/pluggable_transports "$TORBINPATH/PluggableTransports"
 
   # Move tor and dependencies to where TB expects them
@@ -145,7 +149,7 @@ RBM_TB_EOF
 
 tar -C ${TB_STAGE_DIR} -xf [% c('input_files_by_name/firefox') %]/browser.tar.gz
 
-[% IF c("var/macos") -%]
+[% IF c("var/macos_universal") -%]
   # Use symlink in tmp dir to extract "Tor Browser.app" to "Tor Browser-aarch64.app"
   ff_aarch64=$(mktemp -d)
   ln -s "$TBDIR_AARCH64" "$ff_aarch64/[% c("var/Project_Name") %].app"
@@ -284,7 +288,7 @@ done
   mv $distdir/windows-installer ${TB_STAGE_DIR}
 [% END %]
 
-[% IF c("var/macos") -%]
+[% IF c("var/macos_universal") -%]
   # unify.py requires lipo, so we need to add cctools in the PATH
   tar -C /var/tmp/dist -xf $rootdir/[% c('input_files_by_name/macosx-toolchain') %]
   export PATH="/var/tmp/dist/macosx-toolchain/cctools/bin:$PATH"
diff --git a/projects/browser/config b/projects/browser/config
index db68912a..f9d9cba5 100644
--- a/projects/browser/config
+++ b/projects/browser/config
@@ -28,7 +28,6 @@ targets:
       mar_osname: linux64
   macos:
     var:
-      mar_osname: macos
       arch_deps:
         - genisoimage
         - faketime
@@ -36,6 +35,15 @@ targets:
         - python3-pip
         - python3-distutils-extra
         - python3-psutil
+  macos-universal:
+    var:
+      mar_osname: macos
+  macos-aarch64:
+    var:
+      mar_osname: macos-aarch64
+  macos-x86_64:
+    var:
+      mar_osname: macos-x86_64
   windows:
     var:
       arch_deps:
@@ -66,7 +74,7 @@ input_files:
     enable: '[% ! c("var/android") %]'
   - project: firefox
     name: firefox-aarch64
-    enable: '[% c("var/macos") %]'
+    enable: '[% c("var/macos_universal") %]'
     target_prepend:
       - macos-aarch64
   - project: firefox
@@ -81,7 +89,7 @@ input_files:
     enable: '[% c("var/tor-browser") %]'
   - project: tor-expert-bundle
     name: tor-expert-bundle-aarch64
-    enable: '[% c("var/macos") && c("var/tor-browser") %]'
+    enable: '[% c("var/macos_universal") && c("var/tor-browser") %]'
     target_prepend:
       - macos-aarch64
   - project: fonts
diff --git a/projects/release/build b/projects/release/build
index 84d09b05..1a95362a 100644
--- a/projects/release/build
+++ b/projects/release/build
@@ -25,6 +25,12 @@ mkdir -p "$destdir"
 [% IF c("var/browser-macos") -%]
   mv [% c('input_files_by_name/macos') %]/* "$destdir"/
 [% END -%]
+[% IF c("var/browser-macos-x86_64") -%]
+  mv [% c('input_files_by_name/macos-x86_64') %]/* "$destdir"/
+[% END -%]
+[% IF c("var/browser-macos-aarch64") -%]
+  mv [% c('input_files_by_name/macos-aarch64') %]/* "$destdir"/
+[% END -%]
 [% IF c("var/browser-linux-i686") -%]
   mv [% c('input_files_by_name/linux-i686') %]/* "$destdir"/
 [% END -%]
diff --git a/projects/release/config b/projects/release/config
index cd1c7d74..fb49e0d8 100644
--- a/projects/release/config
+++ b/projects/release/config
@@ -63,6 +63,12 @@ targets:
   browser-macos:
     var:
       browser-macos: 1
+  browser-macos-x86_64:
+    var:
+      browser-macos-x86_64: 1
+  browser-macos-aarch64:
+    var:
+      browser-macos-aarch64: 1
   browser-src:
     var:
       browser-src: '[% ! c("var/testbuild") %]'
@@ -192,6 +198,22 @@ input_files:
      - '[% c("var/build_target") %]'
      - '[% c("var/browser_type") %]-macos'
 
+ # non-universal macos build
+ - name: macos-x86_64
+   project: browser
+   enable: '[% c("var/browser-macos-x86_64") %]'
+   target:
+     - '[% c("var/build_target") %]'
+     - '[% c("var/browser_type") %]-macos-x86_64'
+
+ # non-universal macos build
+ - name: macos-aarch64
+   project: browser
+   enable: '[% c("var/browser-macos-aarch64") %]'
+   target:
+     - '[% c("var/build_target") %]'
+     - '[% c("var/browser_type") %]-macos-aarch64'
+
  - name: src-firefox
    project: firefox
    enable: '[% c("var/browser-src") %]'
diff --git a/rbm.conf b/rbm.conf
index fff2fd68..e1f8b867 100644
--- a/rbm.conf
+++ b/rbm.conf
@@ -500,13 +500,26 @@ targets:
         - unzip
 
   torbrowser-macos:
+    - macos-universal
     - macos-x86_64
     - macos
     - torbrowser
+  torbrowser-macos-x86_64:
+    - macos-x86_64
+    - macos
+    - torbrowser
+  torbrowser-macos-aarch64:
+    - macos-aarch64
+    - macos
+    - torbrowser
   basebrowser-macos:
+    - macos-universal
     - macos-x86_64
     - macos
     - basebrowser
+  macos-universal:
+    var:
+      macos_universal: 1
   macos-aarch64:
     arch: aarch64
     var:

-- 
To stop receiving notification emails like this one, please contact
the administrator of this repository.


More information about the tor-commits mailing list