-
Notifications
You must be signed in to change notification settings - Fork 782
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
cmd/gomobile: produce frameworks which follow Apple's specs per platform, fixing Xcode 15.3 compatibility issues #98
Conversation
This change adds compatibility for Xcode 15.3 to "gomobile bind" for building xcframeworks. - New blank Info.plist in the *.framework target root - Add CFBundleExecutable and CFBundleIdentifier to the resource level Info.plist Tested locally on my framework on Xcode 15.3 (fixes issue) and 15.2 (doesn't create new issues). Would love to get some more folks to try this fix, to make sure it works broadly.
…ntion in the package). From Apple docs: "The bundle ID string must contain only alphanumeric characters (A-Z, a-z, 0-9), hyphen (-), and period (.)" - https://help.apple.com/xcode/mac/current/#/deve70ea917b
…ntion in the package). From Apple docs: "The bundle ID string must contain only alphanumeric characters (A-Z, a-z, 0-9), hyphen (-), and period (.)" - https://help.apple.com/xcode/mac/current/#/deve70ea917b
This PR (HEAD: 3896b12) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Gopher Robot: Patch Set 1: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Hajime Hoshi: Patch Set 1: Run-TryBot+1 (3 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Gopher Robot: Patch Set 1: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Gopher Robot: Patch Set 1: TryBot-Result+1 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
This PR (HEAD: 9d5c4a7) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Steve Cosman: Patch Set 2: (3 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Hajime Hoshi: Patch Set 2: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
- if -> switch - Consistent relative paths (old system worked, but consistent is good)
This PR (HEAD: 7bb9459) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Steve Cosman: Patch Set 3: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Emmanuel Odeke: Patch Set 3: Commit-Queue+1 Run-TryBot+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 3: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2024-03-24T23:34:43Z","revision":"7e98f75fd10d6176c8bcad1a7d0dccc655e61672"} Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Gopher Robot: Patch Set 5: TryBot-Result+1 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Steve Cosman: Patch Set 5: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
The placement spec has these as optional, but allowed: https://developer.apple.com/documentation/bundleresources/placing_content_in_a_bundle#3875936 The open source Apple code created Headers: https://opensource.apple.com/source/CF/CF-368.28/framework.make.auto.html gomobile has historically created Modules, and it's optional, so let's keep that to minimize issues for existing users/scripts
This PR (HEAD: 6a0d5eb) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Steve Cosman: Patch Set 6: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Hajime Hoshi: Patch Set 6: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Hajime Hoshi: Patch Set 6: Code-Review+1 Run-TryBot+1 (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Gopher Robot: Patch Set 6: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Gopher Robot: Patch Set 6: TryBot-Result+1 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
This PR (HEAD: 2a90da2) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Dmitri Shuralyov: Patch Set 7: Code-Review+2 Commit-Queue+1 (4 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 7: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2024-03-25T15:56:14Z","revision":"d30ac7ae5ed0d6921f9fb3eb1a634a0bbb193f4b"} Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Dmitri Shuralyov: Patch Set 7: Code-Review+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Dmitri Shuralyov: Patch Set 7: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 7: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 7: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
This PR (HEAD: 28dca85) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/mobile/+/574055. Important tips:
|
Message from Hajime Hoshi: Patch Set 8: Code-Review+1 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Steve Cosman: Patch Set 8: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Dmitri Shuralyov: Patch Set 8: Auto-Submit+1 Code-Review+2 Commit-Queue+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 8: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2024-03-26T15:03:36Z","revision":"1a2476b13222299a11b6cfba8367a0c71ed48ea7"} Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Dmitri Shuralyov: Patch Set 8: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 8: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
Message from Go LUCI: Patch Set 8: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/574055. |
…orm, fixing Xcode 15.3 compatibility issues This patch updates the framework generation code to follow the Apple spec for placing content: https://developer.apple.com/documentation/bundleresources/placing_content_in_a_bundle Previously, we setup the framework in MacOS format, and used symlinks to make it compatible with iOS format. This approach no longer works (it works locally in simulator, but causes signing issues when attempting to upload apps for distribution, or running on real hardware). We now setup the expected bundle format for each platform. Other benefits: - Thirds the size of the xcframework and resulting app binary when distributing the xcframework by zip (common for SPM and other formats). The symlinks resulted in duplicate files after zipping, which made it into the final app. - Set MinimumOSVersion, fixing SPM compatibility issue - Eliminates the blank Info.plist - Initial testing shows this also fixes golang/go#66406 (code signing issues) as a side effect of using the proper format Testing: - Tested all 4 platforms (iOS, simulator, macOS, Catalyst) on Xcode 15.3 Fixes golang/go#66406 Fixes golang/go#66500 Change-Id: I8538989efe67cb0d2d0496087dcbeca923c3dffe GitHub-Last-Rev: 28dca85 GitHub-Pull-Request: #98 Reviewed-on: https://go-review.googlesource.com/c/mobile/+/574055 Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Reviewed-by: Hajime Hoshi <hajimehoshi@gmail.com> Auto-Submit: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Than McIntosh <thanm@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org>
This PR is being closed because golang.org/cl/574055 has been merged. |
…orm, fixing Xcode 15.3 compatibility issues This patch updates the framework generation code to follow the Apple spec for placing content: https://developer.apple.com/documentation/bundleresources/placing_content_in_a_bundle Previously, we setup the framework in MacOS format, and used symlinks to make it compatible with iOS format. This approach no longer works (it works locally in simulator, but causes signing issues when attempting to upload apps for distribution, or running on real hardware). We now setup the expected bundle format for each platform. Other benefits: - Thirds the size of the xcframework and resulting app binary when distributing the xcframework by zip (common for SPM and other formats). The symlinks resulted in duplicate files after zipping, which made it into the final app. - Set MinimumOSVersion, fixing SPM compatibility issue - Eliminates the blank Info.plist - Initial testing shows this also fixes golang/go#66406 (code signing issues) as a side effect of using the proper format Testing: - Tested all 4 platforms (iOS, simulator, macOS, Catalyst) on Xcode 15.3 Fixes golang/go#66406 Fixes golang/go#66500 Change-Id: I8538989efe67cb0d2d0496087dcbeca923c3dffe GitHub-Last-Rev: 28dca85 GitHub-Pull-Request: golang#98 Reviewed-on: https://go-review.googlesource.com/c/mobile/+/574055 Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Reviewed-by: Hajime Hoshi <hajimehoshi@gmail.com> Auto-Submit: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Than McIntosh <thanm@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org>
This patch updates the framework generation code to follow the Apple spec for placing content:
https://developer.apple.com/documentation/bundleresources/placing_content_in_a_bundle
Previously, we setup the framework in MacOS format, and used symlinks to make it compatible with iOS format. This approach no longer works (it works locally in simulator, but causes signing issues when attempting to upload apps for distribution, or running on real hardware). We now setup the expected bundle format for each platform.
Other benefits:
Testing:
Fixes golang/go#66406
Fixes golang/go#66500