PR Guidelines

PR Requirements

  • Clean, not hacky code
  • Described changes and why they were there
  • Following the style (see below)

Code Style

Please read this if you are submitting a PR, in order to minimize the amount of style nits received, and save the time for the maintainers.

Before you submit

Make sure you ran clang-format: clang-format -i src/**/*{cpp,hpp}

Check if your changes don’t violate clang-tidy. Usually this is built into your IDE.

Clang-format

This is non-negotiable. Your code must be formatted.

Clang-tidy

Clang-tidy violations are not hard requirements, but please try to minimize them, and only ignore them if it’s absolutely necessary.

I’ve tweaked it so that in 99% of cases you absolutely should fix it.

Other

Some stuff clang-tidy / clang-format won’t catch:

  • No uninitialized primitives (int, float, double, size_t, etc.)
  • No short ifs. if your if/else body contains 1 line (not 1 statement) do not put {} around it.
  • The above rule does not apply to loops / etc
  • Consider adding a ; inside of empty function bodies
  • Use utilities. Do not invent new types where one already exists.
  • Consider the usage of the STL
  • Minimize manual memory management to an absolute minimum. You have tons of tools at your disposal to do so
  • Whenever you’re initializing vectors arrays or maps with a lot of elements, add a , after the last element to make the styling nicer