PySimultan 0.5.9__py3-none-any.whl → 0.5.9.3__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- PySimultan2/__about__.py +1 -1
- PySimultan2/__init__.py +1 -0
- PySimultan2/data_model.py +7 -21
- PySimultan2/files.py +105 -4
- {pysimultan-0.5.9.dist-info → pysimultan-0.5.9.3.dist-info}/METADATA +1 -1
- {pysimultan-0.5.9.dist-info → pysimultan-0.5.9.3.dist-info}/RECORD +8 -8
- {pysimultan-0.5.9.dist-info → pysimultan-0.5.9.3.dist-info}/WHEEL +0 -0
- {pysimultan-0.5.9.dist-info → pysimultan-0.5.9.3.dist-info}/licenses/LICENSE.txt +0 -0
PySimultan2/__about__.py
CHANGED
@@ -1 +1 @@
|
|
1
|
-
version = '0.5.9'
|
1
|
+
version = '0.5.9.3'
|
PySimultan2/__init__.py
CHANGED
PySimultan2/data_model.py
CHANGED
@@ -538,7 +538,7 @@ class DataModel:
|
|
538
538
|
|
539
539
|
"""
|
540
540
|
Add a file as resource to the project which already exists in the project folder
|
541
|
-
:param filename:
|
541
|
+
:param filename: path to the file or FileInfo object
|
542
542
|
:param target_dir:
|
543
543
|
:return:
|
544
544
|
"""
|
@@ -550,20 +550,12 @@ class DataModel:
|
|
550
550
|
|
551
551
|
if target_dir is None:
|
552
552
|
# check if file is already in project folder
|
553
|
-
if not os.path.exists(os.path.join(str(self.project.ProjectUnpackFolder), filename.Name)):
|
554
|
-
raise FileNotFoundError(f'File {filename} not found in project folder {self.project.ProjectUnpackFolder}')
|
555
|
-
|
556
|
-
self.project.AddResourceFile(FileInfo(str(filename)),
|
557
|
-
self.project_data_manager)
|
558
553
|
|
559
|
-
|
554
|
+
if not filename.FullName.startswith(str(self.project.ProjectUnpackFolder)) and not os.path.exists(os.path.join(str(self.project.ProjectUnpackFolder), filename.Name)):
|
555
|
+
raise FileNotFoundError(f'File {filename} not found in project folder {self.project.ProjectUnpackFolder}')
|
560
556
|
|
561
|
-
|
562
|
-
|
563
|
-
x for x in self.project_data_manager.AssetManager.Resources if x.CurrentFullPath == full_filename
|
564
|
-
)
|
565
|
-
, None
|
566
|
-
)
|
557
|
+
key = self.project_data_manager.AssetManager.AddResourceEntry(filename)
|
558
|
+
return self.project_data_manager.AssetManager.GetResource(key)
|
567
559
|
|
568
560
|
else:
|
569
561
|
if isinstance(target_dir, str):
|
@@ -577,14 +569,8 @@ class DataModel:
|
|
577
569
|
if not os.path.exists(os.path.join(target_dir.FullPath, filename.Name)):
|
578
570
|
raise FileNotFoundError(f'File {filename} not found in project folder {target_dir.FullPath}')
|
579
571
|
|
580
|
-
self.
|
581
|
-
|
582
|
-
self.project_data_manager)
|
583
|
-
|
584
|
-
# get added resource
|
585
|
-
return next((x for x in self.project_data_manager.AssetManager.Resources if
|
586
|
-
x.CurrentFullPath == os.path.join(target_dir.FullPath, filename.Name)), None)
|
587
|
-
|
572
|
+
key = self.project_data_manager.AssetManager.AddResourceEntry(os.path.join(target_dir.FullPath, filename.Name))
|
573
|
+
return self.project_data_manager.AssetManager.GetResource(key)
|
588
574
|
|
589
575
|
def add_resource(self,
|
590
576
|
filename: Union[str, FileInfo],
|
PySimultan2/files.py
CHANGED
@@ -12,13 +12,14 @@ import tempfile
|
|
12
12
|
from typing import List, Union, Optional
|
13
13
|
import shutil
|
14
14
|
import zipfile
|
15
|
+
from pathlib import Path
|
15
16
|
# from System.IO import FileInfo # public FileInfo (string fileName);
|
16
17
|
|
17
18
|
from SIMULTAN.Data.Assets import ResourceEntry, ResourceFileEntry, ContainedResourceFileEntry, Asset, ResourceDirectoryEntry
|
18
19
|
from SIMULTAN.Data.Taxonomy import SimTaxonomyEntry, SimTaxonomyEntryReference, SimTaxonomy
|
19
20
|
from SIMULTAN.Data.Components import SimComponent, ComponentMapping
|
20
21
|
|
21
|
-
from System.IO import DirectoryInfo
|
22
|
+
from System.IO import DirectoryInfo as SystemDirectoryInfo
|
22
23
|
|
23
24
|
# from .config import default_data_model
|
24
25
|
|
@@ -291,7 +292,6 @@ class FileInfo(object, metaclass=MetaMock):
|
|
291
292
|
resource = data_model.add_resource_file(file_path)
|
292
293
|
|
293
294
|
return cls(resource_entry=resource,
|
294
|
-
data_model=data_model,
|
295
295
|
*args,
|
296
296
|
**kwargs)
|
297
297
|
|
@@ -526,6 +526,46 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
|
|
526
526
|
def get_by_key(cls, key: int) -> Optional[DirectoryInfo]:
|
527
527
|
return cls._cls_instances.get(key, None)
|
528
528
|
|
529
|
+
@classmethod
|
530
|
+
def from_existing_directory(cls,
|
531
|
+
directory_path: str,
|
532
|
+
add_files: bool = True,
|
533
|
+
add_sub_directories: bool = True,
|
534
|
+
*args,
|
535
|
+
**kwargs) -> DirectoryInfo:
|
536
|
+
|
537
|
+
data_model = kwargs.get('data_model', config.get_default_data_model())
|
538
|
+
|
539
|
+
if not directory_path.startswith(str(data_model.project.ProjectUnpackFolder)):
|
540
|
+
directory_path = os.path.join(str(data_model.project.ProjectUnpackFolder), directory_path)
|
541
|
+
|
542
|
+
res = data_model.project_data_manager.AssetManager.CreateResourceDirIn(os.path.basename(directory_path),
|
543
|
+
SystemDirectoryInfo(os.path.dirname(directory_path)),
|
544
|
+
'')
|
545
|
+
|
546
|
+
resource = data_model.project_data_manager.AssetManager.GetResource(res.Item1)
|
547
|
+
|
548
|
+
directory_info = cls(resource_entry=resource,
|
549
|
+
*args,
|
550
|
+
**kwargs)
|
551
|
+
|
552
|
+
|
553
|
+
if add_files:
|
554
|
+
directory_info.add_all_contained_files()
|
555
|
+
|
556
|
+
# for file in os.listdir(directory_path):
|
557
|
+
# file_path = os.path.join(directory_path, file)
|
558
|
+
# data_model.add_resource_file(file_path, target_dir=resource)
|
559
|
+
|
560
|
+
if add_sub_directories:
|
561
|
+
directory_info.add_all_contained_directories()
|
562
|
+
|
563
|
+
# for sub_dir in os.listdir(directory_path):
|
564
|
+
# sub_dir_path = os.path.join(directory_path, sub_dir)
|
565
|
+
# data_model.add_resource_directory(sub_dir_path, parent_directory=resource)
|
566
|
+
|
567
|
+
return directory_info
|
568
|
+
|
529
569
|
def __init__(self,
|
530
570
|
path: Optional[str] = None,
|
531
571
|
helper_file: Optional[FileInfo] = None,
|
@@ -626,14 +666,50 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
|
|
626
666
|
else:
|
627
667
|
return None
|
628
668
|
|
629
|
-
def add_sub_directory(self,
|
630
|
-
|
669
|
+
def add_sub_directory(self, dirname: str) -> DirectoryInfo:
|
670
|
+
|
671
|
+
existing = next((x for x in self.sub_directories if x.resource_entry.current_relative_path == dirname), None)
|
672
|
+
if existing is not None:
|
673
|
+
return existing
|
674
|
+
|
675
|
+
return DirectoryInfo(path=os.path.join(self.resource_entry.current_relative_path, dirname),
|
631
676
|
data_model=self.data_model)
|
632
677
|
|
678
|
+
def get_sub_directory(self,
|
679
|
+
dirname: str,
|
680
|
+
create=False) -> Optional[DirectoryInfo]:
|
681
|
+
"""
|
682
|
+
Get a sub directory by name.
|
683
|
+
:param dirname: directory name, relative to self.relative_path
|
684
|
+
:param create:
|
685
|
+
:return:
|
686
|
+
"""
|
687
|
+
|
688
|
+
logger.debug(f'Getting sub directory in {self.relative_path}: {dirname}')
|
689
|
+
res = next((x for x in self.sub_directories if x.resource_entry.Name == dirname), None)
|
690
|
+
if not res and create:
|
691
|
+
logger.debug(f'Creating sub directory in {self.relative_path}: {dirname}')
|
692
|
+
res = self.add_sub_directory(dirname)
|
693
|
+
|
694
|
+
return res
|
695
|
+
|
696
|
+
def get_file(self, filename: str) -> Optional[FileInfo]:
|
697
|
+
resource = next((x for x in self.files if x.resource_entry.Name == filename), None)
|
698
|
+
if resource is not None:
|
699
|
+
return FileInfo(resource_entry=entry,
|
700
|
+
data_model=self.data_model)
|
701
|
+
else:
|
702
|
+
return None
|
703
|
+
|
633
704
|
def add_file(self,
|
634
705
|
filename: str,
|
635
706
|
content: Optional[str] = None) -> FileInfo:
|
636
707
|
|
708
|
+
if self.resource_entry.Children:
|
709
|
+
file = self.get_file(filename)
|
710
|
+
if file is not None:
|
711
|
+
return file
|
712
|
+
|
637
713
|
if content is not None:
|
638
714
|
return FileInfo.from_string(filename=filename,
|
639
715
|
content=content,
|
@@ -644,6 +720,31 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
|
|
644
720
|
return FileInfo(resource_entry=new_resource,
|
645
721
|
data_model=self.data_model)
|
646
722
|
|
723
|
+
def add_all_contained_files(self):
|
724
|
+
for file in os.listdir(self.full_path):
|
725
|
+
full_filename = os.path.join(self.full_path, file)
|
726
|
+
if Path(full_filename).is_file():
|
727
|
+
|
728
|
+
if full_filename in (x.current_full_path for x in self.resource_entry.Children):
|
729
|
+
continue
|
730
|
+
else:
|
731
|
+
logger.info(f'Adding file: {full_filename} to resources')
|
732
|
+
FileInfo.from_existing_file(full_filename, data_model=self.data_model)
|
733
|
+
|
734
|
+
def add_all_contained_directories(self):
|
735
|
+
for file in os.listdir(self.full_path):
|
736
|
+
full_filename = os.path.join(self.full_path, file)
|
737
|
+
if Path(full_filename).is_dir():
|
738
|
+
if full_filename in (x.current_full_path for x in self.resource_entry.Children):
|
739
|
+
continue
|
740
|
+
else:
|
741
|
+
logger.info(f'Adding directory: {full_filename} to resources')
|
742
|
+
DirectoryInfo.from_existing_directory(full_filename, data_model=self.data_model)
|
743
|
+
|
744
|
+
for directory in self.sub_directories:
|
745
|
+
directory.add_all_contained_files()
|
746
|
+
directory.add_all_contained_directories()
|
747
|
+
|
647
748
|
def add_tag(self, tag: SimTaxonomyEntry) -> None:
|
648
749
|
add_tag_to_resource(self.resource_entry, tag)
|
649
750
|
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: PySimultan
|
3
|
-
Version: 0.5.9
|
3
|
+
Version: 0.5.9.3
|
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
|
@@ -1,9 +1,9 @@
|
|
1
1
|
PySimultan2/CHANGELOG.md,sha256=BBfCqgFQeigrlRQdHAksDz70-0fLKjzWkHbfFjJ2eDg,361
|
2
|
-
PySimultan2/__about__.py,sha256=
|
3
|
-
PySimultan2/__init__.py,sha256=
|
4
|
-
PySimultan2/data_model.py,sha256=
|
2
|
+
PySimultan2/__about__.py,sha256=07EsoeVghQ4VppBgKjlpoSsh-r0rQEwLSOZe57CHEdQ,21
|
3
|
+
PySimultan2/__init__.py,sha256=42YM_zQUXdEjbjmgBI0nWJWsr_G6zNe7TxfFmS37mJk,3275
|
4
|
+
PySimultan2/data_model.py,sha256=UcscVLbBaEu9UhV2iaGJnrqX51G5PyEQuoXrz41Hq9g,36126
|
5
5
|
PySimultan2/default_types.py,sha256=K-Eka5BCKk8DT3HU5761Ym_-ZFmu1_Dro0zW0LVGoHA,27157
|
6
|
-
PySimultan2/files.py,sha256=
|
6
|
+
PySimultan2/files.py,sha256=Cn8Oh9yM8q-0p-eNIUp_w53mqDCjxkUccfQQeN8DDqY,27420
|
7
7
|
PySimultan2/multi_values.py,sha256=ZFXlTLuZo32x7_7diYAp2XEjp5uwgHLgNOzN7v74-5I,13650
|
8
8
|
PySimultan2/object_mapper.py,sha256=_SQye38NmIr4m_-X9CuvUJnVDBmjmUDdPH2bnaxpzKY,18546
|
9
9
|
PySimultan2/simultan_object.py,sha256=akaSUZZWIVfwx1wT5EdOgRR2UeShUthX-LE2Uk6w8CQ,19058
|
@@ -75,7 +75,7 @@ PySimultan2/resources/assimp.dll,sha256=HwfDwXqoPDTFRyoQpA3qmgZoUdFtziJkV5fNtktE
|
|
75
75
|
PySimultan2/resources/componentmanager.user,sha256=hrzr1US4pqkFnLHXcvPkvrgGd7QvlxaV8mhS6fuikEs,760
|
76
76
|
PySimultan2/resources/defaultsettings.xml,sha256=s6Tk1tubLz5UYqXZWpD42EDHzedemRY1nEneoIVcUfg,392
|
77
77
|
PySimultan2/resources/setup.bat,sha256=fjvvYfVM6TalS-QTSiKAbAId5nTsk8kGGo06ba-wWaY,32
|
78
|
-
pysimultan-0.5.9.dist-info/METADATA,sha256=
|
79
|
-
pysimultan-0.5.9.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
80
|
-
pysimultan-0.5.9.dist-info/licenses/LICENSE.txt,sha256=pmSr98k6N005KMojnZxzLGRuRlDjDx3PUrK1lFj53HA,1126
|
81
|
-
pysimultan-0.5.9.dist-info/RECORD,,
|
78
|
+
pysimultan-0.5.9.3.dist-info/METADATA,sha256=RIR6ykk8GjDPeTLnih0mvwWHP-pWHYR7XK55dakOJqY,6138
|
79
|
+
pysimultan-0.5.9.3.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
80
|
+
pysimultan-0.5.9.3.dist-info/licenses/LICENSE.txt,sha256=pmSr98k6N005KMojnZxzLGRuRlDjDx3PUrK1lFj53HA,1126
|
81
|
+
pysimultan-0.5.9.3.dist-info/RECORD,,
|
File without changes
|
File without changes
|