From 27309815433e0a550902e835220d7d6a24822477 Mon Sep 17 00:00:00 2001 From: Melvin Wang Date: Tue, 18 Jun 2024 10:08:17 -0700 Subject: [PATCH 1/3] ci: pin LLVM version in pipelines (#175) --- .github/actions/winget-install/action.yml | 6 +++++- .github/workflows/build.yaml | 21 +++++++++++++++++-- .github/workflows/docs.yaml | 21 +++++++++++++++++-- .github/workflows/lint.yaml | 21 +++++++++++++++++-- .../workflows/local-development-makefile.yaml | 21 +++++++++++++++++-- .github/workflows/test.yaml | 21 +++++++++++++++++-- 6 files changed, 100 insertions(+), 11 deletions(-) diff --git a/.github/actions/winget-install/action.yml b/.github/actions/winget-install/action.yml index 0fc349c0..fbffe5b7 100644 --- a/.github/actions/winget-install/action.yml +++ b/.github/actions/winget-install/action.yml @@ -2,7 +2,7 @@ name: "Install Winget" description: "Install winget on windows runners since its not installed by default: https://github.com/actions/runner-images/issues/6472" inputs: GITHUB_TOKEN: - description: 'GitHub token to execute authenticated Github API requests (for higher rate limit)' + description: "GitHub token to execute authenticated Github API requests (for higher rate limit)" required: true runs: using: "composite" @@ -45,3 +45,7 @@ runs: Start-Sleep -Seconds 1 } Write-Output "Winget Version: $(winget --version)" + + - name: Install winget Powershell Module + shell: pwsh + run: Install-Module -Name Microsoft.WinGet.Client -Repository PSGallery -Force diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 2ceceffb..484406a2 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -19,6 +19,9 @@ jobs: wdk: - Microsoft.WindowsWDK.10.0.22621 # NI WDK + llvm: + - 17.0.6 + rust_toolchain: - stable - beta @@ -41,10 +44,24 @@ jobs: with: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Install LLVM ${{ matrix.llvm }} + run: | + if ((Get-WinGetPackage -Id LLVM -Source winget -MatchOption Equals).InstalledVersion -eq '${{ matrix.llvm }}') { + Write-Host "LLVM ${{ matrix.llvm }} is already installed." + } else { + Write-Host "Installing LLVM ${{ matrix.llvm }}..." + Install-WinGetPackage -Id LLVM.LLVM -Version ${{ matrix.llvm }} -Source winget -MatchOption Equals -Mode Silent -Force + } + clang --version + - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Rust Toolchain (${{ matrix.rust_toolchain }}) diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml index f55139cc..56f9412b 100644 --- a/.github/workflows/docs.yaml +++ b/.github/workflows/docs.yaml @@ -19,6 +19,9 @@ jobs: wdk: - Microsoft.WindowsWDK.10.0.22621 # NI WDK + llvm: + - 17.0.6 + rust_toolchain: - stable - beta @@ -41,10 +44,24 @@ jobs: with: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Install LLVM ${{ matrix.llvm }} + run: | + if ((Get-WinGetPackage -Id LLVM -Source winget -MatchOption Equals).InstalledVersion -eq '${{ matrix.llvm }}') { + Write-Host "LLVM ${{ matrix.llvm }} is already installed." + } else { + Write-Host "Installing LLVM ${{ matrix.llvm }}..." + Install-WinGetPackage -Id LLVM.LLVM -Version ${{ matrix.llvm }} -Source winget -MatchOption Equals -Mode Silent -Force + } + clang --version + - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Rust Toolchain (${{ matrix.rust_toolchain }}) diff --git a/.github/workflows/lint.yaml b/.github/workflows/lint.yaml index f17306ba..2783baf7 100644 --- a/.github/workflows/lint.yaml +++ b/.github/workflows/lint.yaml @@ -18,6 +18,9 @@ jobs: wdk: - Microsoft.WindowsWDK.10.0.22621 # NI WDK + llvm: + - 17.0.6 + rust_toolchain: - stable - beta @@ -40,10 +43,24 @@ jobs: with: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Install LLVM ${{ matrix.llvm }} + run: | + if ((Get-WinGetPackage -Id LLVM -Source winget -MatchOption Equals).InstalledVersion -eq '${{ matrix.llvm }}') { + Write-Host "LLVM ${{ matrix.llvm }} is already installed." + } else { + Write-Host "Installing LLVM ${{ matrix.llvm }}..." + Install-WinGetPackage -Id LLVM.LLVM -Version ${{ matrix.llvm }} -Source winget -MatchOption Equals -Mode Silent -Force + } + clang --version + - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Rust Toolchain (${{ matrix.rust_toolchain }}) diff --git a/.github/workflows/local-development-makefile.yaml b/.github/workflows/local-development-makefile.yaml index 354209c3..79cf5bad 100644 --- a/.github/workflows/local-development-makefile.yaml +++ b/.github/workflows/local-development-makefile.yaml @@ -19,6 +19,9 @@ jobs: wdk: - Microsoft.WindowsWDK.10.0.22621 # NI WDK + llvm: + - 17.0.6 + target_triple: - x86_64-pc-windows-msvc # - aarch64-pc-windows-msvc FIXME: find a way to validate the local makefile on aarch64 @@ -32,10 +35,24 @@ jobs: with: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Install LLVM ${{ matrix.llvm }} + run: | + if ((Get-WinGetPackage -Id LLVM -Source winget -MatchOption Equals).InstalledVersion -eq '${{ matrix.llvm }}') { + Write-Host "LLVM ${{ matrix.llvm }} is already installed." + } else { + Write-Host "Installing LLVM ${{ matrix.llvm }}..." + Install-WinGetPackage -Id LLVM.LLVM -Version ${{ matrix.llvm }} -Source winget -MatchOption Equals -Mode Silent -Force + } + clang --version + - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Nightly Rust Toolchain (${{ matrix.target_triple }}) diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 8e9074b4..6a1fab22 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -16,6 +16,9 @@ jobs: wdk: - Microsoft.WindowsWDK.10.0.22621 # NI WDK + llvm: + - 17.0.6 + rust_toolchain: - stable - beta @@ -38,10 +41,24 @@ jobs: with: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Install LLVM ${{ matrix.llvm }} + run: | + if ((Get-WinGetPackage -Id LLVM -Source winget -MatchOption Equals).InstalledVersion -eq '${{ matrix.llvm }}') { + Write-Host "LLVM ${{ matrix.llvm }} is already installed." + } else { + Write-Host "Installing LLVM ${{ matrix.llvm }}..." + Install-WinGetPackage -Id LLVM.LLVM -Version ${{ matrix.llvm }} -Source winget -MatchOption Equals -Mode Silent -Force + } + clang --version + - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Rust Toolchain (${{ matrix.rust_toolchain }}) From 8fd0c3fbf3cd1a2c804116b9026c286fbb49c597 Mon Sep 17 00:00:00 2001 From: Melvin Wang Date: Wed, 17 Jul 2024 15:38:30 -0700 Subject: [PATCH 2/3] ci: fix WDK installation in `Detect Unused Cargo Dependencies` (#181) --- .github/workflows/lint.yaml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/lint.yaml b/.github/workflows/lint.yaml index 2783baf7..fed0c2b9 100644 --- a/.github/workflows/lint.yaml +++ b/.github/workflows/lint.yaml @@ -96,8 +96,12 @@ jobs: - name: Install WDK (${{ matrix.wdk }}) run: | - if (!(winget list --exact --source winget --id ${{ matrix.wdk }})[-1].contains("${{ matrix.wdk }}")) { - winget install --disable-interactivity --source winget --exact --id ${{ matrix.wdk }} + if ((Get-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals).Id -eq '${{ matrix.wdk }}') { + Write-Host "${{ matrix.wdk }} is already installed. Attempting to update..." + Update-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force + } else { + Write-Host "Installing ${{ matrix.wdk }}..." + Install-WinGetPackage -Id ${{ matrix.wdk }} -Source winget -MatchOption Equals -Mode Silent -Force } - name: Install Rust Toolchain (Nightly) From 4ee4b8894215f43b748f5d229f7bbd88093f7986 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Victor?= <85838827+joaoviictorti@users.noreply.github.com> Date: Thu, 18 Jul 2024 00:01:46 -0300 Subject: [PATCH 3/3] Update README.md (#180) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: João Victor <85838827+joaoviictorti@users.noreply.github.com> Co-authored-by: Melvin Wang --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index afdef003..61d7e249 100644 --- a/README.md +++ b/README.md @@ -183,7 +183,7 @@ For release builds: To specify specific features: -`cargo make default --feature ` +`cargo make default --features ` To specify a specific rust toolchain: