bitcoin/ci/test
fanquake 80fd474e40
Merge #19240: build: macOS toolchain simplification and bump
adf543d714 darwin: pass mlinker-version so that clang enables new features (Cory Fields)
2418f739f7 macos: Bump to xcode 11.3.1 and 10.15 SDK (Cory Fields)
5c2c835433 depends: bump MacOS toolchain (Cory Fields)
85b5e42088 contrib: macdeploy: Remove historical extraction notes (Carl Dong)
351beb5c9a contrib: macdeploy: Use apple-sdk-tools instead of xar+pbzx (Carl Dong)
fbcfcf6954 native_cctools: Don't use libc++ from pinned clang (Carl Dong)
3381e4a189 Adapt rest of tooling to new SDK naming scheme (Carl Dong)
b3394ab235 contrib: macdeploy: Correctly generate macOS SDK (Carl Dong)

Pull request description:

  This PR achieves 3 main things:
  1. It simplifies the macOS SDK generation by putting the logic inside a (semi-)portable python3 script `gen-sdk`
  2. It transitions us to using `libc++` headers extracted from the `Xcode.app`, which is more correct as those headers better match the `.tbd` library stubs we use from the `MacOSX.sdk` (located under the same `Xcode.app`). Previously, we used `libc++` headers copied from our downloaded, pinned clang (see `native_cctools.mk`).
  3. It bumps the macOS toolchain in a way that fulfills all of the following constraints:
      1. The new SDK should support compiling with C++17 (our current one doesn't)
      2. The new toolchain should not change our minimum supported macOS version (`-mmacosx-version-min`)
      3. The new toolchain should expect to use a version of `cctools` that is supported by https://github.com/tpoechtrager/cctools-port

  For the constraints in (3), you can reference [this chart](https://en.wikipedia.org/wiki/Xcode#Xcode_7.0_-_11.x_(since_Free_On-Device_Development)) to see that the newest toolchain we can use with our `cctools-port` is `11.3.1`, and the rest of the constraints were tested with local builds.

  #### But [the other Wikipedia chart](https://en.wikipedia.org/wiki/Xcode#Xcode_11.x_(since_SwiftUI_framework)) says that the "min macOS to run" for Xcode 11.3.1 is 10.14.4, doesn't that violate constraint (ii)?

  This confused me at first too, but the "min macOS to run" is for the Xcode.app App itself. The SDK still supports 10.12, as evident in a few plist files and as proven through local builds.

  #### Why bundle all of this together in a single PR?

  We need (1) and (2) together, because if we don't, manually adding the `libc++` headers and writing that out in a `README.md` is going to result in a lot of user error, so it's great to have these together to be more correct and also make it easier on the user at the same time.

  We need (3) together with everything else because bumping (or in the case of (1), renaming) the SDK requires some human coordination and may break some builds. And since it's not that complicated a change, it makes sense to do it together with the rest.

ACKs for top commit:
  theuni:
    ACK adf543d714.
  fanquake:
    ACK adf543d714 - I'll take a look at the linker issue.

Tree-SHA512: 3813b69ebfe9610bee14100f26296fb5438d9bf0dd184ea55e6c38f5ebd94f7c171d98b150fc9e52fde626533f347f7ec51a2b72b79859d946284f578c1084a3
2020-06-23 16:14:49 +08:00
..
00_setup_env.sh tests: run test-security-check.py in CI 2020-06-16 19:52:30 +08:00
00_setup_env_arm.sh scripted-diff: Bump copyright headers 2020-04-16 13:33:09 -04:00
00_setup_env_i686_centos.sh test: set a name for CI Docker containers 2020-02-10 20:03:52 +08:00
00_setup_env_mac.sh macos: Bump to xcode 11.3.1 and 10.15 SDK 2020-06-22 10:14:33 -04:00
00_setup_env_mac_host.sh ci: Upgrade most ci configs to focal 2020-06-19 10:44:11 -04:00
00_setup_env_native_asan.sh ci: Upgrade most ci configs to focal 2020-06-19 10:44:11 -04:00
00_setup_env_native_fuzz.sh build: turn on --enable-c++17 by --enable-fuzz 2020-06-05 11:50:34 +02:00
00_setup_env_native_fuzz_with_valgrind.sh build: turn on --enable-c++17 by --enable-fuzz 2020-06-05 11:50:34 +02:00
00_setup_env_native_multiprocess.sh ci: Upgrade most ci configs to focal 2020-06-19 10:44:11 -04:00
00_setup_env_native_nowallet.sh ci: Have one config run in xenial to test against python3.5 2020-06-19 10:43:21 -04:00
00_setup_env_native_qt5.sh ci: Upgrade most ci configs to focal 2020-06-19 10:44:11 -04:00
00_setup_env_native_tsan.sh ci: tsan with wallet 2020-06-04 18:26:01 -04:00
00_setup_env_native_valgrind.sh Remove unused ci configs that have been moved elsewhere 2020-05-10 07:51:31 -04:00
00_setup_env_s390x.sh scripted-diff: Bump copyright headers 2020-04-16 13:33:09 -04:00
00_setup_env_win64.sh ci: Upgrade most ci configs to focal 2020-06-19 10:44:11 -04:00
03_before_install.sh ci: Remove unused workaround 2020-05-31 18:37:56 -04:00
04_install.sh ci: Set halt_on_error=1 for tsan 2020-05-30 08:32:58 -04:00
05_before_script.sh Adapt rest of tooling to new SDK naming scheme 2020-06-22 10:13:55 -04:00
06_script_a.sh ci: Add and document BASE_BUILD_DIR 2020-04-27 12:27:34 -04:00
06_script_b.sh tests: run test-security-check.py in CI 2020-06-16 19:52:30 +08:00
wrap-qemu.sh scripted-diff: Bump copyright headers 2020-04-16 13:33:09 -04:00
wrap-valgrind.sh scripted-diff: Bump copyright of files changed in 2019 2019-12-30 10:42:20 +13:00