Code organisation
Overview
The AliceO2 repository is subdivided in a number of sub-modules. The per detector sub-modules are grouped under the Detectors directory. The per function are in the top directory or grouped, e.g. Utilites.
A typical submodule looks like :
.
|-- Common
|   |-- CMakeLists.txt
|   |-- doc
|   |   `-- All documentation files
|   |-- include
|   |   `-- Common
|   |       `-- Factory.h
|   |-- src
|   |   |-- Internal.h
|   |   `-- Factory.cxx
|   `-- test
|       `-- TestFactory.cxx
Depending on the case, some subdirectories can be voluntarily left out or added. The headers go to the include directory if they are part of the interface, in the src otherwise.
Other repositories in AliceO2Group
Other repositories in the AliceO2Group follow the same structure.
Principles
A number of principles were agreed on that resulted in the above code organisation :
- A module is a set of code closely related sharing an interface that can result in one or more libraries.
- Favour is given to extracting large common components(modules/projects) into their own repositories within AliceO2Group in github.
- AliceO2 therefore becomes a thinner repo containing :
- Detector specific code (e.g. related to reconstruction, simulation, calibration or qc).
- Commonalities (e.g. DataFormat, Steer-like), i.e. things other components depend on and that have not been extracted to their own repo.
- Global algorithms (e.g. global tracking), i.e. things that depend on several detectors.
 
- The directory structure can be either per detector or per function or a mixture. The AliceO2 repository has a mixture of per detector and per function sub-modules with corresponding sub-structure.
- Naming : camel-case
- What is repeated / structural starts with a lower case letter (e.g. src, include, test).
- The rest (labels, unique names) start with an upper case letter (e.g. Common, Detectors).
 
- Why are headers in MyModule/include/MyModuleand not directly inMyModule/include ?
- The difficulty here is that we have a number of constraints. First the headers must be installed in a directory named after the module. Second the code which uses the headers must include MyModule/xyz.hand it must work whether it is inside AliceO2 or in a different repo, i.e. whether the headers are installed or they are internal. When evaluating the different options we ended up with this not-totally-perfect solution because all other solutions broke one of the constraints or required a massive hurdle of CMake magic. If someone comes up with a different working solution we would happily consider it.