- check doc/OUTLINE.md to get an idea how this is supposed to work,
- check doc/TODO.md and
//TODO:
comments to see what has to be done.
Send PRs on GitHub.
- cpp and h filenames are all lowercase, named after the class name
- 120 chars per line
- new code should mostly follow WebKit C++ style,
except for
m_
for member variables is not required: just_
is fine (read below)s_
for static members is not required- getters start with
get
- it would take a major refactor to change them all
- include guards are
_FOLDER_FOLDER_FILENAME_H
, closing#endif
should have the name as comment #pragma once
is preferred over include guards for new code- camelCase
- protected and private member variables start with
_
- local variables start with a lower case letter
- public methods start with a lower case letter
- protected methods start with a lower case letter
- public member variables should start with a lower case letter - this is to match SDL's structs
- public member variables should only be used for simple structs - use getters/setters otherwise
- getters start with
get
, setters withset
- class names start with a capital letter
- one exception to the above is the Lua Interface, which uses
T::Lua_CamelCase
- loops/iterations use
auto :
orauto& :
where possible - use
std::string
orstd::string_view
(we target c++17) - there are a ton of violations, but new code should still try to check all the boxes
- individual modules/folders/files can have their own style, which should be followed
- stuff is open to debate. PRs for coding style will be welcome at some point.
- ownership should be similar to Qt, where a parent will delete its children
- unique_ptr are fine, "raw pointers" are also fine, but should probably refactor uilib at some point
- avoid shared and weak since they are far from free; prefer clear ownership and life cycle
If a dependency can be used as-is, its style should not be changed from upstream.
Use diff -E -b --color=always -u ...
to compare upstream versions if style is inconsistent.
- we want to be able to deploy to wasm
- total code size is relevant for loading times / download size
- wasm is a lot slower than native code
- memory allocation in multiple threads is slow
- try to use as little of libstdc++ as possible without impacting maintainability
- dead code in static builds gets stripped and the complete libstdc++ is massive
- calling directly into libc is often cheaper (printf, fread vs. std::streams)
- try to avoid exceptions and RTTI - some libs depend on exceptions,
so we don't aim for
-fno-exceptions
at the moment - try to write fast code by default
- assume threads are not cheap
- use private (not protected) where possible to avoid going through vtables
- implement small functions inline in header files for platforms where LTO does not work correctly
We run scan-build in CI to catch some mistakes, excluding some libs.
See scan-build.yaml.
Consider testing with ASAN by passing WITH_ASAN=true to make.
We use codespell to find typos. You can pip install codespell
or rely on the GitHub workflow.
See .codespellrc
if you want to exclude files/folders and .codespellignore
if you want to exclude a word.
Markdown per Google Markdown style guide with the following exceptions:
- single space after bullet / list number
- no lazy numbering because that's awful to read in source form
- nesting lists with two spaces
120 chars per line.
All supported features should be documented in doc/ and added to the json schema in schema/.
Most files have not been updated to follow the style fully. When touching a section, the code style of that section should be fixed.