2018-06-13 20:22:46 +00:00
|
|
|
# Code Style Guidelines
|
2018-06-01 19:24:46 +00:00
|
|
|
|
|
|
|
## Basics
|
|
|
|
|
|
|
|
Basic statements:
|
|
|
|
|
|
|
|
```c++
|
|
|
|
void global_function(int arg1, int arg2,
|
|
|
|
int arg3, ...)
|
|
|
|
{
|
|
|
|
int value;
|
|
|
|
const int constValue = 0;
|
|
|
|
|
|
|
|
if (condition) {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i=0; i<10; ++i) {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
while (condition) {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
do {
|
|
|
|
...
|
2021-01-14 15:45:32 +00:00
|
|
|
} while (condition);
|
2018-06-01 19:24:46 +00:00
|
|
|
|
|
|
|
switch (condition) {
|
|
|
|
case 1:
|
|
|
|
...
|
|
|
|
break;
|
|
|
|
case 2: {
|
|
|
|
int varInsideCase;
|
|
|
|
...
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Namespaces
|
|
|
|
|
|
|
|
Define namespaces with lower case:
|
|
|
|
|
|
|
|
```c++
|
|
|
|
namespace app {
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
} // namespace app
|
|
|
|
```
|
|
|
|
|
|
|
|
## Classes
|
|
|
|
|
|
|
|
Define classes with `CapitalCase` and member functions with `camelCase`:
|
|
|
|
|
|
|
|
```c++
|
|
|
|
class ClassName {
|
|
|
|
public:
|
|
|
|
ClassName();
|
|
|
|
virtual ~ClassName();
|
|
|
|
|
|
|
|
int memberVar() const { return m_memberVar; }
|
|
|
|
void setMemberVar();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void protectedMember();
|
|
|
|
|
|
|
|
private:
|
|
|
|
int m_memberVar;
|
|
|
|
};
|
|
|
|
```
|
|
|
|
|
|
|
|
## C++11
|
|
|
|
|
2020-09-20 16:16:14 +00:00
|
|
|
We are using some modern C++ (C++11, C++14, etc.) features, mainly:
|
2018-06-01 19:24:46 +00:00
|
|
|
|
|
|
|
* Use `nullptr` instead of `NULL` macro
|
2020-09-20 16:16:14 +00:00
|
|
|
* Use `auto` for complex types, iterators, or when the variable type
|
|
|
|
is obvious (e.g. `auto s = new Sprite;`)
|
2018-06-01 19:24:46 +00:00
|
|
|
* Use range-based for loops (`for (const auto& item : values) { ... }`)
|
|
|
|
* Use template alias (`template<typename T> alias = orig<T>;`)
|
|
|
|
* Use non-generic lambda functions
|
2020-04-24 15:07:52 +00:00
|
|
|
* Use `std::shared_ptr` and `std::unique_ptr`
|
|
|
|
* Use `base::clamp` (no `std::clamp` yet)
|
|
|
|
* Use `static constexpr T v = ...;`
|
2018-06-01 19:24:46 +00:00
|
|
|
* You can use `<atomic>`, `<thread>`, `<mutex>`, and `<condition_variable>`
|
2020-04-24 15:07:52 +00:00
|
|
|
* We can use `using T = ...;` instead of `typedef ... T`
|
|
|
|
* We use gcc 9.2 or clang 9.0 on Linux, so check the features available in
|
2018-08-03 15:00:38 +00:00
|
|
|
https://developer.mozilla.org/en-US/docs/Mozilla/Using_CXX_in_Mozilla_code
|