staging-next 2025-01-06 #165990
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# This file was copied mostly from check-maintainers-sorted.yaml. | |
# NOTE: Formatting with the RFC-style nixfmt command is not yet stable. See | |
# https://github.com/NixOS/rfcs/pull/166. | |
# Because of this, this action is not yet enabled for all files -- only for | |
# those who have opted in. | |
name: Check that Nix files are formatted | |
on: | |
pull_request_target: | |
types: [opened, synchronize, reopened, edited] | |
permissions: {} | |
jobs: | |
get-merge-commit: | |
uses: ./.github/workflows/get-merge-commit.yml | |
nixos: | |
name: nixfmt-check | |
runs-on: ubuntu-24.04 | |
needs: get-merge-commit | |
if: "needs.get-merge-commit.outputs.mergedSha && !contains(github.event.pull_request.title, '[skip treewide]')" | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
ref: ${{ needs.get-merge-commit.outputs.mergedSha }} | |
# Fetches the merge commit and its parents | |
fetch-depth: 2 | |
- name: Checking out target branch | |
run: | | |
target=$(mktemp -d) | |
targetRev=$(git rev-parse HEAD^1) | |
git worktree add "$target" "$targetRev" | |
echo "targetRev=$targetRev" >> "$GITHUB_ENV" | |
echo "target=$target" >> "$GITHUB_ENV" | |
- name: Get Nixpkgs revision for nixfmt | |
run: | | |
# pin to a commit from nixpkgs-unstable to avoid e.g. building nixfmt | |
# from staging | |
# This should not be a URL, because it would allow PRs to run arbitrary code in CI! | |
rev=$(jq -r .rev ci/pinned-nixpkgs.json) | |
echo "url=https://github.com/NixOS/nixpkgs/archive/$rev.tar.gz" >> "$GITHUB_ENV" | |
- uses: cachix/install-nix-action@08dcb3a5e62fa31e2da3d490afc4176ef55ecd72 # v30 | |
with: | |
extra_nix_config: sandbox = true | |
nix_path: nixpkgs=${{ env.url }} | |
- name: Install nixfmt | |
run: "nix-env -f '<nixpkgs>' -iAP nixfmt-rfc-style" | |
- name: Check that Nix files are formatted according to the RFC style | |
run: | | |
unformattedFiles=() | |
# TODO: Make this more parallel | |
# Loop through all Nix files touched by the PR | |
while readarray -d '' -n 2 entry && (( ${#entry[@]} != 0 )); do | |
type=${entry[0]} | |
file=${entry[1]} | |
case $type in | |
A*) | |
source="" | |
dest=$file | |
;; | |
M*) | |
source=$file | |
dest=$file | |
;; | |
C*|R*) | |
source=$file | |
read -r -d '' dest | |
;; | |
*) | |
echo "Ignoring file $file with type $type" | |
continue | |
esac | |
# Ignore files that weren't already formatted | |
if [[ -n "$source" ]] && ! nixfmt --check ${{ env.target }}/"$source" 2>/dev/null; then | |
echo "Ignoring file $file because it's not formatted in the target commit" | |
elif ! nixfmt --check "$dest"; then | |
unformattedFiles+=("$dest") | |
fi | |
done < <(git diff -z --name-status ${{ env.targetRev }} -- '*.nix') | |
if (( "${#unformattedFiles[@]}" > 0 )); then | |
echo "Some new/changed Nix files are not properly formatted" | |
echo "Please format them using the Nixpkgs-specific \`nixfmt\` by going to the Nixpkgs root directory, running \`nix-shell\`, then:" | |
echo "nixfmt ${unformattedFiles[*]@Q}" | |
echo "Make sure your branch is up to date with master, rebase if not." | |
echo "If you're having trouble, please ping @NixOS/nix-formatting" | |
exit 1 | |
fi |