From df54c734b3fe7b8b514e1b8adcbe88ec77b08e04 Mon Sep 17 00:00:00 2001 From: Titan Yuan Date: Fri, 27 Sep 2024 17:36:02 -0700 Subject: [PATCH 1/2] Add README for quick start on Mac --- README.md | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index fdca127d..ba0798ce 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,29 @@ ![Sim Salvo Animation](docs/images/sim_salvo_animation.gif) -# Getting started **developing** micromissiles-unity +# Quick Start + +We generate pre-built standalone binaries for Windows and Mac users from the `release` branch. These binaries are intended for non-development users who just want to run the application and modify a few configurations along the way. + +You can find the latest release [here](https://github.com/PisterLab/micromissiles-unity/releases/latest). + +## Windows + +## Mac + +1. Download the zip file for Darwin: `micromissiles--darwin.zip`. +2. Unzip the zip file. The zip file should contain a single app file. +3. Change the permission of the app file recursively by running: + ```bash + chmod -R +x micromissiles--StandaloneOSX.app + ``` +4. Open the app file. +5. If you get a warning that Apple cannot check the application for malicious software: + * Open `System Preferences`. + * Navigate to `Privacy & Security`. + * Click on `Open Anyway` to bypass Apple's developer check. + +# Development This guide will help you set up and run the project in development mode. You'll learn how to install Unity Hub, open the project, and navigate the main scene. @@ -19,7 +41,7 @@ This guide will help you set up and run the project in development mode. You'll ## Prerequisites -- A computer with internet access ;) +- A computer with internet access. - Administrative privileges to install software. - [Git](https://git-scm.com/downloads) installed on your system (optional, for cloning the repository). @@ -54,7 +76,7 @@ Alternatively, you can download the repository as a ZIP file and extract it to a - Navigate to the **"Projects"** tab. - Click on the **"ADD"** button. - Browse to the folder where you cloned or extracted the project. - - Select the folder containing the `Assets` folder and click **"Select Folder"**. + - Select the folder containing the `Assets` folder and click on **"Select Folder"**. 3. **Install the Required Unity Version**: - Unity Hub will detect if the project requires a Unity version that is not currently installed. @@ -65,7 +87,6 @@ Alternatively, you can download the repository as a ZIP file and extract it to a 4. **Open the Project**: - Once the required Unity version is installed, click on the project name in Unity Hub to open it. - ### 4. Open the Main Scene After the project opens in Unity: @@ -90,4 +111,4 @@ After the project opens in Unity: ## Additional Resources - [Keybinds and Controls](docs/Keybinds_and_Controls.md) -- [Simulation Configuration Guide](docs/Simulation_Config_Guide.md) \ No newline at end of file +- [Simulation Configuration Guide](docs/Simulation_Config_Guide.md) From 874f938ab599a1a75b09eb7a90cda1d1c2164430 Mon Sep 17 00:00:00 2001 From: Titan Yuan Date: Fri, 27 Sep 2024 18:01:17 -0700 Subject: [PATCH 2/2] Add release action --- .../workflows/{builder.yaml => build.yaml} | 30 +++++----- .github/workflows/release.yaml | 57 +++++++++++++++++++ README.md | 4 ++ RELEASE.md | 27 +++++++++ 4 files changed, 105 insertions(+), 13 deletions(-) rename .github/workflows/{builder.yaml => build.yaml} (55%) create mode 100644 .github/workflows/release.yaml create mode 100644 RELEASE.md diff --git a/.github/workflows/builder.yaml b/.github/workflows/build.yaml similarity index 55% rename from .github/workflows/builder.yaml rename to .github/workflows/build.yaml index e3c61903..543de2cf 100644 --- a/.github/workflows/builder.yaml +++ b/.github/workflows/build.yaml @@ -1,12 +1,9 @@ -name: Build project +name: Build on: - push: - branches: - - release - pull_request: - branches: - - release + push: + tags: + - 'v[0-9]+.[0-9]+.[0-9]+' jobs: buildForAllSupportedPlatforms: @@ -36,13 +33,20 @@ jobs: UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} with: - buildName: micromissiles-${{ github.run_number }}-${{ matrix.targetPlatform }} + buildName: micromissiles-${{ github.ref_name }}-${{ matrix.targetPlatform }} versioning: Semantic targetPlatform: ${{ matrix.targetPlatform }} - - name: Make build output readable and executable - run: | - sudo chmod -R +rx build/${{ matrix.targetPlatform }} - - uses: actions/upload-artifact@v3 + - if: matrix.targetPlatform == 'StandaloneWindows64' + run: cd build && sudo zip -r build-${{ matrix.targetPlatform }}.zip ${{ matrix.targetPlatform }} && cd - + - if: matrix.targetPlatform == 'StandaloneWindows64' + uses: actions/upload-artifact@v4 with: name: Build-${{ matrix.targetPlatform }} - path: build/${{ matrix.targetPlatform }} \ No newline at end of file + path: build/build-${{ matrix.targetPlatform }}.zip + - if: matrix.targetPlatform == 'StandaloneOSX' + run: sudo tar -czvf build-${{ matrix.targetPlatform }}.tar.gz -C build ${{ matrix.targetPlatform }} + - if: matrix.targetPlatform == 'StandaloneOSX' + uses: actions/upload-artifact@v4 + with: + name: Build-${{ matrix.targetPlatform }} + path: build/build-${{ matrix.targetPlatform }}.tar.gz diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml new file mode 100644 index 00000000..9c0a937f --- /dev/null +++ b/.github/workflows/release.yaml @@ -0,0 +1,57 @@ +name: Release + +on: + workflow_run: + workflows: [Build] + types: [completed] + push: + tags: v[0-9]+.[0-9]+.[0-9]+ + +jobs: + release: + name: Create release + runs-on: ubuntu-latest + if: ${{ github.event.workflow_run.conclusion == 'success' }} + steps: + - uses: actions/checkout@v4 + with: + ref: ${{ github.event.workflow_run.head_branch }} + fetch-depth: 0 + lfs: false + - name: Create release + id: create_release + uses: actions/create-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ github.event.workflow_run.head_branch }} + release_name: ${{ github.event.workflow_run.head_branch }} + body_path: RELEASE.md + draft: false + prerelease: false + - uses: actions/download-artifact@v4 + with: + path: build + merge-multiple: true + github-token: ${{ secrets.GITHUB_TOKEN }} + run-id: ${{ github.event.workflow_run.run_number }} + - run: ls -la * + - run: ls -la build/* + - name: Upload Windows release assets + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_name: micromissiles-${{ github.event.workflow_run.head_branch }}-windows_x86_64.zip + asset_path: build/build-StandaloneWindows64.zip + asset_content_type: application/zip + - name: Upload Darwin release assets + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_name: micromissiles-${{ github.event.workflow_run.head_branch }}-darwin.tar.gz + asset_path: build/build-StandaloneOSX.tar.gz + asset_content_type: application/gzip diff --git a/README.md b/README.md index ba0798ce..bc57e21a 100644 --- a/README.md +++ b/README.md @@ -10,6 +10,10 @@ You can find the latest release [here](https://github.com/PisterLab/micromissile ## Windows +1. Download the zip file for Windows: `micromissiles--windows_x86_64.zip`. +2. Unzip the zip file. The zip file should contain a single directory called `micromissiles--windows_x86_64`. +3. Run `micromissiles--StandaloneWindows64.exe`. + ## Mac 1. Download the zip file for Darwin: `micromissiles--darwin.zip`. diff --git a/RELEASE.md b/RELEASE.md new file mode 100644 index 00000000..0fe4cb93 --- /dev/null +++ b/RELEASE.md @@ -0,0 +1,27 @@ +# micromissiles-unity + +## Build ${{ github.event.workflow_run.head_branch }} + +## Instructions + +Download and extract the archive corresponding to your platform (Windows or Mac) from the binaries listed below. + +## Windows + +1. Download the zip file for Windows: `micromissiles-${{ github.event.workflow_run.head_branch }}-windows_x86_64.zip`. +2. Unzip the zip file. The zip file should contain a single directory called `micromissiles-${{ github.event.workflow_run.head_branch }}-windows_x86_64`. +3. Run `micromissiles--StandaloneWindows64.exe`. + +## Mac + +1. Download the zip file for Darwin: `micromissiles-${{ github.event.workflow_run.head_branch }}-darwin.zip`. +2. Unzip the zip file. The zip file should contain a single app file. +3. Change the permission of the app file recursively by running: + ```bash + chmod -R +x micromissiles--StandaloneOSX.app + ``` +4. Open the app file. +5. If you get a warning that Apple cannot check the application for malicious software: + * Open `System Preferences`. + * Navigate to `Privacy & Security`. + * Click on `Open Anyway` to bypass Apple's developer check.