forked from R3BRootGroup/R3BRoot
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added bestpractices badge Update readme Update readme Update readme Update readme Update Copyright Added Deniz to the list of contributors Added fair-software.yml
- Loading branch information
1 parent
331d5ed
commit 3dea467
Showing
1,624 changed files
with
1,780 additions
and
1,623 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
name: fair-software | ||
|
||
on: | ||
push: | ||
paths: | ||
- README.md | ||
|
||
jobs: | ||
verify: | ||
name: "fair-software" | ||
runs-on: ubuntu-latest | ||
if: github.repository == 'FairRootGroup/FairRoot' | ||
steps: | ||
- uses: fair-software/howfairis-github-action@0.2.1 | ||
name: Measure compliance with fair-software.eu recommendations | ||
env: | ||
PYCHARM_HOSTED: "Trick colorama into displaying colored output" | ||
with: | ||
MY_REPO_URL: "https://github.com/${{ github.repository }}" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,130 @@ | ||
# Contributing | ||
|
||
## Bug reports, feature request, questions etc | ||
|
||
Create a [Github Issue](https://github.com/R3BRootGroup/R3BRoot/issues/new/choose). | ||
|
||
## Contributing code | ||
|
||
Create a [Github Pull Request](https://github.com/R3BRootGroup/R3BRoot/compare): | ||
|
||
1. By default, develop against the [`dev`](https://github.com/R3BRootGroup/R3BRoot/tree/dev) | ||
branch and base your PR against it. | ||
* In rare cases (e.g. backports, some hotfixes) base against the appropriate | ||
branch. | ||
2. If you are a first time contributor, add a separate commit in your PR which | ||
adds your name to the [`CONTRIBUTORS`](CONTRIBUTORS) file. | ||
3. Follow our [Coding Guidelines](#coding-guidelines). | ||
4. Expect that a reviewer will ask you for restructuring your commits! This | ||
usually happens towards the end of the lifetime of a PR when it matured | ||
enough for merging. | ||
|
||
# Coding Guidelines | ||
|
||
These guidelines are horribly incomplete at this point in time, but one has to | ||
start somewhere ;) Exactly because these guidelines are relatively new, do not be | ||
alarmed if large parts of this repo do not follow them (yet). The idea is to | ||
apply them incrementally on new code and when existing code is modified. These | ||
guidelines will also evolve as time passes. | ||
|
||
How to reference a rule in an issue or PR discussion: | ||
``` | ||
// reference to our guideline | ||
[G.2](https://github.com/R3BRootGroup/R3BRoot/blob/master/CONTRIBUTING.md#g.2-adopted-c++-core-guidelines) | ||
// reference to c++ core guideline with prefix CPPCG:: | ||
[CPPCG::I.11](https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md#i11-never-transfer-ownership-by-a-raw-pointer-t-or-reference-t) | ||
``` | ||
|
||
## G - General | ||
|
||
### G.1 Our CI runs [`clang-tidy`](https://clang.llvm.org/extra/clang-tidy/) | ||
|
||
**Config**: [`.clang-tidy`](.clang-tidy) | ||
|
||
We currently do not strictly enforce *clang-tidy* checks, but the author | ||
should try to address any warnings. The set of enabled checks will evolve over | ||
time. | ||
|
||
### G.2 Adopted C++ Core Guidelines | ||
|
||
This shall be an evolving list of explicitely adopted C++ Core Guidelines: | ||
|
||
* [CPPCG::I.11: Never transfer ownership by a raw pointer (`T*`) or reference (`T&`)](https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md#i11-never-transfer-ownership-by-a-raw-pointer-t-or-reference-t) | ||
* If an owning raw pointer cannot be avoided for legacy reasons, | ||
**you must add a comment documenting the ownership semantics!** | ||
|
||
### G.3 Write a good Git history | ||
|
||
* Follow [the seven rules of a great Git commit message](https://cbea.ms/git-commit/#seven-rules)! | ||
* Use a meaningful commit granularity, e.g. do not mix | ||
unrelated changes in a single commit and vice verse squash related commits | ||
into one. | ||
* Utilize [the commit message body to explain *what* and *why* and not *how*](https://cbea.ms/git-commit/#why-not-how). | ||
Aim your message to be meaningful (concise, but complete | ||
enough) to a reader in the future! See also G.4! | ||
* Utilize [reference keywords](https://docs.github.com/en/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword) | ||
both in commit messages as well as in PR comments if applicable. | ||
|
||
### G.4 Conventional Commits | ||
|
||
* Follow the [Conventional Commits Specification](https://www.conventionalcommits.org/en/v1.0.0/) | ||
* Adopted `type`s: `fix:`, `feat:`, `build:`, `chore:`, `ci:`, `docs:`, | ||
`style:`, `refactor:`, `perf:`, `test:` | ||
* If a `scope` is used, prefer the library name (first directory level below | ||
`R3BRoot/`), e.g. `fix(base):` or `feat(geobase):` | ||
|
||
### G.5 Signed Commits and Tags | ||
|
||
You may use any signature format Git and Github support (SSH e.g. may be more | ||
convenient, if one does not have a GPG key yet). | ||
|
||
* [Github - Setup](https://docs.github.com/en/authentication/managing-commit-signature-verification/telling-git-about-your-signing-key) | ||
* [Github - Signing Commits](https://docs.github.com/en/authentication/managing-commit-signature-verification/signing-commits) | ||
* [Github - Signing Tags](https://docs.github.com/en/authentication/managing-commit-signature-verification/signing-tags) | ||
* [Git - Signing Your Work](https://git-scm.com/book/en/v2/Git-Tools-Signing-Your-Work) | ||
Make sure to consider `git config [--local|--global] commit.gpgsign true` | ||
(scroll down to the bottom) | ||
|
||
## D - Documentation | ||
|
||
### D.1 Use [doxygen-style comments](https://www.doxygen.nl/manual/commands.html) | ||
|
||
## S - Style | ||
|
||
### S.1 Our CI enforces formatting with [`clang-format`](https://clang.llvm.org/docs/ClangFormat.html) | ||
|
||
**Config**: [`.clang-format`](.clang-format) | ||
|
||
Rarely, it is needed to opt-out of *clang-format* for certain code sections | ||
because it would just make things worse. | ||
|
||
**Example**: | ||
```cpp | ||
// clang-format off | ||
fDescription.add_options() | ||
("help", "Print this message") | ||
("nevents", po::value<int>(), "Number of events to simulate") | ||
("engine", po::value<vector<string>>(), "Monte Carlo engine") | ||
("multi-threaded", "Geant4 multi threaded") | ||
("output-file", po::value<vector<string>>(), "Output file") | ||
("parameter-file", po::value<vector<string>>(), "Parameter file") | ||
("random-seed", po::value<int>(), "Seed for the random number generator"); | ||
// clang-format on | ||
``` | ||
|
||
### S.2 Prefer variable names describing *what* they contain | ||
|
||
Avoid repeating just the typename. | ||
|
||
**Reason**: Readability | ||
|
||
**Example**: | ||
```cpp | ||
TList* list = module->GetList(); // avoid | ||
TList* volList = module->GetListOfVolumes(); // acceptable | ||
TList* volumes = module->GetVolumes(); // ✓ prefer | ||
|
||
for (auto const& listEntry : *list) { /*...*/ } // avoid | ||
for (auto const& aVol : *volList) { /*...*/ } // acceptable | ||
for (auto const& volume : *volumes) { /*...*/ } // ✓ prefer | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.