fix(build): upgrade cargo-dist

This commit is contained in:
Harsh Shandilya 2023-11-03 02:10:20 +05:30
parent f8ee42d036
commit 8db8c0fa35
No known key found for this signature in database
3 changed files with 377 additions and 117 deletions

View file

@ -4,188 +4,202 @@
# CI that: # CI that:
# #
# * checks for a Git Tag that looks like a release # * checks for a Git Tag that looks like a release
# * creates a Github Release™ and fills in its text # * builds artifacts with cargo-dist (archives, installers, hashes)
# * builds artifacts with cargo-dist (executable-zips, installers) # * uploads those artifacts to temporary workflow zip
# * uploads those artifacts to the Github Release™ # * on success, uploads the artifacts to a Github Release™
# #
# Note that the Github Release™ will be created before the artifacts, # Note that the Github Release™ will be created with a generated
# so there will be a few minutes where the release has no artifacts # title/body based on your changelogs.
# and then they will slowly trickle in, possibly failing. To make
# this more pleasant we mark the release as a "draft" until all
# artifacts have been successfully uploaded. This allows you to
# choose what to do with partial successes and avoids spamming
# anyone with notifications before the release is actually ready.
name: Release name: Release
permissions: permissions:
contents: write contents: write
# This task will run whenever you push a git tag that looks like a version # This task will run whenever you push a git tag that looks like a version
# like "v1", "v1.2.0", "v0.1.0-prerelease01", "my-app-v1.0.0", etc. # like "1.0.0", "v0.1.0-prerelease.1", "my-app/0.1.0", "releases/v1.0.0", etc.
# The version will be roughly parsed as ({PACKAGE_NAME}-)?v{VERSION}, where # Various formats will be parsed into a VERSION and an optional PACKAGE_NAME, where
# PACKAGE_NAME must be the name of a Cargo package in your workspace, and VERSION # PACKAGE_NAME must be the name of a Cargo package in your workspace, and VERSION
# must be a Cargo-style SemVer Version. # must be a Cargo-style SemVer Version (must have at least major.minor.patch).
# #
# If PACKAGE_NAME is specified, then we will create a Github Release™ for that # If PACKAGE_NAME is specified, then the release will be for that
# package (erroring out if it doesn't have the given version or isn't cargo-dist-able). # package (erroring out if it doesn't have the given version or isn't cargo-dist-able).
# #
# If PACKAGE_NAME isn't specified, then we will create a Github Release™ for all # If PACKAGE_NAME isn't specified, then the release will be for all
# (cargo-dist-able) packages in the workspace with that version (this is mode is # (cargo-dist-able) packages in the workspace with that version (this mode is
# intended for workspaces with only one dist-able package, or with all dist-able # intended for workspaces with only one dist-able package, or with all dist-able
# packages versioned/released in lockstep). # packages versioned/released in lockstep).
# #
# If you push multiple tags at once, separate instances of this workflow will # If you push multiple tags at once, separate instances of this workflow will
# spin up, creating an independent Github Release™ for each one. # spin up, creating an independent Github Release™ for each one. However Github
# will hard limit this to 3 tags per commit, as it will assume more tags is a
# mistake.
# #
# If there's a prerelease-style suffix to the version then the Github Release™ # If there's a prerelease-style suffix to the version, then the Github Release™
# will be marked as a prerelease. # will be marked as a prerelease.
on: on:
push: push:
tags: tags:
- '*-?v[0-9]+*' - '**[0-9]+.[0-9]+.[0-9]+*'
pull_request:
jobs: jobs:
# Create the Github Release™ so the packages have something to be uploaded to # Run 'cargo dist plan' to determine what tasks we need to do
create-release: plan:
runs-on: ubuntu-latest runs-on: ubuntu-latest
outputs: outputs:
has-releases: ${{ steps.create-release.outputs.has-releases }} val: ${{ steps.plan.outputs.manifest }}
releases: ${{ steps.create-release.outputs.releases }} tag: ${{ !github.event.pull_request && github.ref_name || '' }}
tag-flag: ${{ !github.event.pull_request && format('--tag={0}', github.ref_name) || '' }}
publishing: ${{ !github.event.pull_request }}
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps: steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- name: Install cargo-dist - name: Install cargo-dist
run: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.sh | sh" run: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.4.0/cargo-dist-installer.sh | sh"
- id: create-release - id: plan
run: | run: |
cargo dist plan --tag=${{ github.ref_name }} --output-format=json > dist-manifest.json cargo dist plan ${{ !github.event.pull_request && format('--tag={0}', github.ref_name) || '' }} --output-format=json > dist-manifest.json
echo "dist plan ran successfully" echo "cargo dist plan ran successfully"
cat dist-manifest.json cat dist-manifest.json
echo "manifest=$(jq -c "." dist-manifest.json)" >> "$GITHUB_OUTPUT"
# Create the Github Release™ based on what cargo-dist thinks it should be - name: "Upload dist-manifest.json"
ANNOUNCEMENT_TITLE=$(jq --raw-output ".announcement_title" dist-manifest.json) uses: actions/upload-artifact@v3
IS_PRERELEASE=$(jq --raw-output ".announcement_is_prerelease" dist-manifest.json) with:
jq --raw-output ".announcement_github_body" dist-manifest.json > new_dist_announcement.md name: artifacts
gh release create ${{ github.ref_name }} --draft --prerelease="$IS_PRERELEASE" --title="$ANNOUNCEMENT_TITLE" --notes-file=new_dist_announcement.md path: dist-manifest.json
echo "created announcement!"
# Upload the manifest to the Github Release™
gh release upload ${{ github.ref_name }} dist-manifest.json
echo "uploaded manifest!"
# Disable all the upload-artifacts tasks if we have no actual releases
HAS_RELEASES=$(jq --raw-output ".releases != null" dist-manifest.json)
echo "has-releases=$HAS_RELEASES" >> "$GITHUB_OUTPUT"
echo "releases=$(jq --compact-output ".releases" dist-manifest.json)" >> "$GITHUB_OUTPUT"
# Build and packages all the platform-specific things # Build and packages all the platform-specific things
upload-local-artifacts: upload-local-artifacts:
# Let the initial task tell us to not run (currently very blunt) # Let the initial task tell us to not run (currently very blunt)
needs: create-release needs: plan
if: ${{ needs.create-release.outputs.has-releases == 'true' }} if: ${{ fromJson(needs.plan.outputs.val).releases != null && (needs.plan.outputs.publishing == 'true' || fromJson(needs.plan.outputs.val).ci.github.pr_run_mode == 'upload') }}
strategy: strategy:
fail-fast: false fail-fast: false
matrix: # Target platforms/runners are computed by cargo-dist in create-release.
# For these target platforms # Each member of the matrix has the following arguments:
include: #
- os: "macos-11" # - runner: the github runner
dist-args: "--artifacts=local --target=aarch64-apple-darwin" # - dist-args: cli flags to pass to cargo dist
install-dist: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.sh | sh" # - install-dist: expression to run to install cargo-dist on the runner
- os: "macos-11" #
dist-args: "--artifacts=local --target=x86_64-apple-darwin" # Typically there will be:
install-dist: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.sh | sh" # - 1 "global" task that builds universal installers
- os: "windows-2019" # - N "local" tasks that build each platform's binaries and platform-specific installers
dist-args: "--artifacts=local --target=x86_64-pc-windows-msvc" matrix: ${{ fromJson(needs.plan.outputs.val).ci.github.artifacts_matrix }}
install-dist: "irm https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.ps1 | iex" runs-on: ${{ matrix.runner }}
- os: "ubuntu-20.04"
dist-args: "--artifacts=local --target=x86_64-unknown-linux-gnu"
install-dist: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.sh | sh"
runs-on: ${{ matrix.os }}
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
BUILD_MANIFEST_NAME: target/distrib/${{ join(matrix.targets, '-') }}-dist-manifest.json
steps: steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- uses: swatinem/rust-cache@v2
- name: Install cargo-dist - name: Install cargo-dist
run: ${{ matrix.install-dist }} run: ${{ matrix.install_dist }}
- name: Run cargo-dist - name: Install dependencies
# This logic is a bit janky because it's trying to be a polyglot between run: |
# powershell and bash since this will run on windows, macos, and linux! ${{ matrix.packages_install }}
# The two platforms don't agree on how to talk about env vars but they - name: Build artifacts
# do agree on 'cat' and '$()' so we use that to marshal values between commands.
run: | run: |
# Actually do builds and make zips and whatnot # Actually do builds and make zips and whatnot
cargo dist build --tag=${{ github.ref_name }} --output-format=json ${{ matrix.dist-args }} > dist-manifest.json cargo dist build ${{ needs.plan.outputs.tag-flag }} --print=linkage --output-format=json ${{ matrix.dist_args }} > dist-manifest.json
echo "dist ran successfully" echo "cargo dist ran successfully"
cat dist-manifest.json - id: cargo-dist
name: Post-build
# We force bash here just because github makes it really hard to get values up
# to "real" actions without writing to env-vars, and writing to env-vars has
# inconsistent syntax between shell and powershell.
shell: bash
run: |
# Parse out what we just built and upload it to the Github Release™ # Parse out what we just built and upload it to the Github Release™
jq --raw-output ".artifacts[]?.path | select( . != null )" dist-manifest.json > uploads.txt echo "paths<<EOF" >> "$GITHUB_OUTPUT"
echo "uploading..." jq --raw-output ".artifacts[]?.path | select( . != null )" dist-manifest.json >> "$GITHUB_OUTPUT"
cat uploads.txt echo "EOF" >> "$GITHUB_OUTPUT"
gh release upload ${{ github.ref_name }} $(cat uploads.txt)
echo "uploaded!"
# Build and packages all the platform-agnostic(ish) things cp dist-manifest.json "$BUILD_MANIFEST_NAME"
- name: "Upload artifacts"
uses: actions/upload-artifact@v3
with:
name: artifacts
path: |
${{ steps.cargo-dist.outputs.paths }}
${{ env.BUILD_MANIFEST_NAME }}
# Build and package all the platform-agnostic(ish) things
upload-global-artifacts: upload-global-artifacts:
needs: upload-local-artifacts needs: [plan, upload-local-artifacts]
runs-on: "ubuntu-22.04" runs-on: "ubuntu-20.04"
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps: steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- name: Install cargo-dist - name: Install cargo-dist
run: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.2.0-prerelease.5/cargo-dist-installer.sh | sh" run: "curl --proto '=https' --tlsv1.2 -LsSf https://github.com/axodotdev/cargo-dist/releases/download/v0.4.0/cargo-dist-installer.sh | sh"
# Get all the local artifacts for the global tasks to use (for e.g. checksums) # Get all the local artifacts for the global tasks to use (for e.g. checksums)
- name: Fetch local artifacts - name: Fetch local artifacts
uses: actions/download-artifact@v3
with:
name: artifacts
path: target/distrib/
- id: cargo-dist
shell: bash
run: | run: |
gh release download ${{ github.ref_name }} --dir target/distrib/ cargo dist build ${{ needs.plan.outputs.tag-flag }} --output-format=json "--artifacts=global" > dist-manifest.json
- name: Run cargo-dist echo "cargo dist ran successfully"
# This logic is a bit janky because it's trying to be a polyglot between
# powershell and bash since this will run on windows, macos, and linux!
# The two platforms don't agree on how to talk about env vars but they
# do agree on 'cat' and '$()' so we use that to marshal values between commands.
run: |
cargo dist build --tag=${{ github.ref_name }} --output-format=json "--artifacts=global" > dist-manifest.json
echo "dist ran successfully"
cat dist-manifest.json
# Parse out what we just built and upload it to the Github Release™ # Parse out what we just built and upload it to the Github Release™
jq --raw-output ".artifacts[]?.path | select( . != null )" dist-manifest.json > uploads.txt echo "paths<<EOF" >> "$GITHUB_OUTPUT"
echo "uploading..." jq --raw-output ".artifacts[]?.path | select( . != null )" dist-manifest.json >> "$GITHUB_OUTPUT"
cat uploads.txt echo "EOF" >> "$GITHUB_OUTPUT"
gh release upload ${{ github.ref_name }} $(cat uploads.txt) - name: "Upload artifacts"
echo "uploaded!" uses: actions/upload-artifact@v3
with:
name: artifacts
path: ${{ steps.cargo-dist.outputs.paths }}
upload-homebrew-formula: should-publish:
needs: [create-release, upload-global-artifacts] needs:
runs-on: "ubuntu-22.04" - plan
- upload-local-artifacts
- upload-global-artifacts
if: ${{ needs.plan.outputs.publishing == 'true' }}
runs-on: ubuntu-latest
steps:
- name: print tag
run: echo "ok we're publishing!"
publish-homebrew-formula:
needs: [plan, should-publish]
runs-on: "ubuntu-20.04"
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
RELEASES: ${{ needs.create-release.outputs.releases }} PLAN: ${{ needs.plan.outputs.val }}
GITHUB_USER: "axo bot" GITHUB_USER: "axo bot"
GITHUB_EMAIL: "admin+bot@axo.dev" GITHUB_EMAIL: "admin+bot@axo.dev"
if: ${{ !fromJson(needs.plan.outputs.val).announcement_is_prerelease || fromJson(needs.plan.outputs.val).publish_prereleases }}
steps: steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/checkout@v4
with: with:
repository: "msfjarvis/homebrew-tap" repository: "msfjarvis/homebrew-tap"
token: ${{ secrets.HOMEBREW_TAP_TOKEN }} token: ${{ secrets.HOMEBREW_TAP_TOKEN }}
# So we have access to the formula # So we have access to the formula
- name: Fetch local artifacts - name: Fetch local artifacts
run: | uses: actions/download-artifact@v3
gh release download ${{ github.ref_name }} --dir Formula --repo ${GITHUB_REPOSITORY} --clobber with:
name: artifacts
path: Formula/
- name: Commit formula files - name: Commit formula files
run: | run: |
git config --global user.name "${GITHUB_USER}" git config --global user.name "${GITHUB_USER}"
git config --global user.email "${GITHUB_EMAIL}" git config --global user.email "${GITHUB_EMAIL}"
for release in $(echo "$RELEASES" | jq --compact-output '.[]'); do for release in $(echo "$PLAN" | jq --compact-output '.releases[]'); do
name=$(echo "$release" | jq .app_name --raw-output) name=$(echo "$release" | jq .app_name --raw-output)
version=$(echo "$release" | jq .app_version --raw-output) version=$(echo "$release" | jq .app_version --raw-output)
@ -194,18 +208,30 @@ jobs:
done done
git push git push
# Mark the Github Release™ as a non-draft now that everything has succeeded! # Create a Github Release with all the results once everything is done
publish-release: publish-release:
# Only run after all the other tasks, but it's ok if upload-artifacts was skipped needs: [plan, should-publish]
needs: [create-release, upload-local-artifacts, upload-global-artifacts]
if: ${{ always() && needs.create-release.result == 'success' && (needs.upload-local-artifacts.result == 'skipped' || needs.upload-local-artifacts.result == 'success') && (needs.upload-global-artifacts.result == 'skipped' || needs.upload-global-artifacts.result == 'success') }}
runs-on: ubuntu-latest runs-on: ubuntu-latest
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps: steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- name: mark release as non-draft - name: "Download artifacts"
uses: actions/download-artifact@v3
with:
name: artifacts
path: artifacts
- name: Cleanup
run: | run: |
gh release edit ${{ github.ref_name }} --draft=false # Remove the granular manifests
rm artifacts/*-dist-manifest.json
- name: Create Release
uses: ncipollo/release-action@v1
with:
tag: ${{ needs.plan.outputs.tag }}
name: ${{ fromJson(needs.plan.outputs.val).announcement_title }}
body: ${{ fromJson(needs.plan.outputs.val).announcement_github_body }}
prerelease: ${{ fromJson(needs.plan.outputs.val).announcement_is_prerelease }}
artifacts: "artifacts/*"

View file

@ -14,6 +14,10 @@ keywords = ["git", "snapshot", "backup", "restore"]
readme = "README.md" readme = "README.md"
include = ["src/**/*", "LICENSE-*", "README.md"] include = ["src/**/*", "LICENSE-*", "README.md"]
[package.metadata.wix]
upgrade-guid = "90907703-6CAD-4F13-AB11-D03BF51966EC"
path-guid = "2995A4B3-1534-48CC-9D44-62713E5411B2"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies] [dependencies]
@ -38,14 +42,16 @@ lto = "thin"
# Config for 'cargo dist' # Config for 'cargo dist'
[workspace.metadata.dist] [workspace.metadata.dist]
# The preferred cargo-dist version to use in CI (Cargo.toml SemVer syntax) # The preferred cargo-dist version to use in CI (Cargo.toml SemVer syntax)
cargo-dist-version = "0.2.0-prerelease.5" cargo-dist-version = "0.4.0"
# CI backends to support (see 'cargo dist generate-ci') # CI backends to support
ci = ["github"] ci = ["github"]
# The installers to generate for each app # The installers to generate for each app
installers = ["shell", "powershell", "homebrew"] installers = ["shell", "powershell", "homebrew", "msi"]
# Target platforms to build apps for (Rust target-triple syntax) # Target platforms to build apps for (Rust target-triple syntax)
targets = ["x86_64-unknown-linux-gnu", "x86_64-apple-darwin", "x86_64-pc-windows-msvc", "aarch64-apple-darwin"] targets = ["x86_64-unknown-linux-gnu", "aarch64-apple-darwin", "x86_64-apple-darwin", "x86_64-unknown-linux-musl", "x86_64-pc-windows-msvc"]
# A GitHub repo to push Homebrew formulas to # A GitHub repo to push Homebrew formulas to
tap = "msfjarvis/homebrew-tap" tap = "msfjarvis/homebrew-tap"
# Publish jobs to run in CI # Publish jobs to run in CI
publish-jobs = ["homebrew"] publish-jobs = ["homebrew"]
# Publish jobs to run in CI
pr-run-mode = "plan"

228
wix/main.wxs Normal file
View file

@ -0,0 +1,228 @@
<?xml version='1.0' encoding='windows-1252'?>
<!--
Copyright (C) 2017 Christopher R. Field.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<!--
The "cargo wix" subcommand provides a variety of predefined variables available
for customization of this template. The values for each variable are set at
installer creation time. The following variables are available:
TargetTriple = The rustc target triple name.
TargetEnv = The rustc target environment. This is typically either
"msvc" or "gnu" depending on the toolchain downloaded and
installed.
TargetVendor = The rustc target vendor. This is typically "pc", but Rust
does support other vendors, like "uwp".
CargoTargetBinDir = The complete path to the directory containing the
binaries (exes) to include. The default would be
"target\release\". If an explicit rustc target triple is
used, i.e. cross-compiling, then the default path would
be "target\<CARGO_TARGET>\<CARGO_PROFILE>",
where "<CARGO_TARGET>" is replaced with the "CargoTarget"
variable value and "<CARGO_PROFILE>" is replaced with the
value from the "CargoProfile" variable. This can also
be overriden manually with tne "target-bin-dir" flag.
CargoTargetDir = The path to the directory for the build artifacts, i.e.
"target".
CargoProfile = The cargo profile used to build the binaries
(usually "debug" or "release").
Version = The version for the installer. The default is the
"Major.Minor.Fix" semantic versioning number of the Rust
package.
-->
<!--
Please do not remove these pre-processor If-Else blocks. These are used with
the `cargo wix` subcommand to automatically determine the installation
destination for 32-bit versus 64-bit installers. Removal of these lines will
cause installation errors.
-->
<?if $(sys.BUILDARCH) = x64 or $(sys.BUILDARCH) = arm64 ?>
<?define PlatformProgramFilesFolder = "ProgramFiles64Folder" ?>
<?else ?>
<?define PlatformProgramFilesFolder = "ProgramFilesFolder" ?>
<?endif ?>
<Wix xmlns='http://schemas.microsoft.com/wix/2006/wi'>
<Product
Id='*'
Name='gitice'
UpgradeCode='90907703-6CAD-4F13-AB11-D03BF51966EC'
Manufacturer='Harsh Shandilya; Amogh Lele'
Language='1033'
Codepage='1252'
Version='$(var.Version)'>
<Package Id='*'
Keywords='Installer'
Description='Freeze your local git repositories for easy restoration'
Manufacturer='Harsh Shandilya; Amogh Lele'
InstallerVersion='450'
Languages='1033'
Compressed='yes'
InstallScope='perMachine'
SummaryCodepage='1252'
/>
<MajorUpgrade
Schedule='afterInstallInitialize'
DowngradeErrorMessage='A newer version of [ProductName] is already installed. Setup will now exit.'/>
<Media Id='1' Cabinet='media1.cab' EmbedCab='yes' DiskPrompt='CD-ROM #1'/>
<Property Id='DiskPrompt' Value='gitice Installation'/>
<Directory Id='TARGETDIR' Name='SourceDir'>
<Directory Id='$(var.PlatformProgramFilesFolder)' Name='PFiles'>
<Directory Id='APPLICATIONFOLDER' Name='gitice'>
<!--
Enabling the license sidecar file in the installer is a four step process:
1. Uncomment the `Component` tag and its contents.
2. Change the value for the `Source` attribute in the `File` tag to a path
to the file that should be included as the license sidecar file. The path
can, and probably should be, relative to this file.
3. Change the value for the `Name` attribute in the `File` tag to the
desired name for the file when it is installed alongside the `bin` folder
in the installation directory. This can be omitted if the desired name is
the same as the file name.
4. Uncomment the `ComponentRef` tag with the Id attribute value of "License"
further down in this file.
-->
<!--
<Component Id='License' Guid='*'>
<File Id='LicenseFile' Name='ChangeMe' DiskId='1' Source='C:\Path\To\File' KeyPath='yes'/>
</Component>
-->
<Directory Id='Bin' Name='bin'>
<Component Id='Path' Guid='2995A4B3-1534-48CC-9D44-62713E5411B2' KeyPath='yes'>
<Environment
Id='PATH'
Name='PATH'
Value='[Bin]'
Permanent='no'
Part='last'
Action='set'
System='yes'/>
</Component>
<Component Id='binary0' Guid='*'>
<File
Id='exe0'
Name='gitice.exe'
DiskId='1'
Source='$(var.CargoTargetBinDir)\gitice.exe'
KeyPath='yes'/>
</Component>
</Directory>
</Directory>
</Directory>
</Directory>
<Feature
Id='Binaries'
Title='Application'
Description='Installs all binaries and the license.'
Level='1'
ConfigurableDirectory='APPLICATIONFOLDER'
AllowAdvertise='no'
Display='expand'
Absent='disallow'>
<!--
Uncomment the following `ComponentRef` tag to add the license
sidecar file to the installer.
-->
<!--<ComponentRef Id='License'/>-->
<ComponentRef Id='binary0'/>
<Feature
Id='Environment'
Title='PATH Environment Variable'
Description='Add the install location of the [ProductName] executable to the PATH system environment variable. This allows the [ProductName] executable to be called from any location.'
Level='1'
Absent='allow'>
<ComponentRef Id='Path'/>
</Feature>
</Feature>
<SetProperty Id='ARPINSTALLLOCATION' Value='[APPLICATIONFOLDER]' After='CostFinalize'/>
<!--
Uncomment the following `Icon` and `Property` tags to change the product icon.
The product icon is the graphic that appears in the Add/Remove
Programs control panel for the application.
-->
<!--<Icon Id='ProductICO' SourceFile='wix\Product.ico'/>-->
<!--<Property Id='ARPPRODUCTICON' Value='ProductICO' />-->
<Property Id='ARPHELPLINK' Value='https://github.com/msfjarvis/gitice'/>
<UI>
<UIRef Id='WixUI_FeatureTree'/>
<!--
Enabling the EULA dialog in the installer is a three step process:
1. Comment out or remove the two `Publish` tags that follow the
`WixVariable` tag.
2. Uncomment the `<WixVariable Id='WixUILicenseRtf' Value='Path\to\Eula.rft'>` tag futher down
3. Replace the `Value` attribute of the `WixVariable` tag with
the path to a RTF file that will be used as the EULA and
displayed in the license agreement dialog.
-->
<Publish Dialog='WelcomeDlg' Control='Next' Event='NewDialog' Value='CustomizeDlg' Order='99'>1</Publish>
<Publish Dialog='CustomizeDlg' Control='Back' Event='NewDialog' Value='WelcomeDlg' Order='99'>1</Publish>
</UI>
<!--
Enabling the EULA dialog in the installer requires uncommenting
the following `WixUILicenseRTF` tag and changing the `Value`
attribute.
-->
<!-- <WixVariable Id='WixUILicenseRtf' Value='Relative\Path\to\Eula.rtf'/> -->
<!--
Uncomment the next `WixVariable` tag to customize the installer's
Graphical User Interface (GUI) and add a custom banner image across
the top of each screen. See the WiX Toolset documentation for details
about customization.
The banner BMP dimensions are 493 x 58 pixels.
-->
<!--<WixVariable Id='WixUIBannerBmp' Value='wix\Banner.bmp'/>-->
<!--
Uncomment the next `WixVariable` tag to customize the installer's
Graphical User Interface (GUI) and add a custom image to the first
dialog, or screen. See the WiX Toolset documentation for details about
customization.
The dialog BMP dimensions are 493 x 312 pixels.
-->
<!--<WixVariable Id='WixUIDialogBmp' Value='wix\Dialog.bmp'/>-->
</Product>
</Wix>