From 17c60bca7ed1abb962af10c53794077e18cda963 Mon Sep 17 00:00:00 2001 From: VisruthSK Date: Wed, 24 Jun 2026 04:07:24 -0700 Subject: [PATCH] Added air setup --- .Rbuildignore | 1 + .github/workflows/format-suggest.yaml | 50 +++++++++++++++++++++++++++ air.toml | 0 3 files changed, 51 insertions(+) create mode 100644 .github/workflows/format-suggest.yaml create mode 100644 air.toml diff --git a/.Rbuildignore b/.Rbuildignore index 594cc2725..1f6f42bd8 100644 --- a/.Rbuildignore +++ b/.Rbuildignore @@ -13,3 +13,4 @@ ^vignettes/articles-online-only$ ^release-prep\.R$ ^\.vscode$ +^[.]?air[.]toml$ diff --git a/.github/workflows/format-suggest.yaml b/.github/workflows/format-suggest.yaml new file mode 100644 index 000000000..6bd6f4060 --- /dev/null +++ b/.github/workflows/format-suggest.yaml @@ -0,0 +1,50 @@ +# Workflow derived from https://github.com/posit-dev/setup-air/tree/main/examples + +on: + # Using `pull_request_target` over `pull_request` for elevated `GITHUB_TOKEN` + # privileges, otherwise we can't set `pull-requests: write` when the pull + # request comes from a fork, which is our main use case (external contributors). + # + # `pull_request_target` runs in the context of the target branch (`main`, usually), + # rather than in the context of the pull request like `pull_request` does. Due + # to this, we must explicitly checkout `ref: ${{ github.event.pull_request.head.sha }}`. + # This is typically frowned upon by GitHub, as it exposes you to potentially running + # untrusted code in a context where you have elevated privileges, but they explicitly + # call out the use case of reformatting and committing back / commenting on the PR + # as a situation that should be safe (because we aren't actually running the untrusted + # code, we are just treating it as passive data). + # https://securitylab.github.com/resources/github-actions-preventing-pwn-requests/ + pull_request_target: + +name: format-suggest.yaml + +jobs: + format-suggest: + name: format-suggest + runs-on: ubuntu-latest + + permissions: + contents: read + checks: write + issues: write + pull-requests: write + + steps: + - uses: actions/checkout@v7 + with: + ref: ${{ github.event.pull_request.head.sha }} + allow-unsafe-pr-checkout: true + persist-credentials: false + + - name: Install + uses: posit-dev/setup-air@v1 + + - name: Format + run: air format . + + - name: Suggest + uses: reviewdog/action-suggester@v1 + with: + level: error + fail_level: error + tool_name: air diff --git a/air.toml b/air.toml new file mode 100644 index 000000000..e69de29bb