Style Guide¶
This document provides a guide to the style used in this project.
Code Formatting¶
We utilize ClangFormat to automate code formatting. Please format your code before pushing and/or creating a pull request.
Naming conventions¶
General¶
In general, we stick to the following naming conventions:
- snake_casefor variables, functions, and filenames
- PascalCasefor classes and structs
- ALL_CAPSfor constants and enum members
- m_prefix for class member variables (if the member is not public)
- member()to get a class member variable (if the member is not public)
- set_member()to set a class member variable (if the member is not public)
Specific¶
- vertex positions: - verticesor- positions
- vertex displacements: - displacements
- vertex rest positions/material coordinates: - rest_positions
- vertex velocities: - velocities
- mesh edge matrix: - edges
- mesh face matrix: - faces
- element vertices: we use a numeral suffix (e.g., - e0and- e1for the end-points of an edge)
- edge-edge pairings: suffix of - aand- b
- continuous collision detection pairs: suffix of - _t0for starting values and- _t1for end values
Documentation¶
We use Doxygen to generate documentation. Please document your code before pushing and/or creating a pull request.