buildat/conventions.txt

88 lines
3.2 KiB
Plaintext
Raw Normal View History

2014-09-17 09:37:11 +03:00
Buildat conventions
===================
2014-09-20 19:05:30 +03:00
C++ Coding style
----------------
2014-09-17 09:37:11 +03:00
Look at the code. It is perfect and will be kept perfect. Requests to fix coding
style are not to be taken personally by the one requesting, nor the one being
2014-09-17 11:28:15 +03:00
requested to fix his style. If something is found to be missing from this
document, such additions shall be made.
2014-09-17 09:37:11 +03:00
2014-09-20 19:05:30 +03:00
util/codestyle.sh:
2014-09-17 11:20:36 +03:00
Always run util/codestyle.sh before committing. It handles most whitespace
issues.
Identifiers:
- Class and struct names are CamelCase,
- All function names are lowercase_with_underscores,
- All variable names are lowercase_with_underscores,
2014-09-17 13:37:34 +03:00
- All member variables start with m_. If the struct in question is a stupid data
container, this does not need to be followed.
2014-09-17 11:20:36 +03:00
Never use "class", always use "struct".
2014-09-17 11:28:15 +03:00
Prefer lightweight interfaces with a creation function for the default
implementation, like "struct State" and "State* createState()". The default
implementation can be called "CState" in this case, if an obviously better name
does not exist.
Use std::unique_ptr and std::shared_ptr. (core/types.h: up_<> and sp_<>)
2014-09-20 10:04:28 +03:00
Header files must have zero preprocessor conditionals.
2014-09-17 13:37:34 +03:00
Function naming:
- Suffix _u: Unsafe, not included in public interface
2014-09-17 16:55:56 +03:00
Do not use assert(); throw anonymous exceptions instead:
- if(fail) throw Exception("Thing failed");
Naming:
- "type": Numeric id representing a type
- "name": A string; generally works as an identifier but not necessarily
- "id": Numeric id of an instance of something that is not a type
Logging:
- Use core/log.h. Only use stdout directly in case of an interactive command
line interface (like printing errors for command line arguments).
Ordering of #include directives:
1) The interface that the current file implements, ""
2) Internal interfaces, from core-ish to utility-ish, ""
3) Bundled libraries, <>
4) Installed libraries, <>
5) STL headers, <>
6) System headers, <>
2014-09-17 09:37:11 +03:00
Non-exception throwing and exception-throwing methods
-----------------------------------------------------
- get_x: Returns NULL or equivalent if not found
- check_x: Throws exception if not found
2014-09-17 11:24:54 +03:00
Directory structure
-------------------
├── 3rdparty << Bundled 3rd-party libraries
├── Build << Build files; "mkdir Build; cmake ..; make"
2014-09-17 11:24:54 +03:00
├── cache << Runtime directory used by Buildat
2014-09-19 10:40:10 +03:00
├── builtin << Built-in modules
├── client << Built-in client files
├── extensions << Built-in client extensions
2014-09-17 11:24:54 +03:00
├── src
│   ├── client << Client-specific code
│   ├── core << Core code (must be kept minimal but sufficient)
│   ├── impl << Interface implementations
│   ├── interface << Interface available to modules
│   └── server << Server-specific code
├── test << All kinds of stuff for testing
└── util << Miscellaneous development utilities
2014-09-17 09:44:09 +03:00
Commit messages
---------------
In present tense. Prepend a location to the message where possible. When adding
2014-09-17 11:20:36 +03:00
something, the "add" verb should be left out. Fine enough examples:
2014-09-17 09:44:09 +03:00
- interface::Server::check_module
- doc: conventions.txt, todo.txt
- Bind a socket but don't listen to it yet
- Remove Module::test_add
- client, 3rdparty/c55lib: Command-line parameters
- 3rdparty/cereal