Clean section header order, document it and implement a checkpatch.pl
check
#1116
Labels
• docs
Related to `Documentation/rust/`, `samples/`, generated docs, doctests, typos...
easy
Expected to be an easy issue to resolve.
good first issue
Good for newcomers
medium
Expected to be an issue of medium difficulty to resolve.
We want to standardize the order in which we list section headers in rustdoc. The reason for this is that the API relevant sections should come first, in order to not miss them. The suggested ordering is:
# Safety
# Guarantees
# Panics
# Errors
# Examples
# Invariants
The first four sections are part of the API surface of the documented item.
# Invariants
are listed as the last section, because they are implementation detail rather than belonging to the API.This should only be the standard for items that are not modules. For modules, we usually have custom sections.
Fix the ordering in existing code (for example there are some instances in
rust/kernel/workqueue.rs
), document the ordering underDocumentation/rust/coding-guidelines.rst
and create acheckpatch.pl
check. Each of theses should be its own patch; depending on the size of the changes in existing code, you might want to split that up into multiple patches as well.Please note that the
checkpatch.pl
maintainers will need to agree to the change.This requires submitting a proper patch to the LKML and the Rust for Linux mailing list. Please recall to test your changes (including generating the documentation if changed, running the Rust doctests if changed, etc.), to use a proper title for the commit, to sign your commit under the Developer's Certificate of Origin and to add a
Suggested-by: tag
and aLink:
tag to this issue. Please see https://rust-for-linux.com/contributing for details.Please take this issue only if you are new to the kernel development process and you would like to use it as a test to submit your first patch to the kernel. Please do not take it if you do not plan to make other contributions to the kernel.
The text was updated successfully, but these errors were encountered: