-
Notifications
You must be signed in to change notification settings - Fork 29
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
aasx.adapter: fix semantic id type deserialization of ModelReference
#337
aasx.adapter: fix semantic id type deserialization of ModelReference
#337
Conversation
968597b
to
9f0dea6
Compare
Thank you very much for your input! I agree that our SDK should not discard content without warning when reading and writing again, so that is definitly something that needs to be addressed. Regarding your suggestions: I need to do some more thinking about which solution is the one with the least repercussions. I'll bring this discussion to our dev meeting and will get back to you. |
Thanks for investigating the topic so far! |
904e747
to
381d6a9
Compare
I added a test that covers all semantic ids that are expected to be ModelReferences for the same type. |
This is what we concluded in our meeting:
Sadly, I did not have time yet to look deeper into the matter. |
ee006dc
to
a441d20
Compare
I rebased on main and changed to a re-raise for those cases. It will raise an error if the reference is a This will still not check if
|
Don't log `ModelReferences` not pointing to `ConceptDescriptions`, as it is not contrained by the spec. Warn about missing references, as the `object_store` seems to be incomplete.
a441d20
to
f0c7eb1
Compare
Many AASX packages include semantic ids with external or model references.
Concept descriptions are lost when reading and writing back to AASX
Problem
When a semantic id with a
ModelReference
is deserialized itstype
is currently set to the abstract typeReferable
.When the aasx is serialized again and the semantic id refers to a concept description, it is skipped, because only concrete
ModelReference
types are looked up and serialized.Solutions
type
of the semantic id to the concrete type determined by the last key element.Writing aasx with external references as semantic ids produce many info logs
Problem
Often an external reference with a global id (e.g. to ECLASS IRDIs) is used as semantic id.
A typical technical data submodel may easily contain around 100 of them.
Writing to an aasx will print an info message for each semantic id, that is not a model reference to an concept description, which clutters the output.
Solutions