From 949c47e762aab9076a4394c3ec73de4535d0da20 Mon Sep 17 00:00:00 2001 From: Alex Eagle Date: Thu, 12 Oct 2023 10:22:24 -0700 Subject: [PATCH] chore: generate API docs for flake8 Part 3 of the 'adding a linter' guide --- README.md | 2 ++ docs/BUILD.bazel | 5 ++++ docs/flake8.md | 74 ++++++++++++++++++++++++++++++++++++++++++++++++ lint/BUILD.bazel | 6 ++++ lint/README.md | 1 - 5 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 docs/flake8.md diff --git a/README.md b/README.md index 7eb683c9..0e884097 100644 --- a/README.md +++ b/README.md @@ -38,6 +38,8 @@ We have a separate project for formatting, see - JavaScript - `eslint`: https://eslint.org/ +- Python + - `flake8`: ### Adding a linter diff --git a/docs/BUILD.bazel b/docs/BUILD.bazel index a61f6888..0b09c0bd 100644 --- a/docs/BUILD.bazel +++ b/docs/BUILD.bazel @@ -12,4 +12,9 @@ stardoc_with_diff_test( bzl_library_target = "//lint:eslint", ) +stardoc_with_diff_test( + name = "flake8", + bzl_library_target = "//lint:flake8", +) + update_docs(name = "update") diff --git a/docs/flake8.md b/docs/flake8.md new file mode 100644 index 00000000..63853c83 --- /dev/null +++ b/docs/flake8.md @@ -0,0 +1,74 @@ + + +API for declaring a flake8 lint aspect that visits py_library rules. + +Typical usage: + +``` +load("@aspect_rules_lint//lint:flake8.bzl", "flake8_aspect") + +flake8 = flake8_aspect( + binary = "@@//:flake8", + config = "@@//:.flake8", +) +``` + + + + +## flake8_action + +
+flake8_action(ctx, executable, srcs, config, report, use_exit_code)
+
+ +Run flake8 as an action under Bazel. + +Based on https://flake8.pycqa.org/en/latest/user/invocation.html + + +**PARAMETERS** + + +| Name | Description | Default Value | +| :------------- | :------------- | :------------- | +| ctx | Bazel Rule or Aspect evaluation context | none | +| executable | label of the the flake8 program | none | +| srcs | python files to be linted | none | +| config | label of the flake8 config file (setup.cfg, tox.ini, or .flake8) | none | +| report | output file to generate | none | +| use_exit_code | whether to fail the build when a lint violation is reported | False | + + + + +## flake8_aspect + +
+flake8_aspect(binary, config)
+
+ +A factory function to create a linter aspect. + +Attrs: + binary: a flake8 executable. Can be obtained from rules_python like so: + + ``` + load("@rules_python//python/entry_points:py_console_script_binary.bzl", "py_console_script_binary") + + py_console_script_binary( + name = "flake8", + pkg = "@pip//flake8:pkg", + ) + ``` + config: the flake8 config file (`setup.cfg`, `tox.ini`, or `.flake8`) + +**PARAMETERS** + + +| Name | Description | Default Value | +| :------------- | :------------- | :------------- | +| binary |

-

| none | +| config |

-

| none | + + diff --git a/lint/BUILD.bazel b/lint/BUILD.bazel index 9f22810d..566c0af4 100644 --- a/lint/BUILD.bazel +++ b/lint/BUILD.bazel @@ -18,3 +18,9 @@ bzl_library( "@aspect_rules_js//js:libs", ], ) + +bzl_library( + name = "flake8", + srcs = ["flake8.bzl"], + visibility = ["//visibility:public"], +) diff --git a/lint/README.md b/lint/README.md index 771b0ea8..c038241e 100644 --- a/lint/README.md +++ b/lint/README.md @@ -69,7 +69,6 @@ https://github.com/aspect-build/rules_lint/commit/29d275bcf7ecf5b99c6bff6913322f Add a rule in the `docs/` folder matching the existing ones, so that the API docs are auto-generated. Run `bazel run docs:update` to create the Markdown file. - Also add your new linter to the README. Here's a commit showing what it should look like: