PySimultan 0.5.8__tar.gz → 0.5.9.1__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/PKG-INFO +7 -3
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/README.md +3 -0
- pysimultan-0.5.9.1/src/PySimultan2/__about__.py +1 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/__init__.py +1 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/data_model.py +40 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/files.py +84 -1
- pysimultan-0.5.9.1/tests/resources/test_file_project.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_files.py +41 -2
- pysimultan-0.5.8/src/PySimultan2/__about__.py +0 -1
- pysimultan-0.5.8/tests/resources/test_file.yml +0 -1
- pysimultan-0.5.8/tests/resources/test_file_project.simultan +0 -0
- pysimultan-0.5.8/tests/resources/test_set_dictionary.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/.gitignore +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/LICENSE.txt +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/pyproject.toml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/CHANGELOG.md +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/default_types.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/geometry/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/geometry/geometry_base.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/geometry/utils.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/multi_values.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/object_mapper.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/AssimpNet.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/AvalonDock.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/BruTile.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ClosedXML.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ComponentBuilder.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ComponentBuilder.dll.config +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ComponentBuilder.runtimeconfig.json +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ComponentBuilder.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ControlzEx.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/DocumentFormat.OpenXml.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/DotSpatial.Projections.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ExcelNumberFormat.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Fluent.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.Core.Wpf.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.SharpDX.Core.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/MathNet.Numerics.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.AspNetCore.Authorization.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Extensions.DependencyInjection.Abstractions.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Extensions.Logging.Abstractions.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Extensions.Options.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Extensions.Primitives.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.WindowsAPICodePack.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Xaml.Behaviors.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Newtonsoft.Json.Bson.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Newtonsoft.Json.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll.config +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll.config +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.Lang.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.Lang.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.Plugins.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.Plugins.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.UI.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.UI.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.D3DCompiler.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.DXGI.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.Direct2D1.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.Direct3D11.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.Direct3D9.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.Mathematics.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SharpDX.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Sprache.Calc.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Sprache.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Collections.Immutable.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Data.OleDb.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Net.Http.Formatting.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Reflection.Metadata.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Reflection.MetadataLoadContext.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/XAMLMarkupExtensions.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/assimp.dll +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/componentmanager.user +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/defaultsettings.xml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/setup.bat +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/simultan_object.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/taxonomy_maps.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/type_setter_lookup.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/utils.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_component.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_component_with_taxonomy_slot.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_referenced_component.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_taxonomies.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/change_references_example.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/empty_project.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/empty_test_excel.xlsx +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example1.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example2.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example3.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example4_reference_list.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example_extend_1.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/list_test.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example3.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example4.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example_create_typed_component.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example_create_typed_component_with_slots.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example_extend.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example_update_references.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_reference_list.yml +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/U5.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/U5_1.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/U5_orig.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/__init__.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/new_geometry_test.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/new_test_file.txt +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/new_test_file2.txt +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/test_file_load.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/test_multi_value_big_table_load.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/test_parameter_reference_project.simultan +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_calc_static_zone_temperature.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_calculate_steady_state_temperature.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_circular_references.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_create_geometry.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_directory_and_files.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_files_load.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_load_geometry.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_load_multi_values.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_new_dll.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_new_project_creation.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_numeric_map.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_parameter_reference.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_pythonnet.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_register_class.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_register_decorator.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_set_attr_property.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_set_dictionary.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_set_properties.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_taxonomie_maps.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_taxonomies.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/test_ui.py +0 -0
- {pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/ui_minimal_example.py +0 -0
@@ -1,11 +1,12 @@
|
|
1
|
-
Metadata-Version: 2.
|
1
|
+
Metadata-Version: 2.4
|
2
2
|
Name: PySimultan
|
3
|
-
Version: 0.5.
|
3
|
+
Version: 0.5.9.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
|
7
7
|
Author-email: Bühler Maximilian <maximilian.buehler@tuwien.ac.at>
|
8
|
-
License: MIT
|
8
|
+
License-Expression: MIT
|
9
|
+
License-File: LICENSE.txt
|
9
10
|
Classifier: Development Status :: 4 - Beta
|
10
11
|
Classifier: Programming Language :: Python
|
11
12
|
Classifier: Programming Language :: Python :: 3.8
|
@@ -166,6 +167,9 @@ print(instances[0].param_1)
|
|
166
167
|
|
167
168
|
# Change Log
|
168
169
|
|
170
|
+
## [0.5.8] - 2024-12-17
|
171
|
+
- Added FileInfo.from_existing_file method to create FileInfo object from existing file in ProjectUnpackFolder
|
172
|
+
|
169
173
|
## [0.5.7] - 2024-12-09
|
170
174
|
- Added support for different taxonomy for content
|
171
175
|
- Added support for numpy np.float32, np.float64 and np.int32, np.int64
|
@@ -138,6 +138,9 @@ print(instances[0].param_1)
|
|
138
138
|
|
139
139
|
# Change Log
|
140
140
|
|
141
|
+
## [0.5.8] - 2024-12-17
|
142
|
+
- Added FileInfo.from_existing_file method to create FileInfo object from existing file in ProjectUnpackFolder
|
143
|
+
|
141
144
|
## [0.5.7] - 2024-12-09
|
142
145
|
- Added support for different taxonomy for content
|
143
146
|
- Added support for numpy np.float32, np.float64 and np.int32, np.int64
|
@@ -0,0 +1 @@
|
|
1
|
+
version = '0.5.9.1'
|
@@ -532,6 +532,46 @@ class DataModel:
|
|
532
532
|
)
|
533
533
|
)
|
534
534
|
|
535
|
+
def add_resource_file(self,
|
536
|
+
filename: Union[str, FileInfo, PythonFileInfo],
|
537
|
+
target_dir: Union[ResourceDirectoryEntry, FileInfo, str] = None) -> ResourceEntry:
|
538
|
+
|
539
|
+
"""
|
540
|
+
Add a file as resource to the project which already exists in the project folder
|
541
|
+
:param filename: path to the file or FileInfo object
|
542
|
+
:param target_dir:
|
543
|
+
:return:
|
544
|
+
"""
|
545
|
+
|
546
|
+
if isinstance(filename, str):
|
547
|
+
filename = FileInfo(filename)
|
548
|
+
elif isinstance(filename, PythonFileInfo):
|
549
|
+
filename = FileInfo(filename.full_path)
|
550
|
+
|
551
|
+
if target_dir is None:
|
552
|
+
# check if file is already in project folder
|
553
|
+
|
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}')
|
556
|
+
|
557
|
+
key = self.project_data_manager.AssetManager.AddResourceEntry(filename)
|
558
|
+
return self.project_data_manager.AssetManager.GetResource(key)
|
559
|
+
|
560
|
+
else:
|
561
|
+
if isinstance(target_dir, str):
|
562
|
+
target_dir = DirectoryInfo(target_dir)
|
563
|
+
elif isinstance(target_dir, ResourceDirectoryEntry):
|
564
|
+
target_dir = DirectoryInfo(target_dir.CurrentFullPath)
|
565
|
+
elif isinstance(target_dir, FileInfo):
|
566
|
+
pass
|
567
|
+
|
568
|
+
# check if file is already in project folder
|
569
|
+
if not os.path.exists(os.path.join(target_dir.FullPath, filename.Name)):
|
570
|
+
raise FileNotFoundError(f'File {filename} not found in project folder {target_dir.FullPath}')
|
571
|
+
|
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)
|
574
|
+
|
535
575
|
def add_resource(self,
|
536
576
|
filename: Union[str, FileInfo],
|
537
577
|
target_dir: Optional[Union[DirectoryInfo, ResourceDirectoryEntry, str]] = None,
|
@@ -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
|
|
@@ -281,6 +282,20 @@ class FileInfo(object, metaclass=MetaMock):
|
|
281
282
|
file_info.write_content(content)
|
282
283
|
return file_info
|
283
284
|
|
285
|
+
@classmethod
|
286
|
+
def from_existing_file(cls,
|
287
|
+
file_path: str,
|
288
|
+
*args,
|
289
|
+
**kwargs) -> FileInfo:
|
290
|
+
|
291
|
+
data_model = kwargs.get('data_model', config.get_default_data_model())
|
292
|
+
resource = data_model.add_resource_file(file_path)
|
293
|
+
|
294
|
+
return cls(resource_entry=resource,
|
295
|
+
*args,
|
296
|
+
**kwargs)
|
297
|
+
|
298
|
+
|
284
299
|
def __init__(self, file_path=None, *args, **kwargs):
|
285
300
|
"""
|
286
301
|
Custom file info object to be used with the with statement. This object is used to open a file and close it
|
@@ -475,7 +490,10 @@ class FileInfo(object, metaclass=MetaMock):
|
|
475
490
|
:return: None
|
476
491
|
"""
|
477
492
|
if self.resource_entry is not None:
|
493
|
+
if self.resource_entry.Key in self._cls_instances:
|
494
|
+
del self._cls_instances[self.resource_entry.Key]
|
478
495
|
self.data_model.delete_resource(self.resource_entry)
|
496
|
+
|
479
497
|
os.remove(self.file_path)
|
480
498
|
|
481
499
|
def to_json(self) -> dict:
|
@@ -508,6 +526,46 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
|
|
508
526
|
def get_by_key(cls, key: int) -> Optional[DirectoryInfo]:
|
509
527
|
return cls._cls_instances.get(key, None)
|
510
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
|
+
|
511
569
|
def __init__(self,
|
512
570
|
path: Optional[str] = None,
|
513
571
|
helper_file: Optional[FileInfo] = None,
|
@@ -626,6 +684,31 @@ class DirectoryInfo(object, metaclass=DirectoryInfoMetaMock):
|
|
626
684
|
return FileInfo(resource_entry=new_resource,
|
627
685
|
data_model=self.data_model)
|
628
686
|
|
687
|
+
def add_all_contained_files(self):
|
688
|
+
for file in os.listdir(self.full_path):
|
689
|
+
full_filename = os.path.join(self.full_path, file)
|
690
|
+
if Path(full_filename).is_file():
|
691
|
+
|
692
|
+
if full_filename in (x.current_full_path for x in self.resource_entry.Children):
|
693
|
+
continue
|
694
|
+
else:
|
695
|
+
logger.info(f'Adding file: {full_filename} to resources')
|
696
|
+
FileInfo.from_existing_file(full_filename, data_model=self.data_model)
|
697
|
+
|
698
|
+
def add_all_contained_directories(self):
|
699
|
+
for file in os.listdir(self.full_path):
|
700
|
+
full_filename = os.path.join(self.full_path, file)
|
701
|
+
if Path(full_filename).is_dir():
|
702
|
+
if full_filename in (x.current_full_path for x in self.resource_entry.Children):
|
703
|
+
continue
|
704
|
+
else:
|
705
|
+
logger.info(f'Adding directory: {full_filename} to resources')
|
706
|
+
DirectoryInfo.from_existing_directory(full_filename, data_model=self.data_model)
|
707
|
+
|
708
|
+
for directory in self.sub_directories:
|
709
|
+
directory.add_all_contained_files()
|
710
|
+
directory.add_all_contained_directories()
|
711
|
+
|
629
712
|
def add_tag(self, tag: SimTaxonomyEntry) -> None:
|
630
713
|
add_tag_to_resource(self.resource_entry, tag)
|
631
714
|
|
Binary file
|
@@ -1,4 +1,3 @@
|
|
1
|
-
import io
|
2
1
|
import os
|
3
2
|
|
4
3
|
from PySimultan2.data_model import DataModel
|
@@ -97,12 +96,52 @@ def test_set_file():
|
|
97
96
|
test_component = mapped_test_component_cls(name='test_component',
|
98
97
|
file_value_2=file_info)
|
99
98
|
|
99
|
+
return mapper
|
100
|
+
|
101
|
+
|
102
|
+
def test_add_resource_in_directory(mapper):
|
103
|
+
|
104
|
+
file_path = os.path.join(str(data_model.project.ProjectUnpackFolder), 'already_exising.txt')
|
105
|
+
|
106
|
+
with open(file_path, 'w') as f:
|
107
|
+
f.write('This is the content of the already existing file.')
|
108
|
+
|
109
|
+
file_info = FileInfo(file_path=file_path)
|
110
|
+
mapped_test_component_cls = mapper.get_mapped_class('TestComponent')
|
111
|
+
test_component = mapped_test_component_cls(name='test_component 2',
|
112
|
+
file_value_2=file_info)
|
113
|
+
|
114
|
+
def test_add_resource_file():
|
115
|
+
file_path = os.path.join(str(data_model.project.ProjectUnpackFolder), 'already_exising_2.txt')
|
116
|
+
|
117
|
+
with open(file_path, 'w') as f:
|
118
|
+
f.write('This is the content of the already existing file 2.')
|
119
|
+
|
120
|
+
file = data_model.add_resource_file(file_path)
|
121
|
+
print(file)
|
122
|
+
|
123
|
+
file_path = os.path.join(str(data_model.project.ProjectUnpackFolder), 'already_exising_3.txt')
|
124
|
+
|
125
|
+
with open(file_path, 'w') as f:
|
126
|
+
f.write('This is the content of the already existing file 3.')
|
127
|
+
|
128
|
+
file_info = FileInfo.from_existing_file(file_path=file_path,
|
129
|
+
data_model=data_model)
|
130
|
+
|
131
|
+
mapped_test_component_cls = mapper.get_mapped_class('TestComponent')
|
132
|
+
test_component3 = mapped_test_component_cls(name='test_component 3',
|
133
|
+
file_value_2=file_info)
|
134
|
+
|
135
|
+
|
136
|
+
|
100
137
|
|
101
138
|
if __name__ == '__main__':
|
102
139
|
new_resource = test_create_resource()
|
103
140
|
test_create_resource_from_string()
|
104
141
|
test_add_resource_to_component(new_resource)
|
105
|
-
test_set_file()
|
142
|
+
mapper = test_set_file()
|
143
|
+
test_add_resource_in_directory(mapper)
|
144
|
+
test_add_resource_file()
|
106
145
|
data_model.save()
|
107
146
|
|
108
147
|
data_model.cleanup()
|
@@ -1 +0,0 @@
|
|
1
|
-
version = '0.5.8'
|
@@ -1 +0,0 @@
|
|
1
|
-
ardgadfb
|
Binary file
|
Binary file
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/ComponentBuilder.dll.config
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/DocumentFormat.OpenXml.dll
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/DotSpatial.Projections.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/HelixToolkit.SharpDX.Core.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Extensions.Options.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.WindowsAPICodePack.dll
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/Microsoft.Xaml.Behaviors.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Collections.Immutable.dll
RENAMED
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Net.Http.Formatting.dll
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/src/PySimultan2/resources/System.Reflection.Metadata.dll
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_component_with_taxonomy_slot.py
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/create_referenced_component.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/empty_project.simultan
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/empty_test_excel.xlsx
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/example_extend_1.simultan
RENAMED
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example3.yml
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example4.yml
RENAMED
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_example_extend.yml
RENAMED
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/readme_examples/resources/template_reference_list.yml
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/test_multi_value_big_table_load.simultan
RENAMED
File without changes
|
{pysimultan-0.5.8 → pysimultan-0.5.9.1}/tests/resources/test_parameter_reference_project.simultan
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|