Include partial YAML files
You can include a partial YAML file from specific objects within the configuration object:
Each of the objects above can have an $include property which is a
sequence of names of files to include.
By choosing where to include partial YAML files strategically, you can split a configuration object into multiple reusable parts for different systems or projects.
Inclusion file search
barectf tries to find each file of an $include property sequence in
specific directories.
When using the barectf CLI tool’s
generate or
show-effective-configuration
commands, the inclusion directory search order is:
- 
The value of each --include-diroption, in order.
- 
The current working directory. 
- 
The directory containing the standard inclusion files (like stdint.yamlandstdmisc.yaml).
By default, if barectf can’t find an inclusion file, the command
prints an error and exits with a
non-zero status. Force barectf to continue silently instead with its
--ignore-include-not-found
option.
Inclusion rules
With the $include property, an object includes the properties of
one or more YAML documents.
barectf processes the items of the $include property sequence
in order.
When an object A includes a YAML document B, the effective object is A “patching” B.
For a given property of A, the patching rules are:
| A's property type | <em>A</em>'s property exists in <em>B</em> | <em>A</em>'s property doesn’t exist in <em>B</em> | 
|---|---|---|
| Null, boolean, integer, and string | Replace B's property with A's property. | Keep A's property. | 
| Sequence | 
 | Keep A's property. | 
| Mapping | 
 | Keep A's property. | 
| When A's property replaces B's property and the value of A's property is null, this effectively “resets” the property to its default value. | 
Examples
base.yamllog-level: WARN
payload-field-type:
  class: structure
  members:
    - msg: string
    - msg_id: uint16$include: [base.yaml]
log-level: ERRORlog-level: ERROR
payload-field-type:
  class: structure
  members:
    - msg: string
    - msg_id: uint16base.yamlfrequency: 1000000
offset:
  seconds: 1992839$include: [base.yaml]
frequency: 8000000
origin-is-unix-epoch: falsefrequency: 8000000
offset:
  seconds: 1992839
origin-is-unix-epoch: falsebase.yaml$field-type-aliases:
  my-enum:
    class: signed-enumeration
    mappings:
      COMPOSE:
        - 56
        - [100, 299]
      DIRTY: [0]$include: [base.yaml]
$field-type-aliases:
  my-enum:
    size: 16
    mappings:
      COMPOSE:
        - -22
# ...$field-type-aliases:
  my-enum:
    class: signed-enumeration
    size: 16
    mappings:
      COMPOSE:
        - 56
        - [100, 299]
        - -22
      DIRTY: [0]
# ...base.yamlspecific-context-field-type:
  class: structure
  members:
    - msg: string
    - user_id: uint16$include: [base.yaml]
specific-context-field-type:
  class: structure
  members:
    - src_ip_addr:
        field-type:
          class: static-array
          length: 4
          element-field-type: uint8
    - user_id: int8specific-context-field-type:
  class: structure
  members:
    - msg: string
    - user_id: int8
    - src_ip_addr:
        field-type:
          class: static-array
          length: 4
          element-field-type: uint8Standard partial YAML files
The barectf project ships with a few “standard” partial YAML files to be included from a trace type object:
- stdint.yaml
- 
Standard integer field type aliases, like uint8,byte-packed-sint16, andbit-packed-uint64.
- stdreal.yaml
- 
Standard real field type aliases, like floatanddouble.
- stdmisc.yaml
- 
The stringandstrstring field type aliases.
- lttng-ust-log-levels.yaml
- 
Log level aliases which correspond to the LTTng-UST log levels.