diff --git a/MODULE.bazel b/MODULE.bazel index ed6f3f66..b15e7296 100644 --- a/MODULE.bazel +++ b/MODULE.bazel @@ -7,6 +7,7 @@ module( ) bazel_dep(name = "aspect_bazel_lib", version = "2.7.7") +bazel_dep(name = "rules_java", version = "8.5.0") # Needed in the root because we use js_lib_helpers in our aspect impl # Minimum version needs 'chore: bump bazel-lib to 2.0 by @alexeagle in #1311' diff --git a/README.md b/README.md index 8e645768..2e0141e7 100644 --- a/README.md +++ b/README.md @@ -21,38 +21,39 @@ Features: New tools are being added frequently, so check this page again! -| Language | Formatter | Linter(s) | -| ---------------------- | --------------------- | -------------------- | -| C / C++ | [clang-format] | [clang-tidy] | -| Cuda | [clang-format] | | -| CSS, Less, Sass | [Prettier] | [Stylelint] | -| Go | [gofmt] or [gofumpt] | | -| GraphQL | [Prettier] | | -| HCL (Hashicorp Config) | [terraform] fmt | | -| HTML | [Prettier] | | -| JSON | [Prettier] | | -| Java | [google-java-format] | [pmd] , [Checkstyle] | -| JavaScript | [Prettier] | [ESLint] | -| Jsonnet | [jsonnetfmt] | | -| Kotlin | [ktfmt] | [ktlint] | -| Markdown | [Prettier] | [Vale] | -| Protocol Buffer | [buf] | [buf lint] | -| Python | [ruff] | [flake8], [ruff] | -| Rust | [rustfmt] | | -| SQL | [prettier-plugin-sql] | | -| Scala | [scalafmt] | | -| Shell | [shfmt] | [shellcheck] | -| Starlark | [Buildifier] | | -| Swift | [SwiftFormat] (1) | | -| TSX | [Prettier] | [ESLint] | -| TypeScript | [Prettier] | [ESLint] | -| YAML | [yamlfmt] | | +| Language | Formatter | Linter(s) | +| ---------------------- | --------------------- |----------------------------------| +| C / C++ | [clang-format] | [clang-tidy] | +| Cuda | [clang-format] | | +| CSS, Less, Sass | [Prettier] | [Stylelint] | +| Go | [gofmt] or [gofumpt] | | +| GraphQL | [Prettier] | | +| HCL (Hashicorp Config) | [terraform] fmt | | +| HTML | [Prettier] | | +| JSON | [Prettier] | | +| Java | [google-java-format] | [pmd] , [Checkstyle], [Spotbugs] | +| JavaScript | [Prettier] | [ESLint] | +| Jsonnet | [jsonnetfmt] | | +| Kotlin | [ktfmt] | [ktlint] | +| Markdown | [Prettier] | [Vale] | +| Protocol Buffer | [buf] | [buf lint] | +| Python | [ruff] | [flake8], [ruff] | +| Rust | [rustfmt] | | +| SQL | [prettier-plugin-sql] | | +| Scala | [scalafmt] | | +| Shell | [shfmt] | [shellcheck] | +| Starlark | [Buildifier] | | +| Swift | [SwiftFormat] (1) | | +| TSX | [Prettier] | [ESLint] | +| TypeScript | [Prettier] | [ESLint] | +| YAML | [yamlfmt] | | [prettier]: https://prettier.io [google-java-format]: https://github.com/google/google-java-format [flake8]: https://flake8.pycqa.org/en/latest/index.html [pmd]: https://docs.pmd-code.org/latest/index.html [checkstyle]: https://checkstyle.sourceforge.io/cmdline.html +[spotbugs]: https://spotbugs.github.io/ [buf lint]: https://buf.build/docs/lint/overview [eslint]: https://eslint.org/ [swiftformat]: https://github.com/nicklockwood/SwiftFormat diff --git a/docs/BUILD.bazel b/docs/BUILD.bazel index 0f7cc148..0c0d296f 100644 --- a/docs/BUILD.bazel +++ b/docs/BUILD.bazel @@ -32,6 +32,11 @@ stardoc_with_diff_test( bzl_library_target = "//lint:checkstyle", ) +stardoc_with_diff_test( + name = "spotbugs", + bzl_library_target = "//lint:spotbugs", +) + stardoc_with_diff_test( name = "format", bzl_library_target = "//format:defs", diff --git a/docs/spotbugs.md b/docs/spotbugs.md new file mode 100644 index 00000000..32b9b5dc --- /dev/null +++ b/docs/spotbugs.md @@ -0,0 +1,98 @@ + + +API for declaring a spotbugs lint aspect that visits java_library and java_binary rules. + +Typical usage: + +First, call the `fetch_spotbugs` helper in `WORKSPACE` to download the jar file. +Alternatively you could use whatever you prefer for managing Java dependencies, such as a Maven integration rule. + +Next, declare a binary target for it, typically in `tools/lint/BUILD.bazel`: + +```starlark +java_binary( + name = "spotbugs", + main_class = "edu.umd.cs.findbugs.LaunchAppropriateUI", + runtime_deps = [ + "@spotbugs//:jar", + ], +) +``` + +Finally, declare an aspect for it, typically in `tools/lint/linters.bzl`: + +```starlark +load("@aspect_rules_lint//lint:spotbugs.bzl", "lint_spotbugs_aspect") + +spotbugs = lint_spotbugs_aspect( + binary = "@@spotbugs//:bin", + exclude_filter = "@@//:spotbugs-exclude.xml", +) + +``` + + + +## fetch_spotbugs + +
+load("@aspect_rules_lint//lint:spotbugs.bzl", "fetch_spotbugs") + +fetch_spotbugs() ++ + + + + + + +## lint_spotbugs_aspect + +
+load("@aspect_rules_lint//lint:spotbugs.bzl", "lint_spotbugs_aspect") + +lint_spotbugs_aspect(binary, exclude_filter, rule_kinds) ++ + + +**PARAMETERS** + + +| Name | Description | Default Value | +| :------------- | :------------- | :------------- | +| binary |
-
| none | +| exclude_filter |-
| none | +| rule_kinds |-
| `["java_library", "java_binary"]` | + + + + +## spotbugs_action + ++load("@aspect_rules_lint//lint:spotbugs.bzl", "spotbugs_action") + +spotbugs_action(ctx, executable, srcs, exclude_filter, stdout, exit_code, options) ++ +Run Spotbugs as an action under Bazel. + +Based on https://spotbugs.readthedocs.io/en/latest/index.html + + +**PARAMETERS** + + +| Name | Description | Default Value | +| :------------- | :------------- | :------------- | +| ctx | Bazel Rule or Aspect evaluation context | none | +| executable | label of the the Spotbugs program | none | +| srcs | jar to be linted | none | +| exclude_filter | label of the spotbugs-exclude.xml file | none | +| stdout | output file to generate | none | +| exit_code | output file to write the exit code. If None, then fail the build when Spotbugs exits non-zero. | `None` | +| options | additional command-line options, see https://spotbugs.readthedocs.io/en/latest/running.html#command-line-options | `[]` | + + diff --git a/example/.aspect/cli/config.yaml b/example/.aspect/cli/config.yaml index 2fc0bf5c..a13ca939 100644 --- a/example/.aspect/cli/config.yaml +++ b/example/.aspect/cli/config.yaml @@ -10,3 +10,4 @@ lint: - //tools/lint:linters.bzl%vale - //tools/lint:linters.bzl%checkstyle - //tools/lint:linters.bzl%clang_tidy + - //tools/lint:linters.bzl%spotbugs diff --git a/example/.bazelrc b/example/.bazelrc index 400bca34..35ef5c1b 100644 --- a/example/.bazelrc +++ b/example/.bazelrc @@ -4,6 +4,7 @@ common --enable_platform_specific_config # Don't depend on a JAVA_HOME pointing at a system JDK # see https://github.com/bazelbuild/rules_jvm_external/issues/445 build --repo_env=JAVA_HOME=../bazel_tools/jdk +common --java_runtime_version=remotejdk_21 common --incompatible_enable_proto_toolchain_resolution common --@aspect_rules_ts//ts:skipLibCheck=always diff --git a/example/BUILD.bazel b/example/BUILD.bazel index ec13673e..b8d151ee 100644 --- a/example/BUILD.bazel +++ b/example/BUILD.bazel @@ -25,6 +25,7 @@ exports_files( ".editorconfig", "ktlint-baseline.xml", ".clang-tidy", + "spotbugs-exclude.xml", ], visibility = ["//visibility:public"], ) diff --git a/example/MODULE.bazel b/example/MODULE.bazel index 817a2b71..eb27adaf 100644 --- a/example/MODULE.bazel +++ b/example/MODULE.bazel @@ -9,8 +9,8 @@ bazel_dep(name = "rules_buf", version = "0.3.0") bazel_dep(name = "bazel_skylib", version = "1.4.2") bazel_dep(name = "toolchains_llvm", version = "0.10.3") bazel_dep(name = "toolchains_protoc", version = "0.3.0") -bazel_dep(name = "rules_java", version = "5.5.0") -bazel_dep(name = "rules_jvm_external", version = "4.5") +bazel_dep(name = "rules_java", version = "8.5.0") +bazel_dep(name = "rules_jvm_external", version = "6.5") bazel_dep(name = "rules_go", version = "0.42.0", repo_name = "io_bazel_rules_go") bazel_dep(name = "rules_proto", version = "6.0.0") bazel_dep(name = "rules_python", version = "0.26.0") diff --git a/example/WORKSPACE.bazel b/example/WORKSPACE.bazel index 605aade4..1ee606ee 100644 --- a/example/WORKSPACE.bazel +++ b/example/WORKSPACE.bazel @@ -318,6 +318,10 @@ load("@aspect_rules_lint//lint:ktlint.bzl", "fetch_ktlint") fetch_ktlint() +load("@aspect_rules_lint//lint:spotbugs.bzl", "fetch_spotbugs") + +fetch_spotbugs() + ######################## # Optional: multitool provides defaults for some tools such as yamlfmt # If you do not set up multitool, you must provide these tools yourself diff --git a/example/WORKSPACE.bzlmod b/example/WORKSPACE.bzlmod index 840a1e98..81fbceb3 100644 --- a/example/WORKSPACE.bzlmod +++ b/example/WORKSPACE.bzlmod @@ -31,3 +31,7 @@ fetch_vale() load("@aspect_rules_lint//lint:ktlint.bzl", "fetch_ktlint") fetch_ktlint() + +load("@aspect_rules_lint//lint:spotbugs.bzl", "fetch_spotbugs") + +fetch_spotbugs() diff --git a/example/lint.sh b/example/lint.sh index 036d47f4..e552d63d 100755 --- a/example/lint.sh +++ b/example/lint.sh @@ -37,7 +37,7 @@ if [ $machine == "Windows" ]; then # avoid missing linters on windows platform args=("--aspects=$(echo //tools/lint:linters.bzl%{flake8,pmd,ruff,vale,clang_tidy} | tr ' ' ',')") else - args=("--aspects=$(echo //tools/lint:linters.bzl%{buf,eslint,flake8,ktlint,pmd,ruff,shellcheck,stylelint,vale,clang_tidy} | tr ' ' ',')") + args=("--aspects=$(echo //tools/lint:linters.bzl%{buf,eslint,flake8,ktlint,pmd,ruff,shellcheck,stylelint,vale,clang_tidy,spotbugs} | tr ' ' ',')") fi # NB: perhaps --remote_download_toplevel is needed as well with remote execution? diff --git a/example/spotbugs-exclude.xml b/example/spotbugs-exclude.xml new file mode 100644 index 00000000..e8f84e3d --- /dev/null +++ b/example/spotbugs-exclude.xml @@ -0,0 +1,7 @@ + +