BuildCache is an open source project, and anyone is of course welcome to contribute to it.
Use GitHub issues to report any problems with BuildCache, or to request new features.
Use the GitHub fork + pull request flow to suggest patches to the project.
BuildCache is written in C++11. Use it.
The code is formatted using clang-format (the formatting rules are given in .clang-format). Use it.
In general, try to follow the style of the existing code base.
- Use
snake_case
for most things (variables, types/classes, functions, ...). - Use
SHOUTY_CASE
for compile-time constants. - Types are suffixed with
_t
(e.g.program_wrapper_t
). - Class members are prefixed with
m_
(e.g.int m_count;
).
- Comments should use proper sentences, with capitalization and an ending period.
- Use a blank line before comment lines.
- Document functions and interfaces with
Doxygen comments (use the
/// @foo
style).
- Include what you use.
Use the recipe model for Git branches and commits. In short:
- Use a feature branch for each patch.
- Use rebase (not merge) to update a branch against master.
- Use proper commit messages:
- Follow the Git conventions.
- Use the imperative mood ("Fix bug", not "Fixed bug").
- Use proper capitalization.
All code is written in a fully portable manner. There are CI pipelines in place that ensure that BuildCache will build and run on at least Linux, macOS and Windows, but the goal is that BuildCache should work on most POSIX-compatible systems.
Any differences between systems are abstracted in suitable modules. For an example, see base/file_utils.cpp.