podio_schema_evolution module
Provides infrastructure for analyzing schema definitions for schema evolution
- class podio_schema_evolution.AddedComponent(component, name)
Bases:
SchemaChange
Class representing an added component
- class podio_schema_evolution.AddedDatatype(datatype, name)
Bases:
SchemaChange
Class representing an added datatype
- class podio_schema_evolution.AddedMember(member, definition_name)
Bases:
SchemaChange
Class representing an added member
- class podio_schema_evolution.AddedMultiRelation(member, datatype)
Bases:
SchemaChange
Class representing an added OneToManyRelation
- class podio_schema_evolution.AddedSingleRelation(member, datatype)
Bases:
SchemaChange
Class representing an added OneToOneRelation
- class podio_schema_evolution.AddedVectorMember(member, datatype)
Bases:
SchemaChange
Class representing an added VectorMember
- class podio_schema_evolution.ChangedMemberType(name, old_member, new_member)
Bases:
SchemaChange
Class representing a type change in a member
- class podio_schema_evolution.DataModelComparator(yamlfile_new, yamlfile_old, evolution_file=None)
Bases:
object
Compares two datamodels and extracts required schema evolution
- check_rename(added_member, dropped_member, schema_changes)
Check whether this pair of addition / removal could be a rename and return True if it is found in the renamings and false otherwise
- compare() None
execute the comparison on-preloaded datamodel definitions
- filter_types_with_adds_and_drops(added_members, dropped_members)
Filter all additions and removals and return pairs of additions / removals that happen on the same datatype
- get_changed_schemata(schema_filter=None)
return the schemata which actually changed
- heuristics()
make an analysis of the data model changes: - check which can be auto-resolved - check which need extra information from the user - check which one are plain forbidden/impossible
- heuristics_members(added_members, dropped_members, schema_changes)
make analysis of member changes in a given data type
- print_comparison()
print the result of the datamodel comparison
- read() None
read datamodels from yaml files
- read_evolution_file() None
read and parse evolution file
- unsupported_changes = (<class 'podio_schema_evolution.AddedVectorMember'>, <class 'podio_schema_evolution.DroppedVectorMember'>, <class 'podio_schema_evolution.AddedSingleRelation'>, <class 'podio_schema_evolution.DroppedSingleRelation'>, <class 'podio_schema_evolution.AddedMultiRelation'>, <class 'podio_schema_evolution.DroppedMultiRelation'>)
- class podio_schema_evolution.DroppedComponent(component, name)
Bases:
SchemaChange
Class representing a dropped component
- class podio_schema_evolution.DroppedDatatype(datatype, name)
Bases:
SchemaChange
Class representing a dropped datatype
- class podio_schema_evolution.DroppedMember(member, definition_name)
Bases:
SchemaChange
Class representing a dropped member
- class podio_schema_evolution.DroppedMultiRelation(member, datatype)
Bases:
SchemaChange
Class representing a dropped OneToManyRelation
- class podio_schema_evolution.DroppedSingleRelation(member, datatype)
Bases:
SchemaChange
Class representing a dropped OneToOneRelation
- class podio_schema_evolution.DroppedVectorMember(member, datatype)
Bases:
SchemaChange
Class representing a dropped VectorMember
- class podio_schema_evolution.RenamedDataType(name_old, name_new)
Bases:
SchemaChange
Class representing a renamed datatype
- class podio_schema_evolution.RenamedMember(name, member_name_old, member_name_new)
Bases:
SchemaChange
Class representing a renamed member
- class podio_schema_evolution.RootIoRule
Bases:
object
A placeholder IORule class
- class podio_schema_evolution.SchemaChange(description)
Bases:
object
The base class for all schema changes providing a brief description as representation
- podio_schema_evolution.root_filter(schema_changes)
Checks what is required/supported for the ROOT backend
At this point in time we are only interested in renames. Everything else will be done by ROOT automatically
- podio_schema_evolution.sio_filter(schema_changes)
Checks what is required/supported for the SIO backend
At this point in time all schema changes have to be handled on PODIO side