Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
| 3 | # Perform runfile initialization here so that child processes have a proper |
| 4 | # RUNFILES_DIR variable set. |
| 5 | |
| 6 | # --- begin runfiles.bash initialization v2 --- |
| 7 | # Copy-pasted from the Bazel Bash runfiles library v2. |
| 8 | set -uo pipefail; f=bazel_tools/tools/bash/runfiles/runfiles.bash |
| 9 | source "${RUNFILES_DIR:-/dev/null}/$f" 2>/dev/null || \ |
| 10 | source "$(grep -sm1 "^$f " "${RUNFILES_MANIFEST_FILE:-/dev/null}" | cut -f2- -d' ')" 2>/dev/null || \ |
| 11 | source "$0.runfiles/$f" 2>/dev/null || \ |
| 12 | source "$(grep -sm1 "^$f " "$0.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \ |
| 13 | source "$(grep -sm1 "^$f " "$0.exe.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \ |
| 14 | { echo>&2 "ERROR: cannot find $f"; exit 1; }; f=; set -e |
| 15 | # --- end runfiles.bash initialization v2 --- |
| 16 | |
Philipp Schrader | 37fdbb6 | 2021-12-18 00:30:37 -0800 | [diff] [blame] | 17 | set -o nounset |
| 18 | |
| 19 | # Redirect the Go cache on buildkite. Otherwise we run into errors like: |
| 20 | # "failed to initialize build cache at /var/lib/buildkite-agent/.cache/go-build" |
| 21 | # due to permission errors. |
| 22 | if ((RUNNING_IN_CI == 1)); then |
| 23 | export GOCACHE=/tmp/lint_go_cache |
| 24 | fi |
| 25 | |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 26 | gofmt() { |
| 27 | ./tools/lint/gofmt |
| 28 | } |
| 29 | |
Philipp Schrader | 37fdbb6 | 2021-12-18 00:30:37 -0800 | [diff] [blame] | 30 | gomod() { |
| 31 | local -r go="$(readlink -f external/go_sdk/bin/go)" |
| 32 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 33 | "${go}" mod tidy -e |
| 34 | } |
| 35 | |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 36 | update_go_repos() { |
Philipp Schrader | d96d4cb | 2022-02-06 15:37:29 -0800 | [diff] [blame] | 37 | # Clear out the go_deps.bzl file so that gazelle won't hesitate to update |
| 38 | # it. Without this step gazelle would never try to remove a dependency. |
| 39 | cat > "${BUILD_WORKSPACE_DIRECTORY}"/go_deps.bzl <<EOF |
| 40 | def go_dependencies(): |
| 41 | pass |
| 42 | EOF |
Philipp Schrader | 37fdbb6 | 2021-12-18 00:30:37 -0800 | [diff] [blame] | 43 | ./gazelle-runner.bash update-repos \ |
| 44 | -from_file=go.mod \ |
| 45 | -to_macro=go_deps.bzl%go_dependencies \ |
| 46 | -prune |
| 47 | } |
| 48 | |
| 49 | gazelle() { |
| 50 | ./gazelle-runner.bash |
| 51 | } |
| 52 | |
| 53 | tweak_gazelle_go_deps() { |
| 54 | local -r tweaker="$(readlink -f tools/go/tweak_gazelle_go_deps)" |
| 55 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 56 | "${tweaker}" ./go_deps.bzl |
| 57 | } |
| 58 | |
Philipp Schrader | d96d4cb | 2022-02-06 15:37:29 -0800 | [diff] [blame] | 59 | clean_up_go_mirrors() { |
| 60 | ./tools/go/mirror_go_repos --prune |
| 61 | } |
| 62 | |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 63 | rustfmt() { |
| 64 | ./tools/lint/rustfmt |
| 65 | } |
| 66 | |
| 67 | cargo_raze() { |
| 68 | local -r cargo_raze="$(readlink -f external/cargo_raze/impl/cargo_raze_bin)" |
Brian Silverman | e84b0cf | 2022-08-13 19:36:21 -0700 | [diff] [blame^] | 69 | export CARGO="$(readlink -f external/rust__x86_64-unknown-linux-gnu_tools/bin/cargo)" |
| 70 | export RUSTC="$(readlink -f external/rust__x86_64-unknown-linux-gnu_tools/bin/rustc)" |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 71 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 72 | # Note we don't run with --generate-lockfile here. If there's a new |
| 73 | # dependency, we don't want to download it, just failing with an error |
| 74 | # is sufficient. |
| 75 | "${cargo_raze}" --manifest-path=Cargo.toml |
| 76 | } |
| 77 | |
| 78 | tweak_cargo_raze() { |
| 79 | local -r tweaker="$(readlink -f tools/rust/tweak_cargo_raze_output)" |
| 80 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 81 | "${tweaker}" . |
| 82 | } |
| 83 | |
Philipp Schrader | cc016b3 | 2021-12-30 08:59:58 -0800 | [diff] [blame] | 84 | buildifier() { |
| 85 | ./tools/lint/buildifier |
| 86 | } |
| 87 | |
Philipp Schrader | ace0884 | 2022-03-26 14:52:55 -0700 | [diff] [blame] | 88 | prettier() { |
Philipp Schrader | 817cce3 | 2022-03-26 15:00:00 -0700 | [diff] [blame] | 89 | ./tools/lint/prettier |
Philipp Schrader | ace0884 | 2022-03-26 14:52:55 -0700 | [diff] [blame] | 90 | } |
| 91 | |
Ravago Jones | 23dac94 | 2022-07-31 16:18:54 -0700 | [diff] [blame] | 92 | yapf() { |
| 93 | ./tools/lint/yapf |
| 94 | } |
| 95 | |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 96 | git_status_is_clean() { |
| 97 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 98 | if ! git diff --quiet; then |
| 99 | echo "One or more linters appear to have made changes to your code!" >&2 |
| 100 | return 1 |
| 101 | fi |
| 102 | } |
| 103 | |
| 104 | # All the linters that we are going to run. |
| 105 | readonly -a LINTERS=( |
| 106 | gofmt |
Philipp Schrader | 37fdbb6 | 2021-12-18 00:30:37 -0800 | [diff] [blame] | 107 | gomod |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 108 | update_go_repos |
Philipp Schrader | 37fdbb6 | 2021-12-18 00:30:37 -0800 | [diff] [blame] | 109 | gazelle |
| 110 | tweak_gazelle_go_deps |
Philipp Schrader | d96d4cb | 2022-02-06 15:37:29 -0800 | [diff] [blame] | 111 | clean_up_go_mirrors |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 112 | rustfmt |
| 113 | cargo_raze |
| 114 | tweak_cargo_raze |
Philipp Schrader | cc016b3 | 2021-12-30 08:59:58 -0800 | [diff] [blame] | 115 | buildifier |
Philipp Schrader | ace0884 | 2022-03-26 14:52:55 -0700 | [diff] [blame] | 116 | prettier |
Ravago Jones | 23dac94 | 2022-07-31 16:18:54 -0700 | [diff] [blame] | 117 | yapf |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 118 | git_status_is_clean # This must the last linter. |
| 119 | ) |
| 120 | |
| 121 | failure=0 |
| 122 | for linter in "${LINTERS[@]}"; do |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 123 | echo "Running ${linter}..." >&2 |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 124 | if ! (eval "${linter}"); then |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 125 | echo "LINTER FAILURE: ${linter}" >&2 |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 126 | failure=1 |
Brian Silverman | 4e27808 | 2022-05-19 22:47:41 -0700 | [diff] [blame] | 127 | else |
| 128 | echo "${linter} succeeded" >&2 |
Philipp Schrader | 773577f | 2021-12-17 23:45:39 -0800 | [diff] [blame] | 129 | fi |
| 130 | done |
| 131 | |
| 132 | if ((failure != 0)); then |
| 133 | echo "One or more linters failed." >&2 |
| 134 | cd "${BUILD_WORKSPACE_DIRECTORY}" |
| 135 | git --no-pager diff || : |
| 136 | exit "${failure}" |
| 137 | fi |
| 138 | |
| 139 | exit 0 |