Skip to content
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

Add darwin universal build and package #3902

Merged
merged 3 commits into from
Nov 23, 2024

Conversation

ansxuman
Copy link

@ansxuman ansxuman commented Nov 22, 2024

Description

Added support for darwin universal build and package

Type of change

Please select the option that is relevant.

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • This change requires a documentation update

How Has This Been Tested?

Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration using wails doctor.

  • Windows
  • macOS
  • Linux

If you checked Linux, please specify the distro and version.

Test Configuration

Please paste the output of wails3 doctor. If you are unable to run this command, please describe your environment in as much detail as possible.

# System
┌────────────────────────────┐
| Name          | MacOS      |
| Version       | 15.1       |
| ID            | 24B83      |
| Branding      | MacOS 15.1 |
| Platform      | darwin     |
| Architecture  | arm64      |
| Apple Silicon | true       |
| CPU           | Apple M1   |
| CPU           | Unknown    |
| GPU           | Unknown    |
| Memory        | Unknown    |
└────────────────────────────┘

# Build Environment
┌────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
| Wails CLI      | v3.0.0-alpha.7                                                                                                            |
| Go Version     | go1.23.2                                                                                                                  |
| Revision       | 5f1b1efc66d6286b1dcf54a51b33bdcdfa0b3c3b                                                                                  |
| Modified       | true                                                                                                                      |
| -buildmode     | exe                                                                                                                       |
| -compiler      | gc                                                                                                                        |
| CGO_CFLAGS     |                                                                                                                           |
| CGO_CPPFLAGS   |                                                                                                                           |
| CGO_CXXFLAGS   |                                                                                                                           |
| CGO_ENABLED    | 1                                                                                                                         |
| CGO_LDFLAGS    |                                                                                                                           |
| DefaultGODEBUG | asynctimerchan=1,gotypesalias=0,httpservecontentkeepheaders=1,tls3des=1,tlskyber=0,x509keypairleaf=0,x509negativeserial=1 |
| GOARCH         | arm64                                                                                                                     |
| GOARM64        | v8.0                                                                                                                      |
| GOOS           | darwin                                                                                                                    |
| vcs            | git                                                                                                                       |
| vcs.modified   | true                                                                                                                      |
| vcs.revision   | 5f1b1efc66d6286b1dcf54a51b33bdcdfa0b3c3b                                                                                  |
| vcs.time       | 2024-11-17T10:37:59Z                                                                                                      |
└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘

# Dependencies
┌────────────────────────────────────────────────────────────────────────┐
| Xcode cli tools | 2409                                                 |
| npm             | 10.8.1                                               |
| *NSIS           | Not Installed. Install with `brew install makensis`. |
└─────────────────────── * - Optional Dependency ────────────────────────┘

Checklist:

  • I have updated website/src/pages/changelog.mdx with details of this PR
  • My code follows the general coding style of this project
  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • I have made corresponding changes to the documentation
  • My changes generate no new warnings
  • I have added tests that prove my fix is effective or that my feature works
  • New and existing unit tests pass locally with my changes

Summary by CodeRabbit

  • New Features

    • Support for Darwin universal builds and packages.
    • New commands for asset updates and runtime generation.
    • Enhanced window positioning options.
    • New templates for SvelteKit.
  • Bug Fixes

    • Resolved issues with AMD64 AppImage compilation and DPI scaling on Windows.
    • Improved handling of window events.
  • Documentation

    • Updated changelog reflecting new features, changes, and fixes.

Copy link
Contributor

coderabbitai bot commented Nov 22, 2024

Walkthrough

The pull request updates the changelog to reflect new features, changes, and bug fixes within the project, including support for Darwin universal builds, enhancements to documentation, and new SvelteKit templates. It introduces new commands for asset updates and runtime generation, modifies existing functionality, and corrects structural definitions. Additionally, it includes significant updates to version 3.0.0-alpha.7, emphasizing improved functionality and user experience across platforms.

Changes

File Path Change Summary
mkdocs-website/docs/en/changelog.md Updated changelog to include new features, changes, bug fixes, and version history.
v3/examples/file-association/Taskfile.yml Added tasks for building and packaging a universal binary for Darwin (macOS) systems.
v3/internal/templates/_common/Taskfile.tmpl.yml Added tasks for building and packaging a universal binary for Darwin (macOS) systems.

Possibly related PRs

Suggested reviewers

  • leaanthony

🐇 "In the meadow where changes bloom,
New features sprout, dispelling gloom.
With builds for Darwin, so bright and fair,
SvelteKit templates dance in the air.
Bugs are fixed, and joy is found,
In our project, progress abounds!" 🐇


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (4)
v3/examples/file-association/Taskfile.yml (1)

35-47: Add error handling and verification steps to the universal build process.

While the implementation follows the correct steps for creating a universal binary, it could benefit from additional robustness:

Consider applying these improvements:

 darwin:build:universal:
   summary: Builds darwin universal binary (arm64 + amd64)
   cmds:
     - task: darwin:build
       vars:
         ARCH: amd64
     - mv {{.BIN_DIR}}/{{.APP_NAME}} {{.BIN_DIR}}/{{.APP_NAME}}-amd64
     - task: darwin:build
       vars:
         ARCH: arm64
     - mv {{.BIN_DIR}}/{{.APP_NAME}} {{.BIN_DIR}}/{{.APP_NAME}}-arm64
     - lipo -create -output {{.BIN_DIR}}/{{.APP_NAME}} {{.BIN_DIR}}/{{.APP_NAME}}-amd64 {{.BIN_DIR}}/{{.APP_NAME}}-arm64
+    - lipo -verify_arch arm64 amd64 {{.BIN_DIR}}/{{.APP_NAME}}
     - rm {{.BIN_DIR}}/{{.APP_NAME}}-amd64 {{.BIN_DIR}}/{{.APP_NAME}}-arm64
+  status:
+    - test -f {{.BIN_DIR}}/{{.APP_NAME}}
mkdocs-website/docs/en/changelog.md (3)

21-21: Enhance the changelog entry with more details

While the entry correctly documents the new feature, it would be more helpful to users if it included:

  • Description of what "universal builds" means (e.g., support for both ARM64 and AMD64 architectures)
  • The new tasks added (darwin:build:universal and darwin:package:universal)
  • Benefits or use cases for this feature

Consider expanding the entry like this:

-Added Support for darwin universal builds and packages by [ansxuman](https://github.com/ansxuman) in [#3902](https://github.com/wailsapp/wails/pull/3902)
+Added Support for Darwin universal builds and packages (ARM64/AMD64) with new tasks `darwin:build:universal` and `darwin:package:universal`. This enables building applications that run natively on both Apple Silicon and Intel-based Macs. By [ansxuman](https://github.com/ansxuman) in [#3902](https://github.com/wailsapp/wails/pull/3902)

46-46: Add context to the build assets fix entry

The fix entry would be more valuable with additional context about what was broken and how it was fixed.

Consider expanding the entry like this:

-Fixed build assets update by @ansxuman in [#3901](https://github.com/wailsapp/wails/pull/3901)
+Fixed build assets update to correctly handle asset updates when using the new `wails3 update build-assets` command by @ansxuman in [#3901](https://github.com/wailsapp/wails/pull/3901)

PR links in changelog need to be updated

The changelog entry for PR #3902 is premature as the PR is still in an OPEN state and hasn't been merged yet. It should be removed from the changelog until the PR is merged.

🔗 Analysis chain

Line range hint 1-24: Documentation follows changelog standards

The changelog entries follow the Keep a Changelog format and properly categorize changes. The PR links and author attributions are consistent throughout.

Let's verify the PR links are valid:

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify PR links in the changelog
# Test: Check if PRs #3901 and #3902 exist and are accessible

gh pr view 3901
gh pr view 3902

Length of output: 14599

🧰 Tools
🪛 LanguageTool

[duplication] ~20-~20: Possible typo: you repeated a word
Context: ...erabilities. --> ## [Unreleased] ### Added - Added Support for darwin universal builds and...

(ENGLISH_WORD_REPEAT_RULE)

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 76e7654 and 8b7337c.

📒 Files selected for processing (2)
  • mkdocs-website/docs/en/changelog.md (2 hunks)
  • v3/examples/file-association/Taskfile.yml (1 hunks)
🔇 Additional comments (1)
v3/examples/file-association/Taskfile.yml (1)

49-54: Add output validation and improve task documentation.

The packaging task could benefit from additional documentation and validation steps:

Consider applying these improvements:

 darwin:package:universal:
-  summary: Packages darwin universal binary (arm64 + amd64)
+  summary: |
+    Packages darwin universal binary (arm64 + amd64)
+    Output: ./build/bin/MyApp.app
   deps:
     - darwin:build:universal
   cmds:
     - task: darwin:create:app:bundle
+    - codesign --verify --verbose ./build/bin/MyApp.app || true
+  status:
+    - test -d ./build/bin/MyApp.app

Let's verify the app bundle creation task exists:

@leaanthony
Copy link
Member

Thanks for opening this. Did you mean to add this to the file-association example or did you mean to have it in the default templates?

@ansxuman
Copy link
Author

Thanks for opening this. Did you mean to add this to the file-association example or did you mean to have it in the default templates?

I realized I missed pushing the changes for the default templates, thanks for catching that!

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (2)
v3/internal/templates/_common/Taskfile.tmpl.yml (2)

35-47: Consider adding error handling and environment checks

While the universal build task is well-structured, there are a few improvements that could make it more robust:

  1. The task should verify the availability of the lipo command before proceeding
  2. Consider adding error handling for failed intermediate builds
  3. The intermediate file cleanup could fail silently if files don't exist

Here's a suggested improvement:

  darwin:build:universal:
    summary: Builds darwin universal binary (arm64 + amd64)
+   preconditions:
+     - sh: command -v lipo
+       msg: "lipo command is required for universal builds"
    cmds:
      - task: darwin:build
        vars:
          ARCH: amd64
      - mv {{ "{{.BIN_DIR}}/{{.APP_NAME}}" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-amd64" }}
      - task: darwin:build
        vars:
          ARCH: arm64
      - mv {{ "{{.BIN_DIR}}/{{.APP_NAME}}" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-arm64" }}
      - lipo -create -output {{ "{{.BIN_DIR}}/{{.APP_NAME}}" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-amd64" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-arm64" }}
-     - rm {{ "{{.BIN_DIR}}/{{.APP_NAME}}-amd64" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-arm64" }}
+     - rm -f {{ "{{.BIN_DIR}}/{{.APP_NAME}}-amd64" }} {{ "{{.BIN_DIR}}/{{.APP_NAME}}-arm64" }}

34-54: Consider documenting the universal build feature

Since this is a new feature for v3 alpha, consider:

  1. Adding comments in the Taskfile explaining the universal build process
  2. Updating the project documentation to cover this new build capability
  3. Including example usage in the README or relevant docs

Consider adding these comments above the tasks:

+# Universal build tasks for Darwin (macOS)
+# Builds both arm64 and amd64 architectures and combines them using lipo
+# Requirements:
+# - lipo command (part of Xcode command line tools)
+# - Sufficient disk space for both architecture builds
  darwin:build:universal:
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 8b7337c and 43ad4e1.

📒 Files selected for processing (1)
  • v3/internal/templates/_common/Taskfile.tmpl.yml (1 hunks)
🔇 Additional comments (1)
v3/internal/templates/_common/Taskfile.tmpl.yml (1)

49-54: Verify the existence of dependent tasks

The task depends on darwin:create:app:bundle which should be defined in the included ./build/Taskfile.darwin.yml.

Let's verify the task dependencies:

✅ Verification successful

Dependencies verified and found to be correctly defined

The task dependencies are properly defined and implemented:

  • darwin:create:app:bundle task exists in the included darwin Taskfile (build/Taskfile.darwin.yml) as shown in the example implementation
  • darwin:build:universal task is defined in the same file and correctly builds both architectures
  • The task chain and implementation follows the expected pattern seen in the example
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check if the required darwin tasks exist in the included files

# Check for the darwin:create:app:bundle task
rg -l "darwin:create:app:bundle" build/Taskfile.darwin.yml

# Check for any potential naming inconsistencies
rg -l "create:app:bundle|create-app-bundle|createAppBundle" build/

Length of output: 240


Script:

#!/bin/bash
# Let's first check where the Taskfile is located and find related task files
fd -t f "Taskfile.*yml"

# Then search for the specific task names in all yml files
rg -l "darwin:create:app:bundle|darwin:build:universal" 

Length of output: 917


Script:

#!/bin/bash
# Let's check the content of both files to understand the task definitions
echo "=== Content of v3/internal/templates/_common/Taskfile.tmpl.yml ==="
cat v3/internal/templates/_common/Taskfile.tmpl.yml

echo -e "\n=== Content of v3/examples/file-association/Taskfile.yml ==="
cat v3/examples/file-association/Taskfile.yml

# Also check related darwin build files in these directories
echo -e "\n=== Checking darwin-related files in file-association example ==="
cat v3/examples/file-association/build/Taskfile.darwin.yml

Length of output: 4965

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants