PySimultan 0.1.53__py3-none-any.whl → 0.2__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (182) hide show
  1. PySimultan-0.2.dist-info/LICENSE.txt +17 -0
  2. PySimultan-0.2.dist-info/METADATA +36 -0
  3. PySimultan-0.2.dist-info/RECORD +82 -0
  4. {PySimultan-0.1.53.dist-info → PySimultan-0.2.dist-info}/WHEEL +1 -1
  5. PySimultan-0.2.dist-info/top_level.txt +1 -0
  6. {PySimultan → PySimultan2}/__init__.py +11 -6
  7. PySimultan2/config.py +52 -0
  8. PySimultan2/data_model.py +713 -0
  9. PySimultan2/default_types.py +507 -0
  10. PySimultan2/files.py +371 -0
  11. PySimultan2/geometry/__init__.py +4 -0
  12. PySimultan2/geometry/geometry_base.py +654 -0
  13. PySimultan2/geometry/utils.py +181 -0
  14. PySimultan2/multi_values.py +277 -0
  15. PySimultan2/object_mapper.py +200 -0
  16. PySimultan2/resources/AssimpNet.dll +0 -0
  17. PySimultan2/resources/AvalonDock.dll +0 -0
  18. PySimultan2/resources/BruTile.dll +0 -0
  19. PySimultan2/resources/ClosedXML.dll +0 -0
  20. PySimultan2/resources/ComponentBuilder.dll +0 -0
  21. PySimultan/resources/ComponentBuilder.exe.config → PySimultan2/resources/ComponentBuilder.dll.config +6 -2
  22. PySimultan2/resources/ComponentBuilder.runtimeconfig.json +18 -0
  23. {PySimultan → PySimultan2}/resources/ComponentBuilder.xml +11877 -6754
  24. PySimultan2/resources/ControlzEx.dll +0 -0
  25. PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
  26. PySimultan2/resources/DocumentFormat.OpenXml.dll +0 -0
  27. PySimultan2/resources/ExcelNumberFormat.dll +0 -0
  28. PySimultan2/resources/Fluent.dll +0 -0
  29. PySimultan2/resources/GeometryViewer.dll +0 -0
  30. {PySimultan → PySimultan2}/resources/GeometryViewer.xml +2201 -1155
  31. PySimultan2/resources/HelixToolkit.Core.Wpf.dll +0 -0
  32. PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll +0 -0
  33. PySimultan2/resources/HelixToolkit.SharpDX.Core.dll +0 -0
  34. PySimultan2/resources/HelixToolkit.dll +0 -0
  35. PySimultan2/resources/MathNet.Numerics.dll +0 -0
  36. PySimultan2/resources/Microsoft.AspNetCore.Authorization.dll +0 -0
  37. PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll +0 -0
  38. PySimultan2/resources/Microsoft.Extensions.DependencyInjection.Abstractions.dll +0 -0
  39. PySimultan2/resources/Microsoft.Extensions.Logging.Abstractions.dll +0 -0
  40. PySimultan2/resources/Microsoft.Extensions.Options.dll +0 -0
  41. PySimultan2/resources/Microsoft.Extensions.Primitives.dll +0 -0
  42. PySimultan2/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
  43. PySimultan2/resources/Microsoft.WindowsAPICodePack.dll +0 -0
  44. PySimultan2/resources/Microsoft.Xaml.Behaviors.dll +0 -0
  45. PySimultan2/resources/Newtonsoft.Json.Bson.dll +0 -0
  46. PySimultan2/resources/Newtonsoft.Json.dll +0 -0
  47. PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
  48. PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll +0 -0
  49. PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll.config +15 -0
  50. PySimultan2/resources/SIMULTAN.Lang.dll +0 -0
  51. {PySimultan → PySimultan2}/resources/SIMULTAN.Lang.xml +5282 -3252
  52. PySimultan2/resources/SIMULTAN.Plugins.dll +0 -0
  53. {PySimultan → PySimultan2}/resources/SIMULTAN.Plugins.xml +110 -0
  54. PySimultan2/resources/SIMULTAN.UI.dll +0 -0
  55. {PySimultan → PySimultan2}/resources/SIMULTAN.UI.xml +10483 -4937
  56. PySimultan2/resources/SIMULTAN.dll +0 -0
  57. PySimultan2/resources/SIMULTAN.xml +34122 -0
  58. PySimultan2/resources/SharpDX.D3DCompiler.dll +0 -0
  59. PySimultan2/resources/SharpDX.DXGI.dll +0 -0
  60. PySimultan2/resources/SharpDX.Direct2D1.dll +0 -0
  61. PySimultan2/resources/SharpDX.Direct3D11.dll +0 -0
  62. PySimultan2/resources/SharpDX.Direct3D9.dll +0 -0
  63. {PySimultan → PySimultan2}/resources/SharpDX.Mathematics.dll +0 -0
  64. PySimultan2/resources/SharpDX.dll +0 -0
  65. {PySimultan → PySimultan2}/resources/SitePlanner.dll +0 -0
  66. {PySimultan → PySimultan2}/resources/SitePlanner.xml +959 -1110
  67. PySimultan2/resources/Sprache.dll +0 -0
  68. PySimultan2/resources/System.Data.OleDb.dll +0 -0
  69. PySimultan2/resources/System.Net.Http.Formatting.dll +0 -0
  70. PySimultan2/resources/XAMLMarkupExtensions.dll +0 -0
  71. PySimultan2/resources/assimp.dll +0 -0
  72. {PySimultan → PySimultan2}/resources/defaultsettings.xml +0 -0
  73. PySimultan2/simultan_object.py +366 -0
  74. PySimultan2/taxonomy_maps.py +169 -0
  75. PySimultan2/utils.py +1383 -0
  76. PySimultan/config.py +0 -57
  77. PySimultan/data_model.py +0 -376
  78. PySimultan/default_types.py +0 -1771
  79. PySimultan/geo_default_types.py +0 -763
  80. PySimultan/geometry.py +0 -309
  81. PySimultan/resources/AssimpNet.dll +0 -0
  82. PySimultan/resources/AssimpNet.xml +0 -12074
  83. PySimultan/resources/BruTile.dll +0 -0
  84. PySimultan/resources/BruTile.xml +0 -1845
  85. PySimultan/resources/ControlzEx.dll +0 -0
  86. PySimultan/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
  87. PySimultan/resources/DXFImportExport.dll +0 -0
  88. PySimultan/resources/DotSpatial.Projections.xml +0 -5879
  89. PySimultan/resources/EXCELImportExport.dll +0 -0
  90. PySimultan/resources/Fluent.dll +0 -0
  91. PySimultan/resources/Fluent.xml +0 -9103
  92. PySimultan/resources/GeoJSON.Net.dll +0 -0
  93. PySimultan/resources/GeometryViewer.Data.dll +0 -0
  94. PySimultan/resources/GeometryViewer.Data.xml +0 -4443
  95. PySimultan/resources/GeometryViewer.Shared.dll +0 -0
  96. PySimultan/resources/GeometryViewer.Shared.xml +0 -588
  97. PySimultan/resources/GeometryViewer.dll +0 -0
  98. PySimultan/resources/HelixToolkit.Wpf.SharpDX.dll +0 -0
  99. PySimultan/resources/HelixToolkit.Wpf.SharpDX.xml +0 -43219
  100. PySimultan/resources/HelixToolkit.Wpf.dll +0 -0
  101. PySimultan/resources/HelixToolkit.Wpf.xml +0 -22363
  102. PySimultan/resources/HelixToolkit.dll +0 -0
  103. PySimultan/resources/HelixToolkit.xml +0 -144
  104. PySimultan/resources/ImportLog_SMART_CAMPUS_TU_WIEN_BIBLIOTHEK_20210305_ZONENMODELL_23_11_2021-06_54_54.txt +0 -1
  105. PySimultan/resources/LibGit2Sharp.dll +0 -0
  106. PySimultan/resources/LibGit2Sharp.dll.config +0 -4
  107. PySimultan/resources/LibGit2Sharp.xml +0 -13770
  108. PySimultan/resources/MathNet.Numerics.dll +0 -0
  109. PySimultan/resources/MathNet.Numerics.xml +0 -57152
  110. PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
  111. PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.xml +0 -25496
  112. PySimultan/resources/Microsoft.WindowsAPICodePack.dll +0 -0
  113. PySimultan/resources/Microsoft.WindowsAPICodePack.xml +0 -2934
  114. PySimultan/resources/Newtonsoft.Json.dll +0 -0
  115. PySimultan/resources/Newtonsoft.Json.xml +0 -11305
  116. PySimultan/resources/ParameterStructure.dll +0 -0
  117. PySimultan/resources/ParameterStructure.xml +0 -10750
  118. PySimultan/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
  119. PySimultan/resources/SIMULTAN.DataExchange.dll +0 -0
  120. PySimultan/resources/SIMULTAN.Lang.dll +0 -0
  121. PySimultan/resources/SIMULTAN.Legacy.dll +0 -0
  122. PySimultan/resources/SIMULTAN.Legacy.xml +0 -254
  123. PySimultan/resources/SIMULTAN.Plugins.dll +0 -0
  124. PySimultan/resources/SIMULTAN.Project.dll +0 -0
  125. PySimultan/resources/SIMULTAN.Project.dll.config +0 -11
  126. PySimultan/resources/SIMULTAN.UI.dll +0 -0
  127. PySimultan/resources/SIMULTAN.Util.dll +0 -0
  128. PySimultan/resources/SIMULTAN.Util.xml +0 -3430
  129. PySimultan/resources/SharpDX.D3DCompiler.dll +0 -0
  130. PySimultan/resources/SharpDX.D3DCompiler.xml +0 -5897
  131. PySimultan/resources/SharpDX.DXGI.dll +0 -0
  132. PySimultan/resources/SharpDX.DXGI.xml +0 -8737
  133. PySimultan/resources/SharpDX.Direct2D1.dll +0 -0
  134. PySimultan/resources/SharpDX.Direct2D1.xml +0 -46691
  135. PySimultan/resources/SharpDX.Direct3D11.dll +0 -0
  136. PySimultan/resources/SharpDX.Direct3D11.xml +0 -31826
  137. PySimultan/resources/SharpDX.Direct3D9.dll +0 -0
  138. PySimultan/resources/SharpDX.Direct3D9.xml +0 -36489
  139. PySimultan/resources/SharpDX.Mathematics.xml +0 -16449
  140. PySimultan/resources/SharpDX.dll +0 -0
  141. PySimultan/resources/Sprache.dll +0 -0
  142. PySimultan/resources/Sprache.xml +0 -1199
  143. PySimultan/resources/System.Net.Http.Formatting.dll +0 -0
  144. PySimultan/resources/System.Net.Http.Formatting.xml +0 -2094
  145. PySimultan/resources/System.Windows.Interactivity.dll +0 -0
  146. PySimultan/resources/TalkGit.dll +0 -0
  147. PySimultan/resources/TalkGit.dll.config +0 -11
  148. PySimultan/resources/WebServiceConnector.dll +0 -0
  149. PySimultan/resources/WebServiceConnector.dll.config +0 -11
  150. PySimultan/resources/XAMLMarkupExtensions.dll +0 -0
  151. PySimultan/resources/XAMLMarkupExtensions.xml +0 -862
  152. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Aero.dll +0 -0
  153. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Metro.dll +0 -0
  154. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.VS2010.dll +0 -0
  155. PySimultan/resources/Xceed.Wpf.AvalonDock.dll +0 -0
  156. PySimultan/resources/Xceed.Wpf.Toolkit.dll +0 -0
  157. PySimultan/resources/assimp.dll +0 -0
  158. PySimultan/resources/schema.yaml +0 -13
  159. PySimultan/resources/simultan_exception_07_10_2021-08_34_24.txt +0 -17
  160. PySimultan/resources/simultan_exception_07_10_2021-10_13_31.txt +0 -17
  161. PySimultan/resources/simultan_exception_11_10_2021-19_45_42.txt +0 -17
  162. PySimultan/resources/simultan_exception_22_11_2021-16_41_52.txt +0 -14
  163. PySimultan/resources/simultan_exception_22_11_2021-17_37_40.txt +0 -14
  164. PySimultan/simultan_geometry_utils.py +0 -81
  165. PySimultan/simultan_utils.py +0 -165
  166. PySimultan/slots.py +0 -51
  167. PySimultan/template_tools.py +0 -628
  168. PySimultan/utils.py +0 -298
  169. PySimultan-0.1.53.dist-info/LICENSE +0 -674
  170. PySimultan-0.1.53.dist-info/LICENSE.txt +0 -674
  171. PySimultan-0.1.53.dist-info/METADATA +0 -690
  172. PySimultan-0.1.53.dist-info/RECORD +0 -119
  173. PySimultan-0.1.53.dist-info/entry_points.txt +0 -3
  174. PySimultan-0.1.53.dist-info/top_level.txt +0 -1
  175. PySimultan-0.1.53.dist-info/zip-safe +0 -1
  176. {PySimultan → PySimultan2}/resources/DotSpatial.Projections.dll +0 -0
  177. {PySimultan → PySimultan2}/resources/GeometryViewer.dll.config +0 -0
  178. {PySimultan → PySimultan2}/resources/SIMULTAN.AutoUpdate.Client.dll.config +0 -0
  179. {PySimultan → PySimultan2}/resources/SitePlanner.dll.config +0 -0
  180. {PySimultan → PySimultan2}/resources/Sprache.Calc.dll +0 -0
  181. {PySimultan → PySimultan2}/resources/__init__.py +0 -0
  182. {PySimultan → PySimultan2}/resources/setup.bat +0 -0
Binary file
Binary file
@@ -0,0 +1,366 @@
1
+ import hashlib
2
+ import json
3
+
4
+ from copy import copy
5
+ from weakref import WeakSet, WeakValueDictionary
6
+ from . import utils
7
+ from numpy import ndarray
8
+ import colorlog
9
+ from typing import Union
10
+
11
+ logger = colorlog.getLogger('PySimultan')
12
+
13
+ from SIMULTAN.Data.Taxonomy import SimTaxonomyEntry, SimTaxonomyEntryReference, SimTaxonomy
14
+ from SIMULTAN.Data.Components import (ComponentWalker, SimComponent, SimBoolParameter, SimDoubleParameter,
15
+ SimEnumParameter, SimIntegerParameter, SimStringParameter, ComponentMapping,
16
+ SimSlot, ComponentMapping)
17
+ from SIMULTAN.Data.Assets import ResourceEntry, ResourceFileEntry, ContainedResourceFileEntry, Asset
18
+ from SIMULTAN.Data import SimId
19
+
20
+ from typing import TYPE_CHECKING
21
+ if TYPE_CHECKING:
22
+ from .data_model import DataModel
23
+ from .object_mapper import PythonMapper
24
+ from .geometry.geometry_base import ExtendedBaseGeometry
25
+
26
+ from .geometry.utils import create_python_geometry
27
+
28
+ from . import config
29
+
30
+
31
+ class ComplexEncoder(json.JSONEncoder):
32
+ def default(self, obj):
33
+ if isinstance(obj, SimultanObject):
34
+ return obj.to_json()
35
+ # Let the base class default method raise the TypeError
36
+ return json.JSONEncoder.default(self, obj)
37
+
38
+
39
+ class classproperty(object):
40
+
41
+ def __init__(self, getter):
42
+ self.getter = getter
43
+
44
+ def __get__(self, instance, owner):
45
+ return self.getter(owner)
46
+
47
+
48
+ class MetaMock(type):
49
+ def __call__(cls: 'SimultanObject', *args, **kwargs) -> 'SimultanObject':
50
+ """
51
+ Metaclass to implement object initialization either with wrapped_obj or keywords.
52
+
53
+ If a wrapped_obj is defined, create new SimultanObject which wraps a SIMULTAN component (wrapped_obj).
54
+
55
+ If no 'wrapped_obj' is defined, a new SimComponent is created with the content defined in the template and the
56
+ values are set to the values defined in kwargs.
57
+ """
58
+
59
+ obj = cls.__new__(cls, *args, **kwargs)
60
+
61
+ wrapped_obj = kwargs.get('wrapped_obj', None)
62
+ if wrapped_obj is None:
63
+
64
+ data_model = kwargs.get('data_model', None)
65
+ if data_model is None:
66
+ from .data_model import data_models
67
+ if list(data_models.data).__len__() == 1:
68
+ data_model = list(data_models.data)[0]()
69
+ kwargs['data_model'] = data_model
70
+ else:
71
+ if config.default_data_model is not None:
72
+ data_model = config.default_data_model
73
+ kwargs['data_model'] = data_model
74
+ else:
75
+ raise TypeError((f'Error creating new instance of class {cls.__name__}:\n'
76
+ f'Any data model was defined. Tried to use default data model but there are multiple datamodels.\n'
77
+ f'Define the data model to use with the key: data_model'))
78
+
79
+ wrapped_obj = cls.create_simultan_component(*args, **kwargs)
80
+
81
+ init_dict = kwargs.copy()
82
+ init_dict['data_model_id'] = data_model.id
83
+ init_dict['object_mapper'] = cls._object_mapper
84
+ init_dict['data_model'] = data_model
85
+ init_dict['wrapped_obj'] = wrapped_obj
86
+ obj.__init__(*args, **init_dict)
87
+
88
+ # for key, value in kwargs.items():
89
+ # if key in ['data_model', 'wrapped_obj', 'object_mapper']:
90
+ # continue
91
+ # setattr(obj, key, value)
92
+
93
+ else:
94
+ obj.__init__(*args, **kwargs)
95
+ return obj
96
+
97
+
98
+ class SimultanObject(object, metaclass=MetaMock):
99
+
100
+ _cls_instances = WeakSet() # weak set with all created objects
101
+ _create_all = False # if true all properties are evaluated to create python objects when initialized
102
+ _cls_instances_dict_cache = None
103
+ __type_view__ = None # ui view cls
104
+
105
+ @classproperty
106
+ def _cls_instances_dict(cls) -> dict[SimId, 'SimultanObject']:
107
+ return dict(zip([x.id for x in cls._cls_instances], [x for x in cls._cls_instances]))
108
+
109
+ @classproperty
110
+ def cls_instances(cls) -> list['SimultanObject']:
111
+ try:
112
+ _ = cls._cls_instances
113
+ return list(cls._cls_instances)
114
+ except Exception as e:
115
+ logger.error(f'Error getting cls_instances: {e}')
116
+ return []
117
+
118
+ @classmethod
119
+ def create_simultan_component(cls, *args, **kwargs) -> SimComponent:
120
+ wrapped_obj = utils.create_simultan_component_for_taxonomy(cls, *args, **kwargs)
121
+ wrapped_obj.Name = kwargs.get('name', 'UnnamedComponent')
122
+ return wrapped_obj
123
+
124
+ def __new__(cls, *args, **kwargs):
125
+ instance = super().__new__(cls)
126
+ if not hasattr(cls, '_cls_instances'):
127
+ cls._cls_instances = WeakSet()
128
+ try:
129
+ cls._cls_instances.add(instance)
130
+ except Exception as e:
131
+ logger.error(f'Error adding instance {instance} to _cls_instances: {e}')
132
+
133
+ return instance
134
+
135
+ def __init__(self, *args, **kwargs):
136
+ self._wrapped_obj: Union[SimComponent, None] = kwargs.get('wrapped_obj', None)
137
+ self.__obj_init__ = kwargs.get('__obj_init__', False)
138
+ self._data_model_id = kwargs.get('data_model_id', None)
139
+ self._data_model: Union[DataModel, None] = kwargs.get('data_model', config.default_data_model)
140
+ self._object_mapper: Union[PythonMapper, None] = kwargs.get('object_mapper', config.default_mapper)
141
+ self.name = kwargs.get('name', None)
142
+
143
+ self.__ui_element__ = None # view object for the object
144
+
145
+ self._slot = None
146
+
147
+ def __getattribute__(self, attr):
148
+
149
+ try:
150
+ return object.__getattribute__(self, attr)
151
+ except AttributeError:
152
+ wrapped = object.__getattribute__(self, '_wrapped_obj')
153
+ if wrapped is not None:
154
+ return object.__getattribute__(wrapped, attr)
155
+ else:
156
+ raise KeyError
157
+
158
+ def __setattr__(self, attr, value):
159
+ if hasattr(self, '_wrapped_obj'):
160
+ if hasattr(self._wrapped_obj, attr) and (self._wrapped_obj is not None) and not self.__obj_init__:
161
+ object.__setattr__(self._wrapped_obj, attr, value)
162
+ return
163
+ # object.__setattr__(self, attr, value)
164
+ super().__setattr__(attr, value)
165
+
166
+ # if hasattr(super(self.__class__), attr):
167
+ # super(self.__class__).__setattr__(attr, value)
168
+
169
+ @property
170
+ def id(self) -> SimId:
171
+ if self._wrapped_obj is not None:
172
+ return self._wrapped_obj.Id
173
+
174
+ @property
175
+ def id_str(self) -> str:
176
+ return '_'.join((str(self.id.GlobalId), str(self.id.LocalId)))
177
+
178
+ @property
179
+ def json_ref(self):
180
+ return {"_ref": {
181
+ "$ref": self.__class__.__name__,
182
+ "$id": {
183
+ "$oid": self.id_str
184
+ }
185
+ }}
186
+
187
+ @property
188
+ def name(self) -> str:
189
+ if self._wrapped_obj is not None:
190
+ return self._wrapped_obj.Name
191
+
192
+ @name.setter
193
+ def name(self, value: str):
194
+ if self._wrapped_obj is not None:
195
+ self._wrapped_obj.Name = value
196
+
197
+ @property
198
+ def parent(self) -> 'SimultanObject':
199
+ if not hasattr(self._wrapped_obj, 'Parent'):
200
+ return None
201
+
202
+ if self._wrapped_obj.Parent is not None:
203
+ return self._object_mapper.create_python_object(self._wrapped_obj.Parent)
204
+ else:
205
+ return None
206
+
207
+ @property
208
+ def slots(self):
209
+ if self._wrapped_obj is not None:
210
+ return list(self._wrapped_obj.Slots.Items)
211
+
212
+ @property
213
+ def primary_slot(self):
214
+ if self._wrapped_obj is not None:
215
+ return self._wrapped_obj.Slots.Items[0]
216
+
217
+ @property
218
+ def referenced_by(self) -> set['SimultanObject']:
219
+ return set([self._object_mapper.create_python_object(x.Target) for x in self._wrapped_obj.ReferencedBy if
220
+ x.Target != self._wrapped_obj])
221
+
222
+ @property
223
+ def _parameters(self) -> dict[str, Union[str, int, float, bool, ndarray]]:
224
+ return {x.NameTaxonomyEntry.get_TextOrKey(): utils.get_obj_value(x,
225
+ data_model=self._data_model,
226
+ object_mapper=self._object_mapper) for x in
227
+ self._wrapped_obj.Parameters}
228
+
229
+ @property
230
+ def associated_geometry(self):
231
+ ref_geometries = self._data_model.get_associated_geometry(self)
232
+
233
+ return [create_python_geometry(None, geo, self._data_model, self._object_mapper, geo_model) for geo, geo_model in
234
+ ref_geometries]
235
+
236
+ def get_subcomponents(self) -> dict[[str, str], Union['SimultanObject', SimComponent]]:
237
+ subcomponents = {}
238
+ for comp in self._wrapped_obj.Components:
239
+ subcomponents[(comp.Slot.SlotBase.Target.Key, comp.Slot.SlotExtension)] = self._object_mapper.create_python_object(comp.Component)
240
+ return subcomponents
241
+
242
+ def get_subcomponent_list(self) -> list[Union['SimultanObject', SimComponent]]:
243
+ return list(self.get_subcomponents().values())
244
+
245
+ def get_referenced_components(self) -> list['SimultanObject']:
246
+ return [self._object_mapper.create_python_object(x) for x in self._wrapped_obj.ReferencedComponents]
247
+
248
+ def add_taxonomy_entry_reference(self,
249
+ taxonomy_entry_reference: SimTaxonomyEntryReference,
250
+ index: int = None):
251
+ if index is None:
252
+ index = self._wrapped_obj.Slots.Items.__len__()
253
+ self._wrapped_obj.Slots.InsertItem(index, taxonomy_entry_reference)
254
+
255
+ def add_subcomponent(self, subcomponent: Union['SimultanObject', SimComponent],
256
+ slot: SimTaxonomyEntryReference = None,
257
+ slot_extension: str = None):
258
+
259
+ if isinstance(subcomponent, SimComponent):
260
+ comp_to_add = subcomponent
261
+ elif isinstance(subcomponent, SimultanObject):
262
+ comp_to_add = subcomponent._wrapped_obj
263
+ else:
264
+ comp_to_add = utils.create_mapped_python_object(subcomponent,
265
+ object_mapper=self._object_mapper,
266
+ data_model=self._data_model,
267
+ add_to_data_model=True)
268
+
269
+ utils.add_sub_component(self._wrapped_obj,
270
+ comp_to_add,
271
+ slot_extension,
272
+ slot)
273
+
274
+ def remove_subcomponent(self, subcomponent: Union['SimultanObject', SimComponent]):
275
+ if isinstance(subcomponent, SimComponent):
276
+ utils.remove_sub_component(self._wrapped_obj, subcomponent)
277
+ elif isinstance(subcomponent, SimultanObject):
278
+ utils.remove_sub_component(self._wrapped_obj, subcomponent._wrapped_obj)
279
+ else:
280
+ raise TypeError(f'Unknown type for subcomponent: {type(subcomponent)}')
281
+
282
+ def add_referenced_component(self,
283
+ referenced_component: Union['SimultanObject', SimComponent],
284
+ slot: SimTaxonomyEntryReference = None,
285
+ slot_extension: str = None):
286
+
287
+ referenced_wrapped_obj = referenced_component if isinstance(referenced_component,
288
+ SimComponent) else referenced_component._wrapped_obj
289
+
290
+ # logger.debug(f'Adding referenced component {referenced_component} to {self}')
291
+ utils.add_referenced_component(self._wrapped_obj,
292
+ referenced_wrapped_obj,
293
+ slot_extension,
294
+ slot)
295
+
296
+ def remove_referenced_component(self, referenced_component: 'SimultanObject'):
297
+ utils.remove_referenced_component(self._wrapped_obj, referenced_component._wrapped_obj)
298
+
299
+ def add_asset(self,
300
+ resource_file_entry: 'ResourceFileEntry',
301
+ _id_contained: str = '') -> Asset:
302
+
303
+ return ComponentMapping.AddAsset(self, resource_file_entry, _id_contained)
304
+
305
+ def __repr__(self):
306
+ return f'{self.name}: ' + object.__repr__(self)
307
+
308
+ def associate(self, other: 'ExtendedBaseGeometry'):
309
+ """
310
+ Associate this object with another object
311
+ :param other: geometry object to associate with
312
+ :return: None
313
+ """
314
+ other.associate(self)
315
+
316
+ def get_raw_attr(self, attr: str):
317
+ return utils.get_component_taxonomy_entry(self._wrapped_obj, attr)
318
+
319
+ def set_attr_prop(self, attr: str, prop: str, value):
320
+ """
321
+ Set attribute of the mapped property
322
+
323
+ Example:
324
+
325
+ class TestComponent(object):
326
+ def __init__(self, *args, **kwargs):
327
+ self.value = kwargs.get('value')
328
+
329
+ content0 = Content(text_or_key='value', # text or key of the content/parameter/property
330
+ property_name='value', # name of the generated property
331
+ type=float, # type of the content/parameter/property
332
+ unit=None, # unit of the content/parameter/property
333
+ documentation='value to test',
334
+ component_policy='subcomponent')
335
+
336
+ test_component_map = TaxonomyMap(taxonomy_name='PySimultan',
337
+ taxonomy_key='PySimultan',
338
+ taxonomy_entry_name='TestComponent',
339
+ taxonomy_entry_key='TestComponent',
340
+ content=[content0]
341
+ )
342
+
343
+ mapper.register(test_component_map.taxonomy_entry_key, TestComponent, taxonomy_map=test_component_map)
344
+ cls1 = mapper.get_mapped_class(test_component_map.taxonomy_entry_key)
345
+
346
+ test_component = cls1(name='test_component',
347
+ value=None)
348
+
349
+ test_component.set_attr_prop('value', 'MinValue, 0)
350
+ test_component.set_attr_prop('value', 'MaxValue, 1)
351
+
352
+ :param attr:
353
+ :param value:
354
+ :return:
355
+ """
356
+ comp_prop = utils.get_component_taxonomy_entry(self._wrapped_obj, attr)
357
+ if comp_prop is not None:
358
+ setattr(comp_prop, prop, value)
359
+ return comp_prop
360
+
361
+
362
+ # def to_json(self):
363
+ #
364
+ # super().to_json(self)
365
+
366
+ # return {str(self.id): {'name': self.name}}
@@ -0,0 +1,169 @@
1
+ import io
2
+ from ruamel.yaml import YAML, yaml_object, add_representer
3
+ from .config import yaml
4
+
5
+ from typing import TYPE_CHECKING, Optional, Union, Literal
6
+ if TYPE_CHECKING:
7
+ from .data_model import DataModel
8
+
9
+ from SIMULTAN.Data.Taxonomy import SimTaxonomyEntryReference
10
+
11
+
12
+ @yaml_object(yaml)
13
+ class Content(object):
14
+
15
+ yaml_tag = u'!Content'
16
+
17
+ def __init__(self, *args, **kwargs):
18
+ """
19
+ Define a content/parameter/property of a taxonomy entry in the taxonomy map.
20
+
21
+ :param args:
22
+ :Keyword Arguments
23
+ * *text_or_key* (``str``) -- text or key of the content/parameter/property
24
+ * *property_name* (``str``) -- name of the generated property
25
+ * *slot_extension* (``str``) -- slot extension of the content/parameter/property
26
+ * *type* (``str``) -- type of the content/parameter/property
27
+ * *unit* (``str``) -- unit of the content/parameter/property
28
+ * *documentation* (``str``) -- documentation of the content/parameter/property
29
+ * *component_policy* (``str``) -- component add policy of the content/parameter/property, '
30
+ reference' or 'subcomponent'
31
+ """
32
+
33
+ self.name: str = kwargs.get('name', kwargs.get('text_or_key'))
34
+ self.text_or_key: str = kwargs.get('text_or_key') # text or key of the content/parameter/property
35
+ self.property_name: str = kwargs.get('property_name') # name of the generated property
36
+ self.slot_extension: str = kwargs.get('slot_extension') # slot extension of the content/parameter/property
37
+ self.type = kwargs.get('type', None) # type of the content/parameter/property
38
+ self.unit: Optional[str] = kwargs.get('unit', None) # unit of the content/parameter/property
39
+ self.documentation: Optional[str] = kwargs.get('documentation', None) # documentation of the content/parameter/property
40
+ self.component_policy: Literal['reference', 'subcomponent'] = kwargs.get('component_policy', 'reference') # component add policy of the content/parameter/property, 'reference' or 'subcomponent'
41
+
42
+ self._taxonomies = {}
43
+ self._taxonomy_entries = {}
44
+ self._taxonomy_map = kwargs.get('taxonomy_map', None)
45
+
46
+ add_kwargs = kwargs.copy()
47
+ _ = [add_kwargs.pop(key, None) for key in ['taxonomy_name', 'taxonomy_key', 'taxonomy_entry_name',
48
+ 'taxonomy_entry_key', 'content', 'documentation', 'python_mapper',
49
+ 'mapped_class', 'unit', 'type', 'component_policy',
50
+ 'text_or_key', 'property_name', 'slot_extension']]
51
+
52
+ self.additional_attributes = add_kwargs
53
+
54
+ def get_taxonomie_entry(self, data_model: 'DataModel'):
55
+ if self._taxonomy_entries.get(data_model, None) is None:
56
+
57
+ taxonomy = self._taxonomy_map.get_or_create_simultan_taxonomy(data_model=data_model, create=True)
58
+ self._taxonomy_entries[data_model] = data_model.get_or_create_taxonomy_entry(name=self.text_or_key,
59
+ key=self.text_or_key,
60
+ description=self.documentation,
61
+ sim_taxonomy=taxonomy)
62
+ return self._taxonomy_entries[data_model]
63
+
64
+ def __repr__(self):
65
+ return (f"Content({self.name}, {self.text_or_key}, "
66
+ f"{self.property_name}, {self.slot_extension}, "
67
+ f"{self.type}, {self.unit}, "
68
+ f"{self.documentation}, {self.component_policy})")
69
+
70
+
71
+ verbose_output = False
72
+
73
+
74
+ @yaml_object(yaml)
75
+ class TaxonomyMap(object):
76
+
77
+ yaml_tag = u'!TaxonomyMap'
78
+
79
+ @classmethod
80
+ def from_yaml_file(cls, filename):
81
+ with open(filename, mode='r') as f:
82
+ taxonomie_map = yaml.load(f)
83
+ return taxonomie_map[0]
84
+
85
+ def __init__(self, *args, **kwargs):
86
+
87
+ self._content = []
88
+ self._content_dict = {}
89
+
90
+ self.taxonomy_name = kwargs.get('taxonomy_name', kwargs.get('taxonomy_key', None))
91
+ self.taxonomy_key = kwargs.get('taxonomy_key', None)
92
+
93
+ self.taxonomy_entry_name = kwargs.get('taxonomy_entry_name', kwargs.get('taxonomy_entry_key', None))
94
+ self.taxonomy_entry_key = kwargs.get('taxonomy_entry_key', None)
95
+
96
+ self.content = kwargs.get('content', [])
97
+ self.documentation = kwargs.get('documentation', '')
98
+
99
+ self.python_mapper = kwargs.get('python_mapper', None)
100
+ self.mapped_class = kwargs.get('mapped_class', None)
101
+
102
+ self._taxonomies = {}
103
+ self._taxonomy_entries = {}
104
+
105
+ @property
106
+ def content(self):
107
+ return self._content
108
+
109
+ @content.setter
110
+ def content(self, value: list[Content]):
111
+ self._content = value
112
+ for content in self._content:
113
+ content._taxonomy_map = self
114
+ self._content_dict = {}
115
+
116
+ @property
117
+ def content_dict(self):
118
+ if self._content_dict == {}:
119
+ for content in self._content:
120
+ self._content_dict[content.text_or_key] = content
121
+ return self._content_dict
122
+
123
+ def write(self, filename=None):
124
+ if filename is not None:
125
+ with open(filename, mode='w') as f:
126
+ yaml.dump([self], f)
127
+ else:
128
+ f = io.StringIO()
129
+ yaml.dump([self], f)
130
+ return f.getvalue()
131
+
132
+ def __getstate__(self):
133
+ data = self.__dict__.copy()
134
+ del data['python_mapper']
135
+ del data['mapped_class']
136
+ return data
137
+
138
+ def add_content(self, content: Content):
139
+ self._content.append(content)
140
+ content._taxonomy_map = self
141
+ self._content_dict = {}
142
+
143
+ def get_or_create_simultan_taxonomy_entry(self, data_model: 'DataModel', create=True):
144
+
145
+ if self._taxonomy_entries.get(data_model, None) is None:
146
+
147
+ taxonomy_entries = data_model.get_taxonomy_entries()
148
+ if self.taxonomy_entry_key in taxonomy_entries.keys():
149
+ self._taxonomy_entries[data_model] = taxonomy_entries[self.taxonomy_entry_key]
150
+ elif create:
151
+ self._taxonomy_entries[data_model] = data_model.get_or_create_taxonomy_entry(
152
+ key=self.taxonomy_entry_key,
153
+ name=self.taxonomy_entry_name,
154
+ sim_taxonomy=self.get_or_create_simultan_taxonomy(data_model=data_model,
155
+ create=create))
156
+ return self._taxonomy_entries[data_model]
157
+
158
+ def get_or_create_simultan_taxonomy(self, data_model: 'DataModel', create=True):
159
+ if self._taxonomies.get(data_model, None) is None:
160
+ self._taxonomies[data_model] = data_model.get_or_create_taxonomy(
161
+ taxonomy_name=self.taxonomy_name,
162
+ taxonomy_key=self.taxonomy_key,
163
+ description=self.documentation,
164
+ create=create)
165
+
166
+ return self._taxonomies[data_model]
167
+
168
+ def get_slot(self, data_model: 'DataModel'):
169
+ return SimTaxonomyEntryReference(self.get_or_create_simultan_taxonomy_entry(data_model=data_model, create=True))