Skip to content

https://github.com/masesgroup/NuReflector/issues/41#issuecomment-1793… #87

https://github.com/masesgroup/NuReflector/issues/41#issuecomment-1793…

https://github.com/masesgroup/NuReflector/issues/41#issuecomment-1793… #87

Workflow file for this run

# This is a basic workflow to help you get started with Actions
name: CI_BUILD
# Controls when the action will run. Triggers the workflow on push
# events but only for the master branch
on:
push:
# only trigger on branches, not on tags
branches: '**'
# This workflow contains two jobs called "check_changes", "build_windows"
jobs:
# Verify if a build is needed
check_changes:
name: Check changed files
outputs:
run_build_windows: ${{ steps.check_files.outputs.run_build_windows }}
runs-on: ubuntu-latest
steps:
- id: get_changed_files
uses: masesgroup/retrieve-changed-files@v3
with:
format: 'csv'
- id: check_files
run: |
mapfile -d ',' -t added_modified_files < <(printf '%s,' '${{ steps.get_changed_files.outputs.added_modified }}')
for added_modified_file in "${added_modified_files[@]}"; do
if [[ $added_modified_file == ".github/workflows/build.yaml"* ]]; then
echo "$added_modified_file is myself."
echo "run_build_windows=true" >> $GITHUB_OUTPUT
break
fi
if [[ $added_modified_file == ".github/workflows/packages.json"* ]]; then
echo "$added_modified_file: packages list changed."
echo "run_build_windows=true" >> $GITHUB_OUTPUT
break
fi
if [[ $added_modified_file == "src/"* ]]; then
echo "$added_modified_file file is under the directory 'src/'."
echo "run_build_windows=true" >> $GITHUB_OUTPUT
break
fi
done
- name: Get run_build_windows
run: echo "The selected run_build_windows is ${{ steps.check_files.outputs.run_build_windows }}"
# Now run "build_windows"
build_windows:
needs: check_changes
if: "always() && needs.check_changes.outputs.run_build_windows == 'true'"
# The type of runner that the job will run on
runs-on: windows-2022
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
- name: Check LongPathsEnabled
run: (Get-ItemProperty "HKLM:System\CurrentControlSet\Control\FileSystem").LongPathsEnabled
# Runs a set of commands using the runners shell
# Support longpaths
- name: Support long paths
run: git config --system core.longpaths true
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v4
with:
fetch-depth: '1'
submodules: 'true'
- name: Compile
run: dotnet build --no-incremental --configuration Release /p:Platform="Any CPU" src\net\NuReflector.sln
- uses: nuget/setup-nuget@v1
with:
nuget-version: '5.x'
- run: nuget pack src\net\NuReflectorCLI\NuReflectorCLI.nuspec -OutputDirectory .\bin
- name: Reflect and Build net6.0 Maven POM files
run: dotnet bin\net6.0\MASES.NuReflectorCLI.dll -PackagesFile .github\workflows\packages.json
- name: Reflect and Build net462 Maven POM files
run: .\bin\net462\MASES.NuReflectorCLI -PackagesFile .github\workflows\packages_net462.json
- name: Clear documentation folder
run: Remove-Item .\docs\* -Recurse -Force -Exclude _config.yml,CNAME
- run: dotnet tool update -g docfx
- name: Build documentation
run: |
cd src\documentation
docfx
- uses: actions/upload-artifact@v3
with:
name: NuReflector
path: .\bin\*nupkg
- name: Extract commit SHA
run: |
echo "GITHUB_COMMIT_MESSAGE=$(echo $GITHUB_SHA | cut -c 1-7)" >> $GITHUB_ENV
shell: bash
- name: Commit changes
if: ${{ github.repository_owner == 'masesgroup'}} #do not push any changes outside main repo
uses: EndBug/add-and-commit@v9
with:
author_name: github-actions
author_email: 41898282+github-actions[bot]@users.noreply.github.com
add: '.\docs\*.*'
message: Update documentation after commit ${{ env.GITHUB_COMMIT_MESSAGE }}
- name: Commit source changes
uses: EndBug/add-and-commit@v9
if: ${{ github.repository_owner == 'masesgroup'}} #do not push any changes outside main repo
with:
author_name: github-actions
author_email: 41898282+github-actions[bot]@users.noreply.github.com
add: '.\netreflected\*.*'
message: Update sources after commit ${{ env.GITHUB_COMMIT_MESSAGE }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}