To describe a data model PODIO provides a data model definition syntax.
This is to ease the creation of optimised data formats, which may take advantage of a so-called struct-of-array
data layout.
From the user-provided data model description PODIO creates all the files necessary to use this data model.
PODIO encourages the usage of composition, rather than inheritance.
One of the reasons for doing so is the focus on efficiency friendly plain-old-data
.
For this reason, PODIO does not support inheritance within the defined data model.
Instead, users can combine multiple components
to build a to be used datatype
.
To allow the datatypes to be real PODs, the data stored within the data model are constrained to be POD-compatible data. Those are
- basic types like int, double, etc
- components built up from basic types or other components
- Fixed sized arrays of those types
In addition, PODIO supports the storage of one-to-one and one-to-many relations between objects. In the following the syntax for defining a given data model is explained. A later section contains more details about the code being created from this.
A component is just a flat struct containing data. it can be defined via:
components:
# My example component
MyComponent:
x : float
y : float
z : float
a : AnotherComponent
Here an excerpt from "datamodel.yaml" for a simple class, just containing one member of the type int
.
datatypes :
EventInfo :
Description : "My first data type"
Author : "It's me"
Members :
- int Number // event number
Using this definition, three classes will be created: EventInfo
, EventInfoData
and EventInfoCollection
. These have the following signature:
class EventInfoData {
public:
int Number;
}
class EventInfo {
public:
...
int Number() const;
void Number(int);
...
}
The definition of a member is done in the Members
section in the form:
Members:
<type> <name> // <comment>
where type
can be any buildin-type or a component
.
There can be one-to-one-relations and one-to-many relations being stored in a particular class. This happens either in the OneToOneRelations
or OneToManyRelations
section of the data definition. The definition has again the form:
OneToOneRelations:
<type> <name> // <comment>
OneToManyRelations:
<type> <name> // <comment>
In a few cases, it makes sense to add some more functionality to the created classes. Thus this library provides two ways of defining additional methods and code. Either by defining them inline or in external files. Extra code has to be provided separately for const and non-const additions.
ExtraCode:
declaration: <string>
implementation : <string>
declarationFile: <string> (to be implemented!)
implementationFile: <string> (to be implemented!)
ConstExtraCode:
declaration: <string>
implementation : <string>
declarationFile: <string> (to be implemented!)
implementationFile: <string> (to be implemented!)
The code being provided has to use the macro {name}
in place of the concrete name of the class.
Some customization of the generated code is possible through flags. These flags are listed in the section options
:
options:
getSyntax: False
exposePODMembers: True
components:
# My simple component
ExampleComponent:
x : int
datatypes:
ExampleType:
Description: "My datatype with a component member"
Author: "Mr me"
Members:
- ExampleComponent comp // component from above
getSyntax
: steers the naming of get and set methods. If set to true, methods are prefixed withget
andset
following the capitalized member name, otherwise the member name is used for both.exposePODMembers
: whether get and set methods are also generated for members of a member-component. In the example corresponding methods would be generated to directly set / getx
throughExampleType
.