kmod/CONTRIBUTING.md
Emil Velikov 1e48f8a37a CONTRIBUTING.md: mention about gtk-doc Since:
We don't have an easy way to test if API is missing a Since annotation,
so mention that in the contributing guide.

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
Link: https://github.com/kmod-project/kmod/pull/200
Signed-off-by: Lucas De Marchi <lucas.de.marchi@gmail.com>
2024-10-23 23:19:11 -05:00

4.2 KiB

Contributing to kmod

Thanks for taking the time to contribute to kmod!

If you want to submit changes, you can send GitHub pull requests as well as patches sent to the mailing list. In addition you can open issues and feature requests on our GitHub tracker.

In this file you can find:

License and SPDX

The project uses GPLv2+ for tools/ and LGPLv2.1+ for everything else. New tools should be licensed under LGPLv2.1+ to make it easy to migrate code to other places when/if needed. When adding new files use the respective SPDX-License-Identifier: instead of the complete license text.

Commit style and history

The kmod project uses a linear, "recipe" style history. This means that commits should be small, digestible, stand-alone, and functional.

Commit messages are in imperative mood and merges are to be avoided.

When in doubt, or need a refresher, checking through the output of git log is highly recommended.

Using commit trailers

Commit messages, apart from stating why a particular change is made, can include a range of trailers.

Signed-off-by

By using a Signed-off-by: trailer you agree that you comply with the Developer Certificate of Origin.

Issues, feature requests

Whenever a patch resolves a particular issue, be that one on our GitHub tracker or elsewhere, use the Closes: trailer followed by the full URL.

Closes: https://github.com/kmod-project/kmod/issues/65

Discussions, references

If your commit covers a topic raised in an issue, but does not resolve the issue itself; or otherwise refers to a more complicated topic, you can use Reference:.

The use of Link: trailer is reserved and should be used only to point to the patch origin. Be that the GitHub pull request, or the mailing list archive.

You can add it yourself, although usually the maintainer will include it when merging the patch.

Bugfixes, regressions

Nobody is perfect and regressions happen from time to time. Whenever a commit addresses a regression caused by another commit, use Fixes: as below:

Fixes: 38943b2 ("shared: use size_t for strbuf")

Coding style

The project uses style practically identical to the kernel style. You can see the in-tree CODING-STYLE file for quick references.

We also have a .clang-format file to ease and enforce the style. Make sure you run git-clang-format against your changes, before submitting PRs/patches.

API documentation

The official libkmod documentation is generated by gtk-doc and a simple test is wired to meson test to catch accidental mistakes or omissions.

If you're unfamiliar with gtk-doc here is a quick primer.

When adding new API, make sure to include the Since: token and add a new api-index section in libkmod/docs/libkmod-docs.xml.

Tools manual pages

Our manual pages are written in scdoc a simple markdown-like syntax. Please make sure to update them as you add new options to the kmod tools.

Tools shell completion

The project aims to provide bash, zsh and fish shell completions for all the kmod tools. Currently support is borderline non-existent, so your help is greatly appreciated.