PySimultan 0.6.0.7__py3-none-any.whl → 0.6.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (109) hide show
  1. PySimultan2/CHANGELOG.md +3 -0
  2. PySimultan2/__about__.py +1 -1
  3. PySimultan2/data_model.py +116 -5
  4. PySimultan2/default_types.py +17 -0
  5. PySimultan2/files.py +112 -11
  6. PySimultan2/utils.py +5 -4
  7. {pysimultan-0.6.0.7.dist-info → pysimultan-0.6.1.dist-info}/METADATA +1 -1
  8. pysimultan-0.6.1.dist-info/RECORD +76 -0
  9. PySimultan2/typings/SIMULTAN/Data/Assets/__init__.pyi +0 -616
  10. PySimultan2/typings/SIMULTAN/Data/Components/__init__.pyi +0 -2538
  11. PySimultan2/typings/SIMULTAN/Data/FlowNetworks/__init__.pyi +0 -499
  12. PySimultan2/typings/SIMULTAN/Data/Geometry/__init__.pyi +0 -2219
  13. PySimultan2/typings/SIMULTAN/Data/MultiValues/__init__.pyi +0 -682
  14. PySimultan2/typings/SIMULTAN/Data/SimMath/__init__.pyi +0 -1654
  15. PySimultan2/typings/SIMULTAN/Data/SimNetworks/__init__.pyi +0 -442
  16. PySimultan2/typings/SIMULTAN/Data/SitePlanner/__init__.pyi +0 -193
  17. PySimultan2/typings/SIMULTAN/Data/Taxonomy/__init__.pyi +0 -367
  18. PySimultan2/typings/SIMULTAN/Data/Users/__init__.pyi +0 -116
  19. PySimultan2/typings/SIMULTAN/Data/ValueMappings/__init__.pyi +0 -212
  20. PySimultan2/typings/SIMULTAN/Data/__init__.pyi +0 -232
  21. PySimultan2/typings/SIMULTAN/DataMapping/__init__.pyi +0 -916
  22. PySimultan2/typings/SIMULTAN/Excel/__init__.pyi +0 -15
  23. PySimultan2/typings/SIMULTAN/Exceptions/__init__.pyi +0 -268
  24. PySimultan2/typings/SIMULTAN/Exchange/SimNetworkConnectors/__init__.pyi +0 -32
  25. PySimultan2/typings/SIMULTAN/Exchange/__init__.pyi +0 -116
  26. PySimultan2/typings/SIMULTAN/Projects/ManagedFiles/__init__.pyi +0 -433
  27. PySimultan2/typings/SIMULTAN/Projects/__init__.pyi +0 -435
  28. PySimultan2/typings/SIMULTAN/Serializer/CODXF/__init__.pyi +0 -103
  29. PySimultan2/typings/SIMULTAN/Serializer/CSV/__init__.pyi +0 -122
  30. PySimultan2/typings/SIMULTAN/Serializer/DXF/__init__.pyi +0 -1335
  31. PySimultan2/typings/SIMULTAN/Serializer/Geometry/__init__.pyi +0 -48
  32. PySimultan2/typings/SIMULTAN/Serializer/JSON/__init__.pyi +0 -562
  33. PySimultan2/typings/SIMULTAN/Serializer/METADXF/__init__.pyi +0 -11
  34. PySimultan2/typings/SIMULTAN/Serializer/PADXF/__init__.pyi +0 -21
  35. PySimultan2/typings/SIMULTAN/Serializer/PPATH/__init__.pyi +0 -11
  36. PySimultan2/typings/SIMULTAN/Serializer/Projects/__init__.pyi +0 -112
  37. PySimultan2/typings/SIMULTAN/Serializer/SIMLINKS/__init__.pyi +0 -5
  38. PySimultan2/typings/SIMULTAN/Serializer/SPDXF/__init__.pyi +0 -13
  39. PySimultan2/typings/SIMULTAN/Serializer/SimGeo/__init__.pyi +0 -54
  40. PySimultan2/typings/SIMULTAN/Serializer/TXDXF/__init__.pyi +0 -46
  41. PySimultan2/typings/SIMULTAN/Serializer/XMI/__init__.pyi +0 -22
  42. PySimultan2/typings/SIMULTAN/Serializer/__init__.pyi +0 -32
  43. PySimultan2/typings/SIMULTAN/Utils/BackgroundWork/__init__.pyi +0 -43
  44. PySimultan2/typings/SIMULTAN/Utils/Collections/__init__.pyi +0 -216
  45. PySimultan2/typings/SIMULTAN/Utils/ElevationProvider/__init__.pyi +0 -66
  46. PySimultan2/typings/SIMULTAN/Utils/Files/__init__.pyi +0 -48
  47. PySimultan2/typings/SIMULTAN/Utils/Randomize/__init__.pyi +0 -11
  48. PySimultan2/typings/SIMULTAN/Utils/Streams/__init__.pyi +0 -59
  49. PySimultan2/typings/SIMULTAN/Utils/UndoRedo/__init__.pyi +0 -133
  50. PySimultan2/typings/SIMULTAN/Utils/__init__.pyi +0 -570
  51. PySimultan2/typings/System/Buffers/Binary/__init__.pyi +0 -248
  52. PySimultan2/typings/System/Buffers/Text/__init__.pyi +0 -91
  53. PySimultan2/typings/System/Buffers/__init__.pyi +0 -192
  54. PySimultan2/typings/System/CodeDom/Compiler/__init__.pyi +0 -137
  55. PySimultan2/typings/System/Collections/Concurrent/__init__.pyi +0 -47
  56. PySimultan2/typings/System/Collections/Generic/__init__.pyi +0 -1293
  57. PySimultan2/typings/System/Collections/ObjectModel/__init__.pyi +0 -166
  58. PySimultan2/typings/System/Collections/Specialized/__init__.pyi +0 -82
  59. PySimultan2/typings/System/Collections/__init__.pyi +0 -403
  60. PySimultan2/typings/System/ComponentModel/__init__.pyi +0 -582
  61. PySimultan2/typings/System/Configuration/Assemblies/__init__.pyi +0 -30
  62. PySimultan2/typings/System/Diagnostics/CodeAnalysis/__init__.pyi +0 -315
  63. PySimultan2/typings/System/Diagnostics/Contracts/__init__.pyi +0 -297
  64. PySimultan2/typings/System/Diagnostics/SymbolStore/__init__.pyi +0 -9
  65. PySimultan2/typings/System/Diagnostics/Tracing/__init__.pyi +0 -641
  66. PySimultan2/typings/System/Diagnostics/__init__.pyi +0 -1101
  67. PySimultan2/typings/System/Globalization/__init__.pyi +0 -1675
  68. PySimultan2/typings/System/IO/Enumeration/__init__.pyi +0 -125
  69. PySimultan2/typings/System/IO/__init__.pyi +0 -2747
  70. PySimultan2/typings/System/Linq/Expressions/__init__.pyi +0 -1815
  71. PySimultan2/typings/System/Net/__init__.pyi +0 -81
  72. PySimultan2/typings/System/Numerics/__init__.pyi +0 -2853
  73. PySimultan2/typings/System/Reflection/Emit/__init__.pyi +0 -1945
  74. PySimultan2/typings/System/Reflection/Metadata/__init__.pyi +0 -24
  75. PySimultan2/typings/System/Reflection/__init__.pyi +0 -2724
  76. PySimultan2/typings/System/Resources/__init__.pyi +0 -205
  77. PySimultan2/typings/System/Runtime/CompilerServices/__init__.pyi +0 -1926
  78. PySimultan2/typings/System/Runtime/ConstrainedExecution/__init__.pyi +0 -49
  79. PySimultan2/typings/System/Runtime/ExceptionServices/__init__.pyi +0 -34
  80. PySimultan2/typings/System/Runtime/InteropServices/ComTypes/__init__.pyi +0 -758
  81. PySimultan2/typings/System/Runtime/InteropServices/Marshalling/__init__.pyi +0 -461
  82. PySimultan2/typings/System/Runtime/InteropServices/ObjectiveC/__init__.pyi +0 -48
  83. PySimultan2/typings/System/Runtime/InteropServices/__init__.pyi +0 -2632
  84. PySimultan2/typings/System/Runtime/Intrinsics/Arm/__init__.pyi +0 -4757
  85. PySimultan2/typings/System/Runtime/Intrinsics/Wasm/__init__.pyi +0 -844
  86. PySimultan2/typings/System/Runtime/Intrinsics/X86/__init__.pyi +0 -5642
  87. PySimultan2/typings/System/Runtime/Intrinsics/__init__.pyi +0 -4504
  88. PySimultan2/typings/System/Runtime/Loader/__init__.pyi +0 -63
  89. PySimultan2/typings/System/Runtime/Remoting/__init__.pyi +0 -7
  90. PySimultan2/typings/System/Runtime/Serialization/__init__.pyi +0 -269
  91. PySimultan2/typings/System/Runtime/Versioning/__init__.pyi +0 -200
  92. PySimultan2/typings/System/Runtime/__init__.pyi +0 -141
  93. PySimultan2/typings/System/Security/Cryptography/__init__.pyi +0 -39
  94. PySimultan2/typings/System/Security/Permissions/__init__.pyi +0 -163
  95. PySimultan2/typings/System/Security/Principal/__init__.pyi +0 -45
  96. PySimultan2/typings/System/Security/__init__.pyi +0 -347
  97. PySimultan2/typings/System/Text/Unicode/__init__.pyi +0 -62
  98. PySimultan2/typings/System/Text/__init__.pyi +0 -1590
  99. PySimultan2/typings/System/Threading/Tasks/Sources/__init__.pyi +0 -76
  100. PySimultan2/typings/System/Threading/Tasks/__init__.pyi +0 -1403
  101. PySimultan2/typings/System/Threading/__init__.pyi +0 -1788
  102. PySimultan2/typings/System/Xml/Schema/__init__.pyi +0 -1255
  103. PySimultan2/typings/System/Xml/Serialization/__init__.pyi +0 -16
  104. PySimultan2/typings/System/Xml/XPath/__init__.pyi +0 -474
  105. PySimultan2/typings/System/Xml/__init__.pyi +0 -2410
  106. PySimultan2/typings/System/__init__.pyi +0 -17821
  107. pysimultan-0.6.0.7.dist-info/RECORD +0 -174
  108. {pysimultan-0.6.0.7.dist-info → pysimultan-0.6.1.dist-info}/WHEEL +0 -0
  109. {pysimultan-0.6.0.7.dist-info → pysimultan-0.6.1.dist-info}/licenses/LICENSE.txt +0 -0
PySimultan2/CHANGELOG.md CHANGED
@@ -1,3 +1,6 @@
1
+ Version 0.6.1 (24.02.2024)
2
+ - Bugfixes in default_types and File/Directory handling
3
+
1
4
  Version 0.6.0.3 (23.01.2024)
2
5
  - Added sub_classes and super_classes to SimultanObject
3
6
 
PySimultan2/__about__.py CHANGED
@@ -1 +1 @@
1
- version = '0.6.0.7'
1
+ version = '0.6.1'
PySimultan2/data_model.py CHANGED
@@ -1,4 +1,5 @@
1
1
  import atexit
2
+ import pathlib
2
3
  import os
3
4
  import shutil
4
5
  from uuid import uuid4
@@ -528,6 +529,17 @@ class DataModel:
528
529
  if isinstance(target_dir, SystemFileInfo):
529
530
  target_dir = target_dir.FullPath
530
531
 
532
+ if target_dir.startswith(self.project.ProjectUnpackFolder.FullPath):
533
+ return self.project.AddEmptyResource(SystemFileInfo(os.path.join(target_dir, str(filename))))
534
+ else:
535
+ return self.project.AddEmptyResource(SystemFileInfo(os.path.join(
536
+ self.project.ProjectUnpackFolder.FullPath,
537
+ target_dir,
538
+ str(filename))
539
+ )
540
+ )
541
+
542
+
531
543
  return self.project.AddEmptyResource(FileInfo(
532
544
  os.path.join(target_dir, str(filename))
533
545
  )
@@ -595,6 +607,9 @@ class DataModel:
595
607
 
596
608
  if not act_filename.startswith(self.project.ProjectUnpackFolder.FullPath) and target_dir is None:
597
609
  target_dir_str = self.project.ProjectUnpackFolder.FullPath
610
+ elif act_filename.startswith(self.project.ProjectUnpackFolder.FullPath):
611
+ target_dir_str = ''
612
+
598
613
  elif target_dir is not None:
599
614
  if isinstance(target_dir, ResourceDirectoryEntry):
600
615
  target_dir_str = target_dir.CurrentFullPath
@@ -626,7 +641,7 @@ class DataModel:
626
641
  if target_dir is None:
627
642
  resource = self.project.CopyResourceAsContainedFileEntry(filename,
628
643
  self.project.ProjectUnpackFolder,
629
- '1')
644
+ '{0} ({1})')
630
645
  else:
631
646
  if isinstance(target_dir, str):
632
647
  target_dir = DirectoryInfo(target_dir)
@@ -655,6 +670,18 @@ class DataModel:
655
670
  logger.error(f'Error while adding resource {filename} to project {self.project_path}: {e}')
656
671
  raise e
657
672
 
673
+ def get_resource(self, key: Union[str, int, SystemFileInfo, DirectoryInfo]):
674
+
675
+ if isinstance(key, (int, SystemFileInfo, DirectoryInfo)):
676
+ return self.project_data_manager.AssetManager.GetResource(key)
677
+ elif isinstance(key, str):
678
+ if os.path.isfile(key):
679
+ return self.project_data_manager.AssetManager.GetResource(SystemFileInfo(key))
680
+ elif os.path.isdir(key):
681
+ return self.project_data_manager.AssetManager.GetResource(DirectoryInfo(key))
682
+ else:
683
+ return None
684
+
658
685
  def delete_resource(self, resource: Union[ResourceEntry, SystemFileInfo, ContainedResourceFileEntry]):
659
686
  """
660
687
  Delete a resource from the project and the project folder
@@ -673,18 +700,102 @@ class DataModel:
673
700
  self.get_file_infos.cache_clear()
674
701
  return success
675
702
 
703
+ def get_existing_resource_directory_entry(self,
704
+ full_path: str) -> ResourceDirectoryEntry:
705
+ return self.project_data_manager.AssetManager.GetResource(DirectoryInfo(full_path))
706
+
676
707
  def create_resource_directory(self,
677
708
  name: str,
678
- parent_directory: DirectoryInfo=None,
709
+ parent_directory: Union[DirectoryInfo, str, pathlib.Path]=None,
710
+ create_parents: bool = True,
679
711
  collision_name_format: str = '{0} ({1})') -> ResourceEntry:
680
712
 
681
713
  if parent_directory is None:
682
- new_directory = self.project.CreateResourceDirIn(name, None, collision_name_format)
714
+ if name.startswith(self.project.ProjectUnpackFolder.FullPath):
715
+ full_path = name
716
+ else:
717
+ full_path = os.path.join(self.project.ProjectUnpackFolder.FullPath, name)
718
+ else:
719
+ if isinstance(parent_directory, str):
720
+ if not parent_directory.startswith(self.project.ProjectUnpackFolder.FullPath):
721
+ full_path = os.path.join(self.project.ProjectUnpackFolder.FullPath, parent_directory, name)
722
+ else:
723
+ full_path = parent_directory
724
+ elif isinstance(parent_directory, DirectoryInfo):
725
+ full_path = os.path.join(parent_directory.FullPath, name)
726
+ elif isinstance(parent_directory, pathlib.Path):
727
+ full_path = os.path.join(parent_directory, name)
728
+
729
+
730
+ existing_resource_directory = self.get_existing_resource_directory_entry(str(full_path))
731
+ if existing_resource_directory is not None:
732
+ return existing_resource_directory
733
+
734
+ if str(pathlib.Path(full_path).parents[0]) == self.project.ProjectUnpackFolder.FullPath:
735
+ # create directory in ProjectUnpackFolder
736
+ resource_directory_entry = self.get_existing_resource_directory_entry(full_path)
737
+ if resource_directory_entry is not None:
738
+ return resource_directory_entry
739
+ else:
740
+ new_resource_entry = self.project.CreateResourceDirIn(
741
+ str(
742
+ pathlib.Path(full_path).relative_to(pathlib.Path(self.project.ProjectUnpackFolder.FullPath))
743
+ ),
744
+ None,
745
+ collision_name_format)
746
+ if new_resource_entry not in self.project_data_manager.AssetManager.Resources:
747
+ self.project_data_manager.AssetManager.AddResourceEntry(new_resource_entry)
748
+ return new_resource_entry
683
749
  else:
684
- new_directory = self.project.CreateResourceDirIn(name, parent_directory, collision_name_format)
750
+ if parent_directory is None:
751
+ parent = None
752
+ for i in reversed(range(pathlib.Path(full_path).parents.__len__())):
753
+ parent = pathlib.Path(full_path).parents[i]
754
+ if str(parent) in self.project.ProjectUnpackFolder.FullPath:
755
+ continue
756
+ if not os.path.exists(parent):
757
+ if create_parents:
758
+ parent_directory = self.create_resource_directory(parent.name,
759
+ parent_directory=parent.parents[0],
760
+ create_parents=False)
761
+ else:
762
+ raise FileNotFoundError(f'Parent directory {parent} does not exist')
763
+ else:
764
+ parent_directory = self.get_existing_resource_directory_entry(str(parent))
685
765
 
686
- return new_directory
766
+ if parent_directory is None:
767
+ new_resource_entry = self.project.CreateResourceDirIn(
768
+ str(
769
+ pathlib.Path(full_path).relative_to(pathlib.Path(self.project.ProjectUnpackFolder.FullPath))
770
+ ),
771
+ parent_directory,
772
+ collision_name_format)
773
+ self.project_data_manager.AssetManager.AddResourceEntry(new_resource_entry)
774
+ return new_resource_entry
775
+ else:
776
+ if isinstance(parent_directory, pathlib.Path):
777
+ target = str(pathlib.Path(full_path).relative_to(parent_directory))
778
+ parent_directory_target = DirectoryInfo(str(parent_directory))
779
+ elif isinstance(parent_directory, str):
780
+ target = str(pathlib.Path(full_path).relative_to(pathlib.Path(parent_directory)))
781
+ parent_directory_target = DirectoryInfo(parent_directory)
782
+ elif isinstance(parent_directory, DirectoryInfo):
783
+ target = str(pathlib.Path(full_path).relative_to(pathlib.Path(parent_directory.CurrentFullPath)))
784
+ parent_directory_target = parent_directory
785
+ elif isinstance(parent_directory, ResourceDirectoryEntry):
786
+ target = str(pathlib.Path(full_path).relative_to(pathlib.Path(parent_directory.CurrentFullPath)))
787
+ parent_directory_target = DirectoryInfo(parent_directory.CurrentFullPath)
687
788
 
789
+ else:
790
+ raise ValueError(f'Parent directory {parent_directory} not found')
791
+
792
+ new_resource_entry = self.project.CreateResourceDirIn(
793
+ target,
794
+ parent_directory_target,
795
+ collision_name_format)
796
+ if new_resource_entry.manager is None:
797
+ self.project_data_manager.AssetManager.AddResourceEntry(new_resource_entry)
798
+ return new_resource_entry
688
799
 
689
800
  def add_table(self, table: SimMultiValueBigTable):
690
801
  self.project_data_manager.ValueManager.Add(table)
@@ -686,5 +686,22 @@ class ComponentDictionary(SimultanObject):
686
686
  }
687
687
  }
688
688
 
689
+ def get_raw_attr(self, attr: Optional[str] = None, text_or_key: Optional[str] = None):
690
+ if attr is not None:
691
+ content = self._taxonomy_map.get_content_by_property_name(attr)
692
+ if content is None:
693
+ content = Content(text_or_key=f'__dict_key__{attr}',
694
+ property_name=attr,
695
+ type=None,
696
+ unit=None,
697
+ documentation=f'Property {attr} in ComponentDictionary',
698
+ component_policy=self.component_policy)
699
+ self._taxonomy_map.add_content(content)
700
+
701
+ return get_component_taxonomy_entry(self._wrapped_obj, content.text_or_key)
702
+
703
+ if text_or_key is not None:
704
+ return get_component_taxonomy_entry(self._wrapped_obj, text_or_key)
705
+
689
706
 
690
707
  component_dict_map = ComponentDictionary._taxonomy_map
PySimultan2/files.py CHANGED
@@ -3,10 +3,12 @@ This module contains classes and functions to handle files and directories.
3
3
  """
4
4
  from __future__ import annotations
5
5
  from datetime import datetime
6
+ import glob
6
7
 
7
8
  import contextlib
8
9
  import os
9
10
  import io
11
+ import re
10
12
  import shutil
11
13
  import tempfile
12
14
  from typing import List, Union, Optional
@@ -124,6 +126,13 @@ def create_asset_from_string(filename: str,
124
126
  :param tag: Tag to be added to the asset.
125
127
  :return: ResourceFileEntry
126
128
  """
129
+
130
+ # check if file already exists
131
+ if target_dir is not None:
132
+ if isinstance(target_dir, DirectoryInfo):
133
+ target_dir = target_dir.full_path
134
+
135
+
127
136
  with tempdir() as dirpath:
128
137
  filepath = os.path.join(dirpath, filename)
129
138
  with open(filepath, 'w') as f:
@@ -290,11 +299,35 @@ class FileInfo(object, metaclass=MetaMock):
290
299
  """
291
300
 
292
301
  data_model = kwargs.get('data_model', config.get_default_data_model())
293
- resource = create_asset_from_string(filename,
294
- content,
295
- target_dir=target_dir,
296
- *args,
297
- **kwargs)
302
+
303
+ if target_dir is not None:
304
+ if isinstance(target_dir, DirectoryInfo):
305
+ full_path = os.path.join(target_dir.full_path, filename)
306
+ elif isinstance(target_dir, ResourceDirectoryEntry):
307
+ full_path = os.path.join(target_dir.CurrentFullPath, filename)
308
+ elif isinstance(target_dir, str):
309
+ full_path = os.path.join(target_dir, filename)
310
+ else:
311
+ if not filename.startswith(str(data_model.project.ProjectUnpackFolder)):
312
+ full_path = os.path.join(str(data_model.project.ProjectUnpackFolder), filename)
313
+ else:
314
+ full_path = filename
315
+
316
+ if os.path.isfile(full_path):
317
+ # check if resource entry exists
318
+ resource = data_model.get_resource(full_path)
319
+ if resource is None:
320
+ resource = create_asset_from_string(filename,
321
+ content,
322
+ target_dir=target_dir,
323
+ *args,
324
+ **kwargs)
325
+ else:
326
+ resource = create_asset_from_string(filename,
327
+ content,
328
+ target_dir=target_dir,
329
+ *args,
330
+ **kwargs)
298
331
 
299
332
  file_info = cls(resource_entry=resource,
300
333
  data_model=data_model)
@@ -332,6 +365,7 @@ class FileInfo(object, metaclass=MetaMock):
332
365
  :param kwargs:
333
366
  """
334
367
  # do custom stuff here
368
+ self.deleted = False
335
369
  self._resource_entry: Union[ResourceFileEntry, ContainedResourceFileEntry, None] = None
336
370
 
337
371
  if file_path is not None:
@@ -365,7 +399,7 @@ class FileInfo(object, metaclass=MetaMock):
365
399
 
366
400
  @property
367
401
  def resource_entry(self) -> Union[ResourceFileEntry, ContainedResourceFileEntry, None]:
368
- if self._resource_entry is None:
402
+ if self._resource_entry is None and not self.deleted:
369
403
  if self.data_model is None:
370
404
  logger.warning(f'No data model provided. Using default data model: {config.get_default_data_model().id}.')
371
405
  self.data_model = config.get_default_data_model()
@@ -453,7 +487,10 @@ class FileInfo(object, metaclass=MetaMock):
453
487
  self.file_obj.close()
454
488
 
455
489
  def __repr__(self):
456
- return f'FileInfo({self.file_path})'
490
+ if not self.deleted:
491
+ return f'FileInfo({self.file_path})'
492
+ else:
493
+ return f'FileInfo({self.file_path}) (deleted)'
457
494
 
458
495
  def move(self, new_directory_path: Union[str, DirectoryInfo]) -> FileInfo:
459
496
 
@@ -533,7 +570,11 @@ class FileInfo(object, metaclass=MetaMock):
533
570
  del self._cls_instances[self.resource_entry.Key]
534
571
  self.data_model.delete_resource(self.resource_entry)
535
572
 
536
- os.remove(self.file_path)
573
+ try:
574
+ os.remove(self.file_path)
575
+ except FileNotFoundError:
576
+ pass
577
+ self.deleted = True
537
578
 
538
579
  def to_json(self) -> dict:
539
580
 
@@ -613,6 +654,8 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
613
654
  *args,
614
655
  **kwargs):
615
656
 
657
+ self.deleted = False
658
+
616
659
  self._resource_entry: Optional[ResourceDirectoryEntry] = None
617
660
  self._helper_file: Optional[FileInfo] = None
618
661
  self.data_model: Optional[DataModel] = kwargs.get('data_model', None)
@@ -635,7 +678,7 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
635
678
 
636
679
  @property
637
680
  def helper_file(self) -> Optional[FileInfo]:
638
- if self._helper_file is None or not isinstance(self._helper_file, FileInfo):
681
+ if (self._helper_file is None or not isinstance(self._helper_file, FileInfo)) and not self.deleted:
639
682
  self._helper_file = self.add_file('__dir_helper_file__')
640
683
 
641
684
  return self._helper_file
@@ -646,7 +689,7 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
646
689
 
647
690
  @property
648
691
  def resource_entry(self) -> Optional[ResourceDirectoryEntry]:
649
- if self._resource_entry is None:
692
+ if self._resource_entry is None and not self.deleted:
650
693
  if self.data_model is None:
651
694
  logger.warning(
652
695
  f'No data model provided. Using default data model: {config.get_default_data_model().id}.')
@@ -795,5 +838,63 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
795
838
  def add_tag(self, tag: SimTaxonomyEntry) -> None:
796
839
  add_tag_to_resource(self.resource_entry, tag)
797
840
 
841
+ def delete(self):
842
+
843
+ for file in self.files:
844
+ file.delete()
845
+
846
+ # delete helper file
847
+ if self.helper_file is not None:
848
+ self.helper_file.delete()
849
+
850
+ if self.resource_entry is not None:
851
+ if self.resource_entry.Key in self._cls_instances:
852
+ del self._cls_instances[self.resource_entry.Key]
853
+ self.data_model.delete_resource(self.resource_entry)
854
+
855
+ shutil.rmtree(self.full_path)
856
+ self.deleted = True
857
+
858
+ def delete_files(self,
859
+ pattern: Optional[str] = None,
860
+ recursive: bool = False) -> None:
861
+ """
862
+ Delete files by pattern.
863
+ :param pattern: Pattern to match files. Default is None. if None, all files are deleted.
864
+ :param recursive: If True, delete files recursively.
865
+ :return:
866
+ """
867
+
868
+ if pattern:
869
+ matching = glob.glob(self.full_path + f'/{pattern}', recursive=recursive)
870
+
871
+ for file in self.files:
872
+ if pattern is None or file.file_path in matching:
873
+ logger.debug(f'Deleting file: {file.filename}')
874
+ file.delete()
875
+
876
+ if recursive:
877
+ for sub_dir in self.sub_directories:
878
+ sub_dir.delete_files(pattern=pattern, recursive=recursive)
879
+
880
+ def delete_subdirectories(self,
881
+ pattern: Optional[str] = None,
882
+ recursive: bool = False) -> None:
883
+
884
+ """
885
+ Delete subdirectories by pattern.
886
+ :param pattern: Regex pattern to match subdirectories. Default is None. If None, all subdirectories are deleted.
887
+ :param recursive: If True, delete subdirectories recursively.
888
+ :return:
889
+ """
890
+
891
+ for sub_dir in self.sub_directories:
892
+ if pattern is None or re.match(pattern, sub_dir.relative_path):
893
+ logger.debug(f'Deleting subdirectory: {sub_dir.relative_path}')
894
+ sub_dir.delete()
895
+
798
896
  def __repr__(self):
799
- return f'DirectoryInfo(key:{self.key}, hash: {hash(self)}; {self.full_path})'
897
+ if not self.deleted:
898
+ return f'DirectoryInfo(key:{self.key}, hash: {hash(self)}; {self.full_path})'
899
+ else:
900
+ return f'(Deleted) DirectoryInfo(key:{self.key}, hash: {hash(self)}; {self.full_path}) (deleted)'
PySimultan2/utils.py CHANGED
@@ -181,7 +181,7 @@ def get_or_create_taxonomy_entry(name: str,
181
181
  if key in taxonomy_entries.keys():
182
182
  return taxonomy_entries[key]
183
183
  if create:
184
- new_sim_taxonomy_entry = SimTaxonomyEntry(key, name, description)
184
+ new_sim_taxonomy_entry = SimTaxonomyEntry(key, name, description, None)
185
185
  if sim_taxonomy is not None:
186
186
  sim_taxonomy.Entries.Add(new_sim_taxonomy_entry)
187
187
  return new_sim_taxonomy_entry
@@ -1132,7 +1132,9 @@ def set_property_to_sim_component(value: Union[SimComponent, SimultanObject, lis
1132
1132
  else:
1133
1133
  component._wrapped_obj.Components.RemoveItem(component_idx)
1134
1134
  if ref_component_idx is not None:
1135
- if wrapped_obj.Id.Equals(component._wrapped_obj.ReferencedComponents.Items[ref_component_idx].Target.Id):
1135
+ if component._wrapped_obj.ReferencedComponents.Items[ref_component_idx].Target is None:
1136
+ component._wrapped_obj.ReferencedComponents.RemoveItem(ref_component_idx)
1137
+ elif wrapped_obj.Id.Equals(component._wrapped_obj.ReferencedComponents.Items[ref_component_idx].Target.Id):
1136
1138
  return
1137
1139
  else:
1138
1140
  component._wrapped_obj.ReferencedComponents.RemoveItem(ref_component_idx)
@@ -1373,7 +1375,7 @@ def set_property_to_dict(value: dict,
1373
1375
  return
1374
1376
 
1375
1377
  if component_idx is not None:
1376
- component = component._wrapped_obj.Components.Items[component_idx].Component
1378
+ sub_component = component._wrapped_obj.Components.Items[component_idx].Component
1377
1379
 
1378
1380
  if 'ComponentDictionary' in [x.Target.Key for x in component.Slots]:
1379
1381
  if not hasattr(component, '_object_mapper'):
@@ -1393,7 +1395,6 @@ def set_property_to_dict(value: dict,
1393
1395
  component_dict.update(value)
1394
1396
  return component_dict
1395
1397
  else:
1396
- component._data_model.remove_subcomponent(component)
1397
1398
  component._wrapped_obj.Components.RemoveItem(component_idx)
1398
1399
  component_idx = None
1399
1400
  if ref_component_idx is not None:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: PySimultan
3
- Version: 0.6.0.7
3
+ Version: 0.6.1
4
4
  Project-URL: Documentation, https://github.com/Bühler Maximilian/PySimultan2#readme
5
5
  Project-URL: Issues, https://github.com/Bühler Maximilian/PySimultan2/issues
6
6
  Project-URL: Source, https://github.com/Bühler Maximilian/PySimultan2
@@ -0,0 +1,76 @@
1
+ PySimultan2/CHANGELOG.md,sha256=m2kQeo1c4OzqfWfSPo5h9a_MckVP9ujQcV522cWJeRw,1168
2
+ PySimultan2/__about__.py,sha256=6dnIBU76aotxIqMySiQ6NBgICwIDVWir8GgeCS4OjOU,19
3
+ PySimultan2/__init__.py,sha256=PGVR1uhY01dF5tHyad-znURUZ_LVB95vsjId2BT0aJM,3245
4
+ PySimultan2/data_model.py,sha256=5E-AJfnXNJq-Y6srN7DfvCDwkZXqXQBDXTsFlQ2Zh6g,44104
5
+ PySimultan2/default_types.py,sha256=giO0cd23fG-9vnC-fXtqnUo7Q3r1q3_howEnVnD7XlU,30360
6
+ PySimultan2/files.py,sha256=mf4MC9UspmQvwbW7GKavwvFKICpKNRfRpDKsA4sZtUQ,33316
7
+ PySimultan2/multi_values.py,sha256=ZFXlTLuZo32x7_7diYAp2XEjp5uwgHLgNOzN7v74-5I,13650
8
+ PySimultan2/object_mapper.py,sha256=Vq4LsX5m6J1dsdlIC6V7sXEUGZYpkgPD6kwOdo5dLRI,19888
9
+ PySimultan2/simultan_object.py,sha256=-3dTlkyoVdrXmSZgozz7fTHJnaxN63utYPXOXTCuEOY,20837
10
+ PySimultan2/taxonomy_maps.py,sha256=hhgXhRXIPTD2briG_yYZssJ9musOnzs0LC4e8e78e40,10323
11
+ PySimultan2/type_setter_lookup.py,sha256=PGa5_EtV7SM15w3uxy0fA3LiQ0TaS4Ys0LYR5zs8aNk,3748
12
+ PySimultan2/utils.py,sha256=NzJabuewGd-UQG9YkvbivyhSqBcjMPArfRl-IzcKAZU,67097
13
+ PySimultan2/geometry/__init__.py,sha256=nJolTD1i5J8qUkOQa-r3D20aq3Co3sN31Xc0n4wJpJo,248
14
+ PySimultan2/geometry/geometry_base.py,sha256=TwABfQEsqxAIGLqwvqVXEV-GA5sYGBJSJm7e58QmNzM,24015
15
+ PySimultan2/geometry/utils.py,sha256=J25YsK8sso_UL7xRusItQZvyjtvxdOsSPelBQYFABhY,8519
16
+ PySimultan2/resources/AssimpNet.dll,sha256=x8uwMHPRmEH9fDQihfEQLUdblM1u7RP-CCnUjOpXcLo,205312
17
+ PySimultan2/resources/AvalonDock.dll,sha256=9tCcw7cpaVq0bh1H2sfcxb8EWhySmgujPs89lAqIPZs,500224
18
+ PySimultan2/resources/BruTile.dll,sha256=sJOMQaku5jxcbL7XEd9pehBopyFEHOZzaLyNZyD6u7U,203264
19
+ PySimultan2/resources/ClosedXML.dll,sha256=dzkwJaBvIdou7SZSE5lsEART_jlnMMztEZu_jBuHp74,1198592
20
+ PySimultan2/resources/ComponentBuilder.dll,sha256=38kTs312oyDDfX9z4JJyvlfbb7JxMrCEFe58zYnidcQ,2324992
21
+ PySimultan2/resources/ComponentBuilder.dll.config,sha256=jP5s_8OMg9085DyGtrLZcguy8etqm4ra21KwDXq1sy0,3032
22
+ PySimultan2/resources/ComponentBuilder.runtimeconfig.json,sha256=YBIGLYblUb1QapC3Td-VcI9HtfEQ_6rQssb-JbeODyA,458
23
+ PySimultan2/resources/ComponentBuilder.xml,sha256=-P7kILmeX_v7ZCie38jMrceS5gX53h7q8ukIKNmgoyU,1044233
24
+ PySimultan2/resources/ControlzEx.dll,sha256=S26xw5MnNiIoyiCmVFbFOmUx1yx_zAyXBdDSOSidZxQ,463160
25
+ PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll,sha256=JG8HbAq5s796e02jB9QklO2cOyKPtHmhY6vc7KUs0OQ,41800
26
+ PySimultan2/resources/DocumentFormat.OpenXml.dll,sha256=JjiBI17BpHztipV39dQdXAjhHo6Ic0xRjijJJuBQLLo,6108592
27
+ PySimultan2/resources/DotSpatial.Projections.dll,sha256=dK4oFLcpUK3i6CZ3qIcX5B0npYd-W4hHJz7RJvM77ho,1541632
28
+ PySimultan2/resources/ExcelNumberFormat.dll,sha256=18Rbjk4QJ4MeL8jN-UH69R0opm_qz8qqc32nMmLntQc,30720
29
+ PySimultan2/resources/Fluent.dll,sha256=9b7QKKj8-Ynhe4WqSVfiP82PkxYz_kI_GXYi_KQxrEU,2598400
30
+ PySimultan2/resources/HelixToolkit.Core.Wpf.dll,sha256=EU2-CBh2SDNjwZEP2pOBJhLUf0lKpOL77dYH4fS3wZY,592384
31
+ PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll,sha256=KgLYD_QrOxwu90Zk59KLsquAGthP_B-FW0GyHEkyDk0,613888
32
+ PySimultan2/resources/HelixToolkit.SharpDX.Core.dll,sha256=iKE8TEEAEX9FCg-6CipTCq79aiR79d6jep0rwMCAwgM,1733120
33
+ PySimultan2/resources/HelixToolkit.dll,sha256=HjbeIX5qCQOm-2HhJCd7ZjCwGAeVoaAHo3SHV8_B4ak,6656
34
+ PySimultan2/resources/MathNet.Numerics.dll,sha256=g7QaYI5DhAnWUg0BEk9S9XQJ4il5HA4HTjFazn2fQTQ,1600000
35
+ PySimultan2/resources/Microsoft.AspNetCore.Authorization.dll,sha256=P7_HRwCqdk3q1MD7UtlAXMN_E8gZRdzme6ESGZsXHNk,49272
36
+ PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll,sha256=jddQwxkgfjmJ6vlXok-PbfnIquNDs6VHvspFEopiTAY,17016
37
+ PySimultan2/resources/Microsoft.Extensions.DependencyInjection.Abstractions.dll,sha256=jrAm-30mcWoI54hsUTOr-RMOzHIq-zO8ZuRBVrBvCoo,43656
38
+ PySimultan2/resources/Microsoft.Extensions.Logging.Abstractions.dll,sha256=7mzUlhcvGxpAVO4h_Tka7P_8IXF9ZsHkGt0fp5aufkU,63096
39
+ PySimultan2/resources/Microsoft.Extensions.Options.dll,sha256=gcHJrSv1wTqvF9SyWTEKcbiShn4mkgfnm9-tRQr4OqY,60584
40
+ PySimultan2/resources/Microsoft.Extensions.Primitives.dll,sha256=q4ruoDSCjV_QJY9ZkzV6uxvEvZUVrDbyUjU3SSh5SlE,41616
41
+ PySimultan2/resources/Microsoft.WindowsAPICodePack.Shell.dll,sha256=VTVjKHwRDUz4rGoy8r3j4IP94wHDQky2NImHsqFhbHk,514048
42
+ PySimultan2/resources/Microsoft.WindowsAPICodePack.dll,sha256=aB9FK5RWRh1onyayOe0YIuu2Qtqv7hq-HmZQH40Mk4s,103936
43
+ PySimultan2/resources/Microsoft.Xaml.Behaviors.dll,sha256=j3gq16397qqTMYMGWqegvpOHq85gOOkSRV54UnsErco,145272
44
+ PySimultan2/resources/Newtonsoft.Json.Bson.dll,sha256=tgbl3XemJCyh8d9xfrU9lQWuVpBDMLl1wI1PLb6MMxk,90624
45
+ PySimultan2/resources/Newtonsoft.Json.dll,sha256=etsgJYQb32kqVnEuCK_nXhcwxx1keKj-1XWs1DJRpmI,639488
46
+ PySimultan2/resources/Python.Runtime.dll,sha256=i8TGSK2uHgN4_JwFn8llwTNrhXtqU-l05M8-CdMIy7Q,438784
47
+ PySimultan2/resources/SIMULTAN.Lang.dll,sha256=Z_vMisLt6CHABBO_FYcA9utI8n10kSqXy7tE5iFa8o0,2587136
48
+ PySimultan2/resources/SIMULTAN.Lang.xml,sha256=5kUlwuT-UNog9Y2JjjSFdBW8b1s14Nf1B_YyQlrf7Vg,739070
49
+ PySimultan2/resources/SIMULTAN.UI.dll,sha256=Iya297q6BCfLAHxLnJEoFi6h9-H54Dg0Ps6bbyDyOuQ,1245184
50
+ PySimultan2/resources/SIMULTAN.UI.xml,sha256=NVUg3RiPzvUJk87fHnVya0BVdL3tECz8gg2GQZHOevs,836095
51
+ PySimultan2/resources/SIMULTAN.dll,sha256=eNB8MyMrrqNk398r2q39Y3-L5eeymN4eShFFD_OmKcA,1771520
52
+ PySimultan2/resources/SIMULTAN.xml,sha256=oRopamMm95ByupGN_8VzQmMlHA_AfFS2bFBZ1pPAlY0,1968806
53
+ PySimultan2/resources/SharpDX.D3DCompiler.dll,sha256=qyDGhqpcMo0zkNAdSdyX9sxWRxGRZq6ce4FIBXvxXSI,57856
54
+ PySimultan2/resources/SharpDX.DXGI.dll,sha256=GMTsibwN7s_JG8t-ofKaJpDpKIADw2bqAnAzdLS21zI,147968
55
+ PySimultan2/resources/SharpDX.Direct2D1.dll,sha256=HkRyV1YspAeY05q0E4pkFy3Hrrkd96fr9SzlmVnDekc,495616
56
+ PySimultan2/resources/SharpDX.Direct3D11.dll,sha256=XBwIVxhA-_S5haBjrGlXEwWWqIg5IKcXT7fFFoJt2rE,282624
57
+ PySimultan2/resources/SharpDX.Direct3D9.dll,sha256=aXAe2nQzrAAQq6QWudnCRc14aUdw1LtrdUG4O6zkHVU,338944
58
+ PySimultan2/resources/SharpDX.Mathematics.dll,sha256=ajtUzW3A6l7UwfVpZgpPacGrVHHP24QZmdSyZOHOThI,215552
59
+ PySimultan2/resources/SharpDX.dll,sha256=UY1FparshMs36D7iz1jFA6tqJf67jEi1MxY0DJZ-hL0,275968
60
+ PySimultan2/resources/Sprache.Calc.dll,sha256=QyBWSMEL5UXootOCTzYWlAkDgGcseeVgDaw_W7K32zc,22528
61
+ PySimultan2/resources/Sprache.dll,sha256=4c4dDHP9ztxaBDpgWYBUhKKkzPl5eISQimpThGZl0t8,59904
62
+ PySimultan2/resources/System.Collections.Immutable.dll,sha256=YkpsmK2tsFnupt75OgF4vW0fedXRXfvGwPKONArInxk,245920
63
+ PySimultan2/resources/System.Data.OleDb.dll,sha256=-AAzdmyo01QNgD9qnUIewEImplJFVNDGUlqE17qmRYA,124024
64
+ PySimultan2/resources/System.Net.Http.Formatting.dll,sha256=xQBIin4YpqDObdqwau_5dr8XQEq54hlxV4gBgNtUqbc,179672
65
+ PySimultan2/resources/System.Reflection.Metadata.dll,sha256=Z_vYHE6IgOvBi3DLxLhfX-v6o01lTfD0B4oW6B8IsyA,475912
66
+ PySimultan2/resources/System.Reflection.MetadataLoadContext.dll,sha256=P4PBRwAGWL27sNc754Wd28t_koJKBFYJ2FyolrD1xo0,242296
67
+ PySimultan2/resources/XAMLMarkupExtensions.dll,sha256=Ck7FAAFHqSSwMtGJebfun-88OCEplWxY2YKMwlFaF84,36864
68
+ PySimultan2/resources/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
69
+ PySimultan2/resources/assimp.dll,sha256=HwfDwXqoPDTFRyoQpA3qmgZoUdFtziJkV5fNtktEZEU,6081536
70
+ PySimultan2/resources/componentmanager.user,sha256=hrzr1US4pqkFnLHXcvPkvrgGd7QvlxaV8mhS6fuikEs,760
71
+ PySimultan2/resources/defaultsettings.xml,sha256=QCkKmhNMxwSvC-aYUUMhkCkXqRSrkuFt5s4FEI5x1wo,396
72
+ PySimultan2/resources/setup.bat,sha256=fjvvYfVM6TalS-QTSiKAbAId5nTsk8kGGo06ba-wWaY,32
73
+ pysimultan-0.6.1.dist-info/METADATA,sha256=rmVLXHOWpGN4dnbPTasxcmYddyMd2ZkmxBupk0j4aiE,6548
74
+ pysimultan-0.6.1.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
75
+ pysimultan-0.6.1.dist-info/licenses/LICENSE.txt,sha256=pmSr98k6N005KMojnZxzLGRuRlDjDx3PUrK1lFj53HA,1126
76
+ pysimultan-0.6.1.dist-info/RECORD,,