PySimultan 0.1.54__py3-none-any.whl → 0.2.1__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- PySimultan-0.2.1.dist-info/LICENSE.txt +17 -0
- PySimultan-0.2.1.dist-info/METADATA +36 -0
- PySimultan-0.2.1.dist-info/RECORD +82 -0
- {PySimultan-0.1.54.dist-info → PySimultan-0.2.1.dist-info}/WHEEL +1 -1
- PySimultan-0.2.1.dist-info/top_level.txt +1 -0
- {PySimultan → PySimultan2}/__init__.py +11 -6
- PySimultan2/config.py +52 -0
- PySimultan2/data_model.py +713 -0
- PySimultan2/default_types.py +507 -0
- PySimultan2/files.py +371 -0
- PySimultan2/geometry/__init__.py +4 -0
- PySimultan2/geometry/geometry_base.py +654 -0
- PySimultan2/geometry/utils.py +181 -0
- PySimultan2/multi_values.py +277 -0
- PySimultan2/object_mapper.py +200 -0
- PySimultan2/resources/AssimpNet.dll +0 -0
- PySimultan2/resources/AvalonDock.dll +0 -0
- PySimultan2/resources/BruTile.dll +0 -0
- PySimultan2/resources/ClosedXML.dll +0 -0
- PySimultan2/resources/ComponentBuilder.dll +0 -0
- PySimultan/resources/ComponentBuilder.exe.config → PySimultan2/resources/ComponentBuilder.dll.config +6 -2
- PySimultan2/resources/ComponentBuilder.runtimeconfig.json +18 -0
- {PySimultan → PySimultan2}/resources/ComponentBuilder.xml +11877 -6754
- PySimultan2/resources/ControlzEx.dll +0 -0
- PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
- PySimultan2/resources/DocumentFormat.OpenXml.dll +0 -0
- PySimultan2/resources/ExcelNumberFormat.dll +0 -0
- PySimultan2/resources/Fluent.dll +0 -0
- PySimultan2/resources/GeometryViewer.dll +0 -0
- {PySimultan → PySimultan2}/resources/GeometryViewer.xml +2201 -1155
- PySimultan2/resources/HelixToolkit.Core.Wpf.dll +0 -0
- PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll +0 -0
- PySimultan2/resources/HelixToolkit.SharpDX.Core.dll +0 -0
- PySimultan2/resources/HelixToolkit.dll +0 -0
- PySimultan2/resources/MathNet.Numerics.dll +0 -0
- PySimultan2/resources/Microsoft.AspNetCore.Authorization.dll +0 -0
- PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll +0 -0
- PySimultan2/resources/Microsoft.Extensions.DependencyInjection.Abstractions.dll +0 -0
- PySimultan2/resources/Microsoft.Extensions.Logging.Abstractions.dll +0 -0
- PySimultan2/resources/Microsoft.Extensions.Options.dll +0 -0
- PySimultan2/resources/Microsoft.Extensions.Primitives.dll +0 -0
- PySimultan2/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
- PySimultan2/resources/Microsoft.WindowsAPICodePack.dll +0 -0
- PySimultan2/resources/Microsoft.Xaml.Behaviors.dll +0 -0
- PySimultan2/resources/Newtonsoft.Json.Bson.dll +0 -0
- PySimultan2/resources/Newtonsoft.Json.dll +0 -0
- PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
- PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll +0 -0
- PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll.config +15 -0
- PySimultan2/resources/SIMULTAN.Lang.dll +0 -0
- {PySimultan → PySimultan2}/resources/SIMULTAN.Lang.xml +5282 -3252
- PySimultan2/resources/SIMULTAN.Plugins.dll +0 -0
- {PySimultan → PySimultan2}/resources/SIMULTAN.Plugins.xml +110 -0
- PySimultan2/resources/SIMULTAN.UI.dll +0 -0
- {PySimultan → PySimultan2}/resources/SIMULTAN.UI.xml +10483 -4937
- PySimultan2/resources/SIMULTAN.dll +0 -0
- PySimultan2/resources/SIMULTAN.xml +34122 -0
- PySimultan2/resources/SharpDX.D3DCompiler.dll +0 -0
- PySimultan2/resources/SharpDX.DXGI.dll +0 -0
- PySimultan2/resources/SharpDX.Direct2D1.dll +0 -0
- PySimultan2/resources/SharpDX.Direct3D11.dll +0 -0
- PySimultan2/resources/SharpDX.Direct3D9.dll +0 -0
- {PySimultan → PySimultan2}/resources/SharpDX.Mathematics.dll +0 -0
- PySimultan2/resources/SharpDX.dll +0 -0
- {PySimultan → PySimultan2}/resources/SitePlanner.dll +0 -0
- {PySimultan → PySimultan2}/resources/SitePlanner.xml +959 -1110
- PySimultan2/resources/Sprache.dll +0 -0
- PySimultan2/resources/System.Data.OleDb.dll +0 -0
- PySimultan2/resources/System.Net.Http.Formatting.dll +0 -0
- PySimultan2/resources/XAMLMarkupExtensions.dll +0 -0
- PySimultan2/resources/assimp.dll +0 -0
- {PySimultan → PySimultan2}/resources/defaultsettings.xml +0 -0
- PySimultan2/simultan_object.py +366 -0
- PySimultan2/taxonomy_maps.py +169 -0
- PySimultan2/utils.py +1383 -0
- PySimultan/config.py +0 -57
- PySimultan/data_model.py +0 -376
- PySimultan/default_types.py +0 -1771
- PySimultan/geo_default_types.py +0 -763
- PySimultan/geometry.py +0 -309
- PySimultan/resources/AssimpNet.dll +0 -0
- PySimultan/resources/AssimpNet.xml +0 -12074
- PySimultan/resources/BruTile.dll +0 -0
- PySimultan/resources/BruTile.xml +0 -1845
- PySimultan/resources/ControlzEx.dll +0 -0
- PySimultan/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
- PySimultan/resources/DXFImportExport.dll +0 -0
- PySimultan/resources/DotSpatial.Projections.xml +0 -5879
- PySimultan/resources/EXCELImportExport.dll +0 -0
- PySimultan/resources/Fluent.dll +0 -0
- PySimultan/resources/Fluent.xml +0 -9103
- PySimultan/resources/GeoJSON.Net.dll +0 -0
- PySimultan/resources/GeometryViewer.Data.dll +0 -0
- PySimultan/resources/GeometryViewer.Data.xml +0 -4443
- PySimultan/resources/GeometryViewer.Shared.dll +0 -0
- PySimultan/resources/GeometryViewer.Shared.xml +0 -588
- PySimultan/resources/GeometryViewer.dll +0 -0
- PySimultan/resources/HelixToolkit.Wpf.SharpDX.dll +0 -0
- PySimultan/resources/HelixToolkit.Wpf.SharpDX.xml +0 -43219
- PySimultan/resources/HelixToolkit.Wpf.dll +0 -0
- PySimultan/resources/HelixToolkit.Wpf.xml +0 -22363
- PySimultan/resources/HelixToolkit.dll +0 -0
- PySimultan/resources/HelixToolkit.xml +0 -144
- PySimultan/resources/ImportLog_SMART_CAMPUS_TU_WIEN_BIBLIOTHEK_20210305_ZONENMODELL_23_11_2021-06_54_54.txt +0 -1
- PySimultan/resources/LibGit2Sharp.dll +0 -0
- PySimultan/resources/LibGit2Sharp.dll.config +0 -4
- PySimultan/resources/LibGit2Sharp.xml +0 -13770
- PySimultan/resources/MathNet.Numerics.dll +0 -0
- PySimultan/resources/MathNet.Numerics.xml +0 -57152
- PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
- PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.xml +0 -25496
- PySimultan/resources/Microsoft.WindowsAPICodePack.dll +0 -0
- PySimultan/resources/Microsoft.WindowsAPICodePack.xml +0 -2934
- PySimultan/resources/Newtonsoft.Json.dll +0 -0
- PySimultan/resources/Newtonsoft.Json.xml +0 -11305
- PySimultan/resources/ParameterStructure.dll +0 -0
- PySimultan/resources/ParameterStructure.xml +0 -10750
- PySimultan/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
- PySimultan/resources/SIMULTAN.DataExchange.dll +0 -0
- PySimultan/resources/SIMULTAN.Lang.dll +0 -0
- PySimultan/resources/SIMULTAN.Legacy.dll +0 -0
- PySimultan/resources/SIMULTAN.Legacy.xml +0 -254
- PySimultan/resources/SIMULTAN.Plugins.dll +0 -0
- PySimultan/resources/SIMULTAN.Project.dll +0 -0
- PySimultan/resources/SIMULTAN.Project.dll.config +0 -11
- PySimultan/resources/SIMULTAN.UI.dll +0 -0
- PySimultan/resources/SIMULTAN.Util.dll +0 -0
- PySimultan/resources/SIMULTAN.Util.xml +0 -3430
- PySimultan/resources/SharpDX.D3DCompiler.dll +0 -0
- PySimultan/resources/SharpDX.D3DCompiler.xml +0 -5897
- PySimultan/resources/SharpDX.DXGI.dll +0 -0
- PySimultan/resources/SharpDX.DXGI.xml +0 -8737
- PySimultan/resources/SharpDX.Direct2D1.dll +0 -0
- PySimultan/resources/SharpDX.Direct2D1.xml +0 -46691
- PySimultan/resources/SharpDX.Direct3D11.dll +0 -0
- PySimultan/resources/SharpDX.Direct3D11.xml +0 -31826
- PySimultan/resources/SharpDX.Direct3D9.dll +0 -0
- PySimultan/resources/SharpDX.Direct3D9.xml +0 -36489
- PySimultan/resources/SharpDX.Mathematics.xml +0 -16449
- PySimultan/resources/SharpDX.dll +0 -0
- PySimultan/resources/Sprache.dll +0 -0
- PySimultan/resources/Sprache.xml +0 -1199
- PySimultan/resources/System.Net.Http.Formatting.dll +0 -0
- PySimultan/resources/System.Net.Http.Formatting.xml +0 -2094
- PySimultan/resources/System.Windows.Interactivity.dll +0 -0
- PySimultan/resources/TalkGit.dll +0 -0
- PySimultan/resources/TalkGit.dll.config +0 -11
- PySimultan/resources/WebServiceConnector.dll +0 -0
- PySimultan/resources/WebServiceConnector.dll.config +0 -11
- PySimultan/resources/XAMLMarkupExtensions.dll +0 -0
- PySimultan/resources/XAMLMarkupExtensions.xml +0 -862
- PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Aero.dll +0 -0
- PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Metro.dll +0 -0
- PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.VS2010.dll +0 -0
- PySimultan/resources/Xceed.Wpf.AvalonDock.dll +0 -0
- PySimultan/resources/Xceed.Wpf.Toolkit.dll +0 -0
- PySimultan/resources/assimp.dll +0 -0
- PySimultan/resources/schema.yaml +0 -13
- PySimultan/resources/simultan_exception_07_10_2021-08_34_24.txt +0 -17
- PySimultan/resources/simultan_exception_07_10_2021-10_13_31.txt +0 -17
- PySimultan/resources/simultan_exception_11_10_2021-19_45_42.txt +0 -17
- PySimultan/resources/simultan_exception_22_11_2021-16_41_52.txt +0 -14
- PySimultan/resources/simultan_exception_22_11_2021-17_37_40.txt +0 -14
- PySimultan/simultan_geometry_utils.py +0 -81
- PySimultan/simultan_utils.py +0 -165
- PySimultan/slots.py +0 -51
- PySimultan/template_tools.py +0 -631
- PySimultan/utils.py +0 -298
- PySimultan-0.1.54.dist-info/LICENSE +0 -674
- PySimultan-0.1.54.dist-info/LICENSE.txt +0 -674
- PySimultan-0.1.54.dist-info/METADATA +0 -690
- PySimultan-0.1.54.dist-info/RECORD +0 -119
- PySimultan-0.1.54.dist-info/entry_points.txt +0 -3
- PySimultan-0.1.54.dist-info/top_level.txt +0 -1
- PySimultan-0.1.54.dist-info/zip-safe +0 -1
- {PySimultan → PySimultan2}/resources/DotSpatial.Projections.dll +0 -0
- {PySimultan → PySimultan2}/resources/GeometryViewer.dll.config +0 -0
- {PySimultan → PySimultan2}/resources/SIMULTAN.AutoUpdate.Client.dll.config +0 -0
- {PySimultan → PySimultan2}/resources/SitePlanner.dll.config +0 -0
- {PySimultan → PySimultan2}/resources/Sprache.Calc.dll +0 -0
- {PySimultan → PySimultan2}/resources/__init__.py +0 -0
- {PySimultan → PySimultan2}/resources/setup.bat +0 -0
PySimultan/template_tools.py
DELETED
@@ -1,631 +0,0 @@
|
|
1
|
-
from ruamel.yaml import YAML, yaml_object, add_representer
|
2
|
-
from .config import yaml
|
3
|
-
import io
|
4
|
-
import colorlog
|
5
|
-
from uuid import uuid4
|
6
|
-
import typing
|
7
|
-
|
8
|
-
from yamale.readers.yaml_reader import _parsers
|
9
|
-
import yamale
|
10
|
-
|
11
|
-
|
12
|
-
from collections import UserList
|
13
|
-
from .default_types import SimultanObject
|
14
|
-
from .default_types import List as SimultanList
|
15
|
-
from .default_types import ValueField, BuildInFace, BuildInVolume, BuildInZone, BaseBuildInConstruction, BuildInMaterialLayer, ReferenceList
|
16
|
-
from .geo_default_types import geometry_types
|
17
|
-
from .geometry import GeometryModel
|
18
|
-
from .utils import parse_slot
|
19
|
-
|
20
|
-
from functools import lru_cache
|
21
|
-
|
22
|
-
from System.Linq import Enumerable
|
23
|
-
from ParameterStructure.Values import SimMultiValuePointer
|
24
|
-
from ParameterStructure.Components import SimComponent
|
25
|
-
|
26
|
-
from typing import List as TypeList
|
27
|
-
from typing import NewType, Union
|
28
|
-
|
29
|
-
try:
|
30
|
-
import importlib.resources as pkg_resources
|
31
|
-
except ImportError:
|
32
|
-
# Try backported to PY<37 importlib_resources.
|
33
|
-
import importlib_resources as pkg_resources
|
34
|
-
|
35
|
-
from . import resources
|
36
|
-
|
37
|
-
with pkg_resources.path(resources, 'schema.yaml') as r_path:
|
38
|
-
schema_file = str(r_path)
|
39
|
-
|
40
|
-
|
41
|
-
logger = colorlog.getLogger('PySimultan')
|
42
|
-
|
43
|
-
|
44
|
-
template_classes = {}
|
45
|
-
|
46
|
-
|
47
|
-
# create the class for the templates
|
48
|
-
@yaml_object(yaml)
|
49
|
-
class Template(object):
|
50
|
-
|
51
|
-
yaml_tag = u'!Template:'
|
52
|
-
|
53
|
-
def __init__(self, *args, **kwargs):
|
54
|
-
""" Template class to define how SIMULTAN SimComponents are imported and parsed
|
55
|
-
|
56
|
-
:param args:
|
57
|
-
:param kwargs:
|
58
|
-
|
59
|
-
@keyword template_name: Name of the Template. This name is the name of the created Python class and used for
|
60
|
-
TYPE matching the SIMULTAN SimComponent
|
61
|
-
@keyword template_id: ID of the template; int
|
62
|
-
@keyword inherits_from: name of the python template or the template instance this template inherits from
|
63
|
-
@keyword content: List of attribute names
|
64
|
-
@keyword documentation: Entry to document the template; str
|
65
|
-
@keyword units: units of the content. Dictionary
|
66
|
-
@keyword types: Dictionary with the type of the content. if the type is 'str' get_TextValue() is returned, param.get_ValueCurrent() otherwise
|
67
|
-
@keyword slots: Dictionary with the name of the content and the name of the slot where it is expected. The expected slot is a string
|
68
|
-
@keyword default_slot: Default slot name for the Simultan component when new created
|
69
|
-
with the slot name and the extension, seperated by a blank
|
70
|
-
"""
|
71
|
-
|
72
|
-
self.template_name = kwargs.get('template_name', None)
|
73
|
-
self.template_id = kwargs.get('template_id', None)
|
74
|
-
|
75
|
-
self.inherits_from = kwargs.get('inherits_from', None)
|
76
|
-
|
77
|
-
self.content = kwargs.get('content', [])
|
78
|
-
self.documentation = kwargs.get('documentation', None)
|
79
|
-
self.units = kwargs.get('units', {})
|
80
|
-
self.types = kwargs.get('types', {})
|
81
|
-
|
82
|
-
self.slots = kwargs.get('slots', {})
|
83
|
-
self.synonyms = kwargs.get('synonyms', {}) # name of the attribute in the python class
|
84
|
-
|
85
|
-
self.template_parser = kwargs.get('template_parser', None)
|
86
|
-
self.template_class = kwargs.get('template_class', None)
|
87
|
-
|
88
|
-
self.default_slot = kwargs.get('default_slot', 'Element')
|
89
|
-
|
90
|
-
def write(self, filename: str = None):
|
91
|
-
"""
|
92
|
-
write the template as .yml to a file
|
93
|
-
:param filename: name and path of the file to save; Example: C:\SIMULTAN\my_template.yml
|
94
|
-
:return: None
|
95
|
-
"""
|
96
|
-
if filename is not None:
|
97
|
-
yaml.dump([self], open(filename, mode='w'))
|
98
|
-
else:
|
99
|
-
f = io.StringIO()
|
100
|
-
yaml.dump([self], f)
|
101
|
-
return f.getvalue()
|
102
|
-
|
103
|
-
def create_template_class(self, template_parser, template_classes):
|
104
|
-
"""
|
105
|
-
Creates a template class for this template.
|
106
|
-
:param template_parser: TemplateParser instance
|
107
|
-
:param template_classes: list of template classes to inherit from (e.g. default classes)
|
108
|
-
:return: TemplateClass
|
109
|
-
"""
|
110
|
-
|
111
|
-
if (self.template_parser is template_parser) and (self.template_class is not None):
|
112
|
-
return self.template_class
|
113
|
-
|
114
|
-
self.template_parser = template_parser
|
115
|
-
|
116
|
-
# for inheritance:
|
117
|
-
# template classes must inherit from SimultanObject, UserList or ValueField
|
118
|
-
|
119
|
-
if (self.inherits_from is None) and (self.template_name in self.template_parser.bases.keys()):
|
120
|
-
self.inherits_from = self.template_name
|
121
|
-
|
122
|
-
if self.inherits_from is not None:
|
123
|
-
if self.inherits_from in self.template_parser.bases.keys():
|
124
|
-
base = template_classes[self.inherits_from]
|
125
|
-
|
126
|
-
simultan_base_list = [SimultanObject, UserList, ValueField]
|
127
|
-
|
128
|
-
if any([issubclass(base, x) for x in simultan_base_list]):
|
129
|
-
bases = (base, )
|
130
|
-
else:
|
131
|
-
bases = (SimultanObject, ) + (base, )
|
132
|
-
# bases = (base, ) + (SimultanObject, )
|
133
|
-
|
134
|
-
# if SimultanObject in base.__bases__:
|
135
|
-
# bases = (base, )
|
136
|
-
# elif UserList in base.__bases__:
|
137
|
-
# bases = (base, )
|
138
|
-
# elif ValueField in base.__bases__:
|
139
|
-
# bases = (base, )
|
140
|
-
# else:
|
141
|
-
# bases = (SimultanObject, ) + (base, )
|
142
|
-
else:
|
143
|
-
base = template_classes[self.inherits_from.template_name]
|
144
|
-
bases = (base, )
|
145
|
-
|
146
|
-
def new_init(self, *args, **kwargs):
|
147
|
-
|
148
|
-
for i in range(self.__class__.__bases__.__len__()):
|
149
|
-
self.__class__.__bases__[i].__init__(self, *args, **kwargs)
|
150
|
-
|
151
|
-
else:
|
152
|
-
bases = (SimultanObject, )
|
153
|
-
# create the class from the template
|
154
|
-
|
155
|
-
def new_init(self, *args, **kwargs):
|
156
|
-
|
157
|
-
self.__class__.__bases__[0].__init__(self, *args, **kwargs)
|
158
|
-
|
159
|
-
new_class_dict = {'__init__': new_init,
|
160
|
-
'_template_name': self.template_name,
|
161
|
-
'_template_id': self.template_id,
|
162
|
-
'_documentation': self.documentation,
|
163
|
-
'_content': [cont for cont in self.content],
|
164
|
-
'_types': self.types,
|
165
|
-
'_units': self.units,
|
166
|
-
'_base': bases,
|
167
|
-
'_template_parser': self.template_parser,
|
168
|
-
'_slots': self.slots,
|
169
|
-
'_synonyms': self.synonyms,
|
170
|
-
'_default_slot': self.default_slot}
|
171
|
-
|
172
|
-
new_class_dict.update(self.get_properties())
|
173
|
-
new_class = type(self.template_name, bases, new_class_dict)
|
174
|
-
|
175
|
-
self.template_class = new_class
|
176
|
-
|
177
|
-
return new_class
|
178
|
-
|
179
|
-
def get_properties(self):
|
180
|
-
|
181
|
-
prop_dict = {}
|
182
|
-
|
183
|
-
for prop in self.content:
|
184
|
-
|
185
|
-
if prop in self.slots.keys():
|
186
|
-
slot = self.slots[prop]
|
187
|
-
else:
|
188
|
-
slot = None
|
189
|
-
|
190
|
-
syn = self.synonyms.get('prop', prop)
|
191
|
-
|
192
|
-
prop_dict[syn] = add_properties(prop, syn, param_type=self.types.get(prop, None), slot=slot)
|
193
|
-
|
194
|
-
return prop_dict
|
195
|
-
|
196
|
-
def __getstate__(self):
|
197
|
-
state = self.__dict__.copy()
|
198
|
-
del state['template_parser']
|
199
|
-
del state['template_class']
|
200
|
-
return state
|
201
|
-
|
202
|
-
def __setstate__(self, d):
|
203
|
-
|
204
|
-
if 'template_name' not in d:
|
205
|
-
raise Exception(f'Template missing value for template_name')
|
206
|
-
|
207
|
-
if 'template_id' not in d:
|
208
|
-
raise Exception(f'Template missing value for template_id')
|
209
|
-
|
210
|
-
# add missing values:
|
211
|
-
|
212
|
-
if 'inherits_from' not in d:
|
213
|
-
d['inherits_from'] = None
|
214
|
-
|
215
|
-
if 'content' not in d:
|
216
|
-
d['content'] = []
|
217
|
-
|
218
|
-
if 'documentation' not in d:
|
219
|
-
d['documentation'] = None
|
220
|
-
|
221
|
-
if 'units' not in d:
|
222
|
-
d['units'] = {}
|
223
|
-
|
224
|
-
if 'types' not in d:
|
225
|
-
d['types'] = {}
|
226
|
-
|
227
|
-
if 'types' not in d:
|
228
|
-
d['types'] = {}
|
229
|
-
|
230
|
-
if 'slots' not in d:
|
231
|
-
d['slots'] = {}
|
232
|
-
|
233
|
-
if 'default_slot' not in d:
|
234
|
-
d['default_slot'] = 'Element'
|
235
|
-
|
236
|
-
self.__dict__ = d
|
237
|
-
|
238
|
-
self.template_parser = None
|
239
|
-
self.template_class = None
|
240
|
-
|
241
|
-
def __repr__(self):
|
242
|
-
return f"Template '{self.template_name}': " + object.__repr__(self)
|
243
|
-
|
244
|
-
|
245
|
-
yaml.constructor.yaml_constructors['!Template'] = yaml.constructor.yaml_constructors['!Template:']
|
246
|
-
|
247
|
-
|
248
|
-
class TemplateParser(object):
|
249
|
-
|
250
|
-
bases = {'Liste': SimultanList,
|
251
|
-
'List': SimultanList,
|
252
|
-
'ReferenceList': ReferenceList,
|
253
|
-
'ValueField': ValueField,
|
254
|
-
'Geometric Area': BuildInFace,
|
255
|
-
'Geometrische_Flächen': BuildInFace,
|
256
|
-
'Geometric Volume': BuildInVolume,
|
257
|
-
'Geometrische_Volumina': BuildInVolume,
|
258
|
-
'BuildInZone': BuildInZone,
|
259
|
-
'BuildInConstruction': BaseBuildInConstruction,
|
260
|
-
'BuildInMaterialLayer': BuildInMaterialLayer}
|
261
|
-
|
262
|
-
geo_bases = {'base': geometry_types.base,
|
263
|
-
'layer': geometry_types.layer,
|
264
|
-
'vertex': geometry_types.vertex,
|
265
|
-
'edge': geometry_types.edge,
|
266
|
-
'edge_loop': geometry_types.edge_loop,
|
267
|
-
'face': geometry_types.face,
|
268
|
-
'volume': geometry_types.volume,
|
269
|
-
}
|
270
|
-
|
271
|
-
_create_all = False
|
272
|
-
|
273
|
-
def __init__(self, *args, **kwargs):
|
274
|
-
|
275
|
-
"""
|
276
|
-
Class which handles templates. This class generates python objects from the SIMULTAN data model for templates.
|
277
|
-
|
278
|
-
@keyword templates: list of templates; if templates is None and template_filepath is defined,
|
279
|
-
templates are automatically loaded
|
280
|
-
@keyword template_filepath: filepath to the template (*.yml)
|
281
|
-
|
282
|
-
"""
|
283
|
-
|
284
|
-
self._current_data_model = None
|
285
|
-
|
286
|
-
self.id = uuid4()
|
287
|
-
|
288
|
-
self._templates = kwargs.get('templates', None)
|
289
|
-
self.template_filepath = kwargs.get('template_filepath', None)
|
290
|
-
|
291
|
-
self._template_classes = kwargs.get('template_classes', None)
|
292
|
-
|
293
|
-
self.data_models = kwargs.get('data_models', {})
|
294
|
-
|
295
|
-
self._typed_geo_models = None
|
296
|
-
|
297
|
-
template_classes[self.id] = self._template_classes
|
298
|
-
|
299
|
-
self.current_data_model = kwargs.get('current_data_model', None)
|
300
|
-
|
301
|
-
@property
|
302
|
-
def current_data_model(self):
|
303
|
-
return self._current_data_model
|
304
|
-
|
305
|
-
@current_data_model.setter
|
306
|
-
def current_data_model(self, value):
|
307
|
-
self._current_data_model = value
|
308
|
-
if self._current_data_model is None:
|
309
|
-
return
|
310
|
-
|
311
|
-
if self._current_data_model not in self.data_models:
|
312
|
-
self.data_models[self._current_data_model.id] = self._current_data_model
|
313
|
-
|
314
|
-
@property
|
315
|
-
def templates(self):
|
316
|
-
if self.template_filepath is None:
|
317
|
-
return None
|
318
|
-
|
319
|
-
if self._templates is None:
|
320
|
-
self._templates = self.load_templates_from_file()
|
321
|
-
return self._templates
|
322
|
-
|
323
|
-
@property
|
324
|
-
def template_classes(self):
|
325
|
-
if self._template_classes is None:
|
326
|
-
self.create_template_classes()
|
327
|
-
return self._template_classes
|
328
|
-
|
329
|
-
@property
|
330
|
-
def typed_geo_models(self):
|
331
|
-
if self._typed_geo_models is None:
|
332
|
-
self._typed_geo_models = self.get_typed_geo_models()
|
333
|
-
return self._typed_geo_models
|
334
|
-
|
335
|
-
def get_model_by_file_id(self, id):
|
336
|
-
return self.current_data_model.models_dict[id]
|
337
|
-
|
338
|
-
def get_typed_model_by_file_id(self, id):
|
339
|
-
return self.typed_geo_models[id]
|
340
|
-
|
341
|
-
def load_templates_from_file(self, filepath=None):
|
342
|
-
"""
|
343
|
-
Load templates from file
|
344
|
-
:param filepath: filepath of the file (str)
|
345
|
-
:return: templates; list of templates
|
346
|
-
"""
|
347
|
-
if filepath is None:
|
348
|
-
filepath = self.template_filepath
|
349
|
-
|
350
|
-
if filepath is None:
|
351
|
-
templates = []
|
352
|
-
else:
|
353
|
-
with open(filepath, mode='r', encoding="utf-8") as f_obj:
|
354
|
-
templates = yaml.load(f_obj)
|
355
|
-
|
356
|
-
return templates
|
357
|
-
|
358
|
-
def create_template_classes(self) -> typing.Dict[str, str]:
|
359
|
-
|
360
|
-
logger.info('\n\nCreating template-classes:\n-------------------------------------')
|
361
|
-
template_classes = {**self.bases}
|
362
|
-
|
363
|
-
if self.templates is not None:
|
364
|
-
logger.info(f'found {self.templates.__len__()} templates')
|
365
|
-
|
366
|
-
for template in self.templates:
|
367
|
-
|
368
|
-
new_class = template.create_template_class(self, template_classes)
|
369
|
-
template_classes[template.template_name] = new_class
|
370
|
-
|
371
|
-
logger.info(f'Created template class {template.template_name}. Inherits from {template.inherits_from}')
|
372
|
-
|
373
|
-
else:
|
374
|
-
logger.info(f'No template file defined')
|
375
|
-
|
376
|
-
self._template_classes = template_classes
|
377
|
-
logger.info('template-class creation finished\n\n')
|
378
|
-
return self._template_classes
|
379
|
-
|
380
|
-
@lru_cache(maxsize=None)
|
381
|
-
def create_python_object(self, sim_component, template_name=None):
|
382
|
-
|
383
|
-
# get the template or slot
|
384
|
-
# template_name = None
|
385
|
-
if hasattr(sim_component, 'Parameters'):
|
386
|
-
t_name = next((x.TextValue for x in sim_component.Parameters.Items if x.Name == 'TYPE'), None)
|
387
|
-
if t_name is not None:
|
388
|
-
template_name = t_name
|
389
|
-
|
390
|
-
if (template_name is None) and (hasattr(sim_component, 'get_CurrentSlot')):
|
391
|
-
template_name = sim_component.CurrentSlot.Base
|
392
|
-
|
393
|
-
# if no template and no slot could be found return the plain SimComponent
|
394
|
-
|
395
|
-
if template_name is None:
|
396
|
-
if isinstance(sim_component, SimMultiValuePointer):
|
397
|
-
template_name = 'ValueField'
|
398
|
-
|
399
|
-
if template_name is None:
|
400
|
-
if self._create_all:
|
401
|
-
if hasattr(SimComponent, 'ContainedSimComponentsAsList'):
|
402
|
-
_ = [self.create_python_object(x) for x in sim_component.Components]
|
403
|
-
if hasattr(SimComponent, 'ReferencedSimComponents'):
|
404
|
-
_ = [self.create_python_object(x) for x in sim_component.ReferencedComponents.Items]
|
405
|
-
return sim_component
|
406
|
-
|
407
|
-
if template_name not in self.template_classes.keys():
|
408
|
-
|
409
|
-
# create new class for the template / slot
|
410
|
-
base = SimultanObject
|
411
|
-
bases = (base, )
|
412
|
-
|
413
|
-
def new__init(self, *args, **kwargs):
|
414
|
-
self.__class__.__bases__[0].__init__(self, *args, **kwargs)
|
415
|
-
|
416
|
-
new_class_dict = {'__init__': new__init,
|
417
|
-
'_template_name': template_name,
|
418
|
-
'_template_id': None,
|
419
|
-
'_documentation': None,
|
420
|
-
'_content': None,
|
421
|
-
'_types': None,
|
422
|
-
'_units': None,
|
423
|
-
'_base': bases,
|
424
|
-
'_template_parser': self,
|
425
|
-
'_slots': {}}
|
426
|
-
|
427
|
-
new_class = type(template_name, bases, new_class_dict)
|
428
|
-
self.template_classes[template_name] = new_class
|
429
|
-
|
430
|
-
template_class = self.template_classes[template_name]
|
431
|
-
|
432
|
-
# init new instance
|
433
|
-
template_class._template_parser = self
|
434
|
-
new_instance = template_class(wrapped_obj=sim_component,
|
435
|
-
template_parser=self,
|
436
|
-
data_model_id=self._current_data_model.id)
|
437
|
-
|
438
|
-
# new_instance._template_parser = self
|
439
|
-
return new_instance
|
440
|
-
|
441
|
-
def get_typed_geo_models(self):
|
442
|
-
typed_models_dict = {}
|
443
|
-
for key, model in self.current_data_model.models_dict.items():
|
444
|
-
if model is None:
|
445
|
-
typed_models_dict[key] = None
|
446
|
-
continue
|
447
|
-
typed_models_dict[key] = GeometryModel(template_parser=self,
|
448
|
-
wrapped_obj=model,
|
449
|
-
geo_types=self.geo_bases)
|
450
|
-
# models.append(GeometryModel(wrapped_obj=model))
|
451
|
-
return typed_models_dict
|
452
|
-
|
453
|
-
def add_new_geometry_model(self, file_name: str, model_name: str = None):
|
454
|
-
|
455
|
-
model, resource = self.current_data_model.add_new_geometry_model(file_name, model_name, return_resource=True)
|
456
|
-
|
457
|
-
return self.add_typed_geo_model(model, resource.Key)
|
458
|
-
|
459
|
-
def add_typed_geo_model(self, model, key):
|
460
|
-
"""
|
461
|
-
Add a geometry model as typed model
|
462
|
-
:param model: ParameterStructure.Assets.ContainedResourceFileEntry
|
463
|
-
:param key: resource key
|
464
|
-
"""
|
465
|
-
if self._typed_geo_models is None:
|
466
|
-
self._typed_geo_models = {}
|
467
|
-
|
468
|
-
self._typed_geo_models[key] = GeometryModel(template_parser=self,
|
469
|
-
wrapped_obj=model,
|
470
|
-
geo_types=self.geo_bases)
|
471
|
-
|
472
|
-
return self._typed_geo_models[key]
|
473
|
-
|
474
|
-
def get_geo_components(self, geometry):
|
475
|
-
return Enumerable.ToList[SimComponent](self.current_data_model.exch.GetComponents(geometry))
|
476
|
-
|
477
|
-
def get_py_geo_components(self, geometry, template_name=None):
|
478
|
-
components = Enumerable.ToList[SimComponent](self.current_data_model.exch.GetComponents(geometry))
|
479
|
-
return [self.create_python_object(x, template_name=template_name) for x in components]
|
480
|
-
|
481
|
-
|
482
|
-
def add_properties(prop_name: str, syn_name: str, param_type: str, slot=None) -> property:
|
483
|
-
"""
|
484
|
-
create property for a class
|
485
|
-
:param prop_name: name of the property (str)
|
486
|
-
:param prop_name: name of the synonym (str)
|
487
|
-
:param param_type: type of the property; if type == 'str': param.get_TextValue(); else: param.get_ValueCurrent() is returned
|
488
|
-
:param slot: slot; default is None
|
489
|
-
:return: property
|
490
|
-
"""
|
491
|
-
|
492
|
-
@lru_cache()
|
493
|
-
def getx(self):
|
494
|
-
obj = None
|
495
|
-
|
496
|
-
idx = next((i for i, x in enumerate(self._wrapped_obj.Parameters.Items) if x.Name == prop_name), None)
|
497
|
-
if idx is not None:
|
498
|
-
param = self._wrapped_obj.Parameters.Items[idx]
|
499
|
-
obj = param.get_MultiValuePointer()
|
500
|
-
|
501
|
-
if obj is None:
|
502
|
-
if param_type == 'str':
|
503
|
-
obj = param.get_TextValue()
|
504
|
-
else:
|
505
|
-
obj = param.get_ValueCurrent()
|
506
|
-
|
507
|
-
if obj is None:
|
508
|
-
full_slot_name = self._slots.get(prop_name, None)
|
509
|
-
slot_name, slot_extension = parse_slot(full_slot_name)
|
510
|
-
|
511
|
-
if full_slot_name is not None:
|
512
|
-
obj = next((x.Component for x in self._wrapped_obj.Components.Items
|
513
|
-
if (x.Slot.SlotBase.Base == slot_name) & (x.Slot.SlotExtension == slot_extension)),
|
514
|
-
None)
|
515
|
-
|
516
|
-
if obj is None:
|
517
|
-
obj = next((x.Target for x in self._wrapped_obj.ReferencedComponents.Items
|
518
|
-
if ' '.join([str(x.Slot.SlotBase),
|
519
|
-
x.Slot.SlotExtension]) == full_slot_name),
|
520
|
-
None)
|
521
|
-
|
522
|
-
return self._template_parser.create_python_object(obj)
|
523
|
-
|
524
|
-
def setx(self, value: Union[int, float, SimComponent, SimultanObject]):
|
525
|
-
getx.cache_clear()
|
526
|
-
idx = next((i for i, x in enumerate(self._wrapped_obj.Parameters.Items) if x.Name == prop_name), None)
|
527
|
-
|
528
|
-
if isinstance(value, (SimComponent, SimultanObject)):
|
529
|
-
# set reference or subcomponent
|
530
|
-
|
531
|
-
if prop_name not in self._slots.keys():
|
532
|
-
raise KeyError(f'{prop_name} not defined as slot for class {self.__class__.__name__}')
|
533
|
-
|
534
|
-
full_slot_name = self._slots.get(prop_name, None)
|
535
|
-
slot_name, slot_extension = parse_slot(full_slot_name)
|
536
|
-
|
537
|
-
# check if slot exists:
|
538
|
-
idx = self.slot_components.index[
|
539
|
-
(self.slot_components.slot == slot_name) & (self.slot_components.slot_extension == slot_extension)]
|
540
|
-
|
541
|
-
if idx.__len__() == 1:
|
542
|
-
# if subcomponent:
|
543
|
-
if self.slot_components.iloc[idx].comp_type.values == 0:
|
544
|
-
if isinstance(value, SimultanObject):
|
545
|
-
pass
|
546
|
-
|
547
|
-
ref = next((x for x in self._wrapped_obj.Components.Items
|
548
|
-
if ((x.Slot.SlotBase.Base == slot_name) & (
|
549
|
-
x.Slot.SlotExtension == slot_extension))), None)
|
550
|
-
|
551
|
-
if isinstance(value, SimComponent):
|
552
|
-
ref.Component = value
|
553
|
-
elif isinstance(value, SimultanObject):
|
554
|
-
ref.Component = value._wrapped_obj
|
555
|
-
|
556
|
-
# if reference:
|
557
|
-
elif self.slot_components.iloc[idx].comp_type.values == 1:
|
558
|
-
ref = next((x for x in self._wrapped_obj.ReferencedComponents.Items
|
559
|
-
if ((x.Slot.SlotBase.Base == slot_name) & (
|
560
|
-
x.Slot.SlotExtension == slot_extension))), None)
|
561
|
-
|
562
|
-
if isinstance(value, SimComponent):
|
563
|
-
# delete reference
|
564
|
-
self.remove_component_reference(ref.reference)
|
565
|
-
# add the SimComponent as sub-component
|
566
|
-
self.add_sub_component(component=value,
|
567
|
-
slot_name=slot_name,
|
568
|
-
slot_extension=slot_extension,
|
569
|
-
alter_slot=True)
|
570
|
-
else:
|
571
|
-
ref.Target = value._wrapped_obj
|
572
|
-
|
573
|
-
# index does not exist
|
574
|
-
elif idx.__len__() == 0:
|
575
|
-
if isinstance(value, SimultanObject):
|
576
|
-
self.add_component_reference(component=value._wrapped_obj,
|
577
|
-
slot_name=slot_name,
|
578
|
-
slot_extension=slot_extension)
|
579
|
-
elif isinstance(value, SimComponent):
|
580
|
-
self.add_sub_component(component=value, slot_name=slot_name, slot_extension=slot_extension)
|
581
|
-
|
582
|
-
elif param_type == 'str':
|
583
|
-
#todo: implementation for referenced parameters
|
584
|
-
if self._wrapped_obj.Parameters.Items[2].GetReferencedParameter() != self._wrapped_obj.Parameters.Items[idx]:
|
585
|
-
raise NotImplementedError(f'{self.name}: Param {prop_name} is a referenced Parameter. Setting referenced parameters is not yet implemented')
|
586
|
-
self._wrapped_obj.Parameters.Items[idx].set_TextValue(value)
|
587
|
-
elif isinstance(value, (int, float)):
|
588
|
-
# todo: implementation for referenced parameters
|
589
|
-
if self._wrapped_obj.Parameters.Items[2].GetReferencedParameter() != self._wrapped_obj.Parameters.Items[idx]:
|
590
|
-
raise NotImplementedError(f'{self.name}: Param {prop_name} is a referenced Parameter. Setting referenced parameters is not yet implemented')
|
591
|
-
self._wrapped_obj.Parameters.Items[idx].set_ValueCurrent(float(value))
|
592
|
-
else:
|
593
|
-
raise TypeError(
|
594
|
-
f'{self.name}: Error setting parameter {prop_name} to {type(value)}. Supported types are only: int float str SimComponent SimultanObject.')
|
595
|
-
|
596
|
-
def delx(self):
|
597
|
-
logger.warning('delete method not implemented')
|
598
|
-
raise NotImplementedError
|
599
|
-
|
600
|
-
return property(getx, setx, delx, f"automatic created property")
|
601
|
-
|
602
|
-
|
603
|
-
def _my_loader(f):
|
604
|
-
import yaml
|
605
|
-
|
606
|
-
description = []
|
607
|
-
|
608
|
-
def any_constructor(loader, tag_suffix, node):
|
609
|
-
if isinstance(node, yaml.MappingNode):
|
610
|
-
return loader.construct_mapping(node)
|
611
|
-
if isinstance(node, yaml.SequenceNode):
|
612
|
-
return loader.construct_sequence(node)
|
613
|
-
return loader.construct_scalar(node)
|
614
|
-
|
615
|
-
yaml.add_multi_constructor('', any_constructor, Loader=yaml.SafeLoader)
|
616
|
-
data = list(yaml.load_all(f, Loader=yaml.SafeLoader))
|
617
|
-
return data
|
618
|
-
|
619
|
-
|
620
|
-
_parsers['_my_loader'] = _my_loader
|
621
|
-
|
622
|
-
|
623
|
-
class TemplateValidator(object):
|
624
|
-
|
625
|
-
def __init__(self, *args, **kwargs):
|
626
|
-
|
627
|
-
self.schema = yamale.make_schema(schema_file, parser='ruamel')
|
628
|
-
|
629
|
-
def validate(self, yaml_file):
|
630
|
-
data = yamale.make_data(yaml_file, parser='_my_loader')
|
631
|
-
yamale.validate(self.schema, data)
|