xcoll 0.5.12__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.
Potentially problematic release.
This version of xcoll might be problematic. Click here for more details.
- xcoll/__init__.py +5 -18
- xcoll/__init__.py.orig +26 -0
- xcoll/beam_elements/__init__.py +1 -0
- xcoll/beam_elements/absorber.py +12 -2
- xcoll/beam_elements/base.py +162 -62
- xcoll/beam_elements/blowup.py +1 -0
- xcoll/beam_elements/elements_src/black_absorber.h +57 -58
- xcoll/beam_elements/elements_src/black_crystal.h +49 -50
- xcoll/beam_elements/elements_src/everest_block.h +21 -11
- xcoll/beam_elements/elements_src/everest_collimator.h +100 -91
- xcoll/beam_elements/elements_src/everest_crystal.h +145 -140
- xcoll/beam_elements/elements_src/transparent_collimator.h +126 -0
- xcoll/beam_elements/elements_src/transparent_crystal.h +118 -0
- xcoll/beam_elements/everest.py +16 -5
- xcoll/beam_elements/monitor.py +1 -0
- xcoll/beam_elements/transparent.py +83 -0
- xcoll/colldb.py +15 -6
- xcoll/general.py +1 -1
- xcoll/general.py.orig +20 -0
- xcoll/headers/particle_states.py +51 -0
- xcoll/initial_distribution.py +121 -91
- xcoll/initial_distribution.py.orig +256 -0
- xcoll/interaction_record/interaction_record.py +2 -1
- xcoll/interaction_record/interaction_types.py +2 -2
- xcoll/line_tools.py +163 -73
- xcoll/lossmap.py +519 -127
- xcoll/plot.py +109 -0
- xcoll/rf_sweep.py +6 -0
- xcoll/scattering_routines/engine.py +414 -217
- xcoll/scattering_routines/environment.py +297 -0
- xcoll/scattering_routines/everest/amorphous.h +95 -71
- xcoll/scattering_routines/everest/{channeling.h → channelling.h} +121 -112
- xcoll/scattering_routines/everest/constants.h +1 -1
- xcoll/scattering_routines/everest/crystal_parameters.h +9 -9
- xcoll/scattering_routines/everest/everest.h +8 -3
- xcoll/scattering_routines/everest/everest.py +2 -1
- xcoll/scattering_routines/everest/ionisation_loss.h +141 -0
- xcoll/scattering_routines/everest/jaw.h +19 -24
- xcoll/scattering_routines/everest/materials.py +2 -0
- xcoll/scattering_routines/everest/multiple_coulomb_scattering.h +2 -2
- xcoll/scattering_routines/everest/nuclear_interaction.h +35 -19
- xcoll/scattering_routines/everest/properties.h +3 -72
- xcoll/xaux.py +65 -109
- {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/METADATA +5 -5
- xcoll-0.6.1.dist-info/RECORD +138 -0
- xcoll/_manager.py +0 -22
- xcoll/headers/particle_states.h +0 -25
- xcoll/install.py +0 -35
- xcoll/scattering_routines/geant4/collimasim/.git +0 -1
- xcoll/scattering_routines/geant4/collimasim/.gitignore +0 -12
- xcoll/scattering_routines/geant4/collimasim/.gitmodules +0 -3
- xcoll/scattering_routines/geant4/collimasim/CMakeLists.txt +0 -26
- xcoll/scattering_routines/geant4/collimasim/README.md +0 -21
- xcoll/scattering_routines/geant4/collimasim/docs/Makefile +0 -20
- xcoll/scattering_routines/geant4/collimasim/docs/make.bat +0 -35
- xcoll/scattering_routines/geant4/collimasim/docs/source/collimasim.rst +0 -10
- xcoll/scattering_routines/geant4/collimasim/docs/source/conf.py +0 -59
- xcoll/scattering_routines/geant4/collimasim/docs/source/index.rst +0 -26
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.appveyor.yml +0 -37
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-format +0 -19
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-tidy +0 -65
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.cmake-format.yaml +0 -73
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.git +0 -1
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CODEOWNERS +0 -9
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CONTRIBUTING.md +0 -386
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/bug-report.yml +0 -45
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/config.yml +0 -8
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/dependabot.yml +0 -16
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler.yml +0 -8
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler_merged.yml +0 -3
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/pull_request_template.md +0 -19
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/ci.yml +0 -969
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/configure.yml +0 -84
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/format.yml +0 -48
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/labeler.yml +0 -16
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/pip.yml +0 -103
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.gitignore +0 -45
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.pre-commit-config.yaml +0 -151
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.readthedocs.yml +0 -3
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/CMakeLists.txt +0 -297
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/LICENSE +0 -29
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/MANIFEST.in +0 -6
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/README.rst +0 -180
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Doxyfile +0 -23
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Makefile +0 -192
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/_static/theme_overrides.css +0 -11
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/chrono.rst +0 -81
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/custom.rst +0 -93
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/eigen.rst +0 -310
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/functional.rst +0 -109
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/index.rst +0 -43
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/overview.rst +0 -171
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/stl.rst +0 -251
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/strings.rst +0 -305
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/classes.rst +0 -1297
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/embedding.rst +0 -262
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/exceptions.rst +0 -396
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/functions.rst +0 -568
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/misc.rst +0 -337
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/index.rst +0 -13
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/numpy.rst +0 -463
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/object.rst +0 -286
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/utilities.rst +0 -155
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/smart_ptrs.rst +0 -174
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/basics.rst +0 -308
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.py +0 -91
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.rst +0 -95
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/changelog.rst +0 -2050
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/classes.rst +0 -542
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/cmake/index.rst +0 -8
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/compiling.rst +0 -648
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/conf.py +0 -381
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/faq.rst +0 -343
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/index.rst +0 -48
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/installing.rst +0 -105
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/limitations.rst +0 -72
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11-logo.png +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.png +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.svg +0 -427
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.png +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.svg +0 -427
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/reference.rst +0 -130
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/release.rst +0 -96
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/requirements.txt +0 -8
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/upgrade.rst +0 -548
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/attr.h +0 -605
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/buffer_info.h +0 -144
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/cast.h +0 -1432
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/chrono.h +0 -213
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/common.h +0 -2
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/complex.h +0 -65
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/class.h +0 -709
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/common.h +0 -1021
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/descr.h +0 -104
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/init.h +0 -346
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/internals.h +0 -467
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/type_caster_base.h +0 -978
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/typeid.h +0 -55
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eigen.h +0 -606
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/embed.h +0 -284
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eval.h +0 -163
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/functional.h +0 -121
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/gil.h +0 -193
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/iostream.h +0 -275
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/numpy.h +0 -1741
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/operators.h +0 -163
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/options.h +0 -65
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pybind11.h +0 -2497
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pytypes.h +0 -1879
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl/filesystem.h +0 -103
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl.h +0 -375
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl_bind.h +0 -747
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/noxfile.py +0 -88
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__init__.py +0 -11
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__main__.py +0 -52
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.py +0 -12
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.pyi +0 -6
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/commands.py +0 -21
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/py.typed +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.py +0 -482
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.pyi +0 -63
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pyproject.toml +0 -41
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.cfg +0 -56
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.py +0 -155
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/CMakeLists.txt +0 -503
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/conftest.py +0 -208
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/constructor_stats.h +0 -275
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/cross_module_gil_utils.cpp +0 -73
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/env.py +0 -33
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/pytest.ini +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/test_files.py +0 -279
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/pytest.ini +0 -0
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/test_setuphelper.py +0 -143
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/local_bindings.h +0 -85
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/object.h +0 -179
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_cross_module_tests.cpp +0 -151
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.cpp +0 -91
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.h +0 -85
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pytest.ini +0 -19
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/requirements.txt +0 -12
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.cpp +0 -26
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.py +0 -25
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.cpp +0 -216
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.py +0 -163
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.cpp +0 -286
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.py +0 -536
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.cpp +0 -107
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.py +0 -248
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.cpp +0 -227
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.py +0 -202
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.cpp +0 -84
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.py +0 -210
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.cpp +0 -550
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.py +0 -473
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/CMakeLists.txt +0 -84
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/embed.cpp +0 -21
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt +0 -28
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt +0 -39
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt +0 -46
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/main.cpp +0 -6
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt +0 -41
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt +0 -35
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt +0 -41
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/test.py +0 -10
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.cpp +0 -165
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.py +0 -53
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.cpp +0 -238
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.py +0 -126
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.cpp +0 -141
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.py +0 -117
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.cpp +0 -41
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.py +0 -50
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.cpp +0 -69
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.py +0 -42
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.cpp +0 -348
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.py +0 -771
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/CMakeLists.txt +0 -47
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/catch.cpp +0 -22
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/external_module.cpp +0 -23
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.cpp +0 -326
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.py +0 -15
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.cpp +0 -148
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.py +0 -272
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.cpp +0 -119
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.py +0 -51
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval_call.py +0 -5
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.cpp +0 -285
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.h +0 -12
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.py +0 -265
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.cpp +0 -397
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.py +0 -520
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.cpp +0 -49
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.py +0 -94
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.cpp +0 -125
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.py +0 -331
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.cpp +0 -153
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.py +0 -284
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.cpp +0 -107
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.py +0 -257
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.cpp +0 -412
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.py +0 -517
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.cpp +0 -102
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.py +0 -92
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.cpp +0 -233
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.py +0 -360
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.cpp +0 -472
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.py +0 -593
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.cpp +0 -524
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.py +0 -441
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.cpp +0 -103
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.py +0 -267
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.cpp +0 -73
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.py +0 -59
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.cpp +0 -235
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.py +0 -146
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.cpp +0 -189
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.py +0 -82
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.cpp +0 -560
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.py +0 -651
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.cpp +0 -500
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.py +0 -253
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.cpp +0 -452
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.py +0 -318
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.cpp +0 -342
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.py +0 -291
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.cpp +0 -131
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.py +0 -318
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.cpp +0 -144
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.py +0 -29
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.cpp +0 -66
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.py +0 -44
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.cpp +0 -22
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.py +0 -9
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.cpp +0 -510
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.py +0 -408
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-numpy-scipy.supp +0 -140
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-python.supp +0 -117
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindCatch.cmake +0 -70
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindEigen3.cmake +0 -86
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindPythonLibsNew.cmake +0 -257
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/check-style.sh +0 -44
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/cmake_uninstall.cmake.in +0 -23
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/libsize.py +0 -39
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/make_changelog.py +0 -64
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Common.cmake +0 -402
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Config.cmake.in +0 -233
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11NewTools.cmake +0 -276
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Tools.cmake +0 -214
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pyproject.toml +0 -3
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_global.py.in +0 -65
- xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_main.py.in +0 -41
- xcoll/scattering_routines/geant4/collimasim/pyproject.toml +0 -8
- xcoll/scattering_routines/geant4/collimasim/setup.py +0 -144
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.cpp +0 -403
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.hh +0 -100
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.cpp +0 -763
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.hh +0 -118
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/__init__.py +0 -8
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/bindings.cpp +0 -63
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/pyCollimatorPass.py +0 -142
- xcoll/scattering_routines/geant4/collimasim/src/collimasim/xtrack_collimator.py +0 -556
- xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/PKG-INFO +0 -6
- xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/SOURCES.txt +0 -24
- xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/dependency_links.txt +0 -1
- xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/not-zip-safe +0 -1
- xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/top_level.txt +0 -1
- xcoll/scattering_routines/geant4/collimasim/tests/README.md +0 -25
- xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_forions.dat +0 -25
- xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_new_example.dat +0 -18
- xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_old_example.dat +0 -68
- xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_testing.dat +0 -15
- xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_yaml_example.yaml +0 -110
- xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps.dat +0 -7
- xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps_pyat_test.dat +0 -3
- xcoll/scattering_routines/geant4/collimasim/tests/resources/collonly_twiss_file_example.tfs +0 -54
- xcoll/scattering_routines/geant4/collimasim/tests/resources/settings.gmad +0 -3
- xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_black_absorber.gmad +0 -3
- xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_ions.gmad +0 -5
- xcoll/scattering_routines/geant4/collimasim/tests/resources/twiss_file_testing.tfs +0 -51
- xcoll/scattering_routines/geant4/collimasim/tests/test_pyat.py +0 -65
- xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_passmethod.py +0 -59
- xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_tracking.py +0 -102
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack.py +0 -75
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_angle.py +0 -74
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_colldb_load.py +0 -84
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction.py +0 -159
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction_ion.py +0 -99
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_ions.py +0 -78
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_lost_energy.py +0 -88
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tilt.py +0 -80
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking.py +0 -97
- xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking_ions.py +0 -96
- xcoll-0.5.12.dist-info/RECORD +0 -415
- {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/LICENSE +0 -0
- {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/NOTICE +0 -0
- {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/WHEEL +0 -0
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
cmake_minimum_required(VERSION 3.4)
|
|
2
|
-
|
|
3
|
-
# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with
|
|
4
|
-
# some versions of VS that have a patched CMake 3.11. This forces us to emulate
|
|
5
|
-
# the behavior using the following workaround:
|
|
6
|
-
if(${CMAKE_VERSION} VERSION_LESS 3.18)
|
|
7
|
-
cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION})
|
|
8
|
-
else()
|
|
9
|
-
cmake_policy(VERSION 3.18)
|
|
10
|
-
endif()
|
|
11
|
-
|
|
12
|
-
project(test_subdirectory_embed CXX)
|
|
13
|
-
|
|
14
|
-
set(PYBIND11_INSTALL
|
|
15
|
-
ON
|
|
16
|
-
CACHE BOOL "")
|
|
17
|
-
set(PYBIND11_EXPORT_NAME test_export)
|
|
18
|
-
|
|
19
|
-
add_subdirectory("${pybind11_SOURCE_DIR}" pybind11)
|
|
20
|
-
|
|
21
|
-
# Test basic target functionality
|
|
22
|
-
add_executable(test_subdirectory_embed ../embed.cpp)
|
|
23
|
-
target_link_libraries(test_subdirectory_embed PRIVATE pybind11::embed)
|
|
24
|
-
set_target_properties(test_subdirectory_embed PROPERTIES OUTPUT_NAME test_cmake_build)
|
|
25
|
-
|
|
26
|
-
add_custom_target(
|
|
27
|
-
check_subdirectory_embed
|
|
28
|
-
$<TARGET_FILE:test_subdirectory_embed> "${PROJECT_SOURCE_DIR}/../test.py"
|
|
29
|
-
DEPENDS test_subdirectory_embed)
|
|
30
|
-
|
|
31
|
-
# Test custom export group -- PYBIND11_EXPORT_NAME
|
|
32
|
-
add_library(test_embed_lib ../embed.cpp)
|
|
33
|
-
target_link_libraries(test_embed_lib PRIVATE pybind11::embed)
|
|
34
|
-
|
|
35
|
-
install(
|
|
36
|
-
TARGETS test_embed_lib
|
|
37
|
-
EXPORT test_export
|
|
38
|
-
ARCHIVE DESTINATION bin
|
|
39
|
-
LIBRARY DESTINATION lib
|
|
40
|
-
RUNTIME DESTINATION lib)
|
|
41
|
-
install(EXPORT test_export DESTINATION lib/cmake/test_export/test_export-Targets.cmake)
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
cmake_minimum_required(VERSION 3.4)
|
|
2
|
-
|
|
3
|
-
# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with
|
|
4
|
-
# some versions of VS that have a patched CMake 3.11. This forces us to emulate
|
|
5
|
-
# the behavior using the following workaround:
|
|
6
|
-
if(${CMAKE_VERSION} VERSION_LESS 3.18)
|
|
7
|
-
cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION})
|
|
8
|
-
else()
|
|
9
|
-
cmake_policy(VERSION 3.18)
|
|
10
|
-
endif()
|
|
11
|
-
|
|
12
|
-
project(test_subdirectory_function CXX)
|
|
13
|
-
|
|
14
|
-
add_subdirectory("${pybind11_SOURCE_DIR}" pybind11)
|
|
15
|
-
pybind11_add_module(test_subdirectory_function ../main.cpp)
|
|
16
|
-
set_target_properties(test_subdirectory_function PROPERTIES OUTPUT_NAME test_cmake_build)
|
|
17
|
-
|
|
18
|
-
if(DEFINED Python_EXECUTABLE)
|
|
19
|
-
set(_Python_EXECUTABLE "${Python_EXECUTABLE}")
|
|
20
|
-
elseif(DEFINED PYTHON_EXECUTABLE)
|
|
21
|
-
set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}")
|
|
22
|
-
else()
|
|
23
|
-
message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)")
|
|
24
|
-
endif()
|
|
25
|
-
|
|
26
|
-
add_custom_target(
|
|
27
|
-
check_subdirectory_function
|
|
28
|
-
${CMAKE_COMMAND}
|
|
29
|
-
-E
|
|
30
|
-
env
|
|
31
|
-
PYTHONPATH=$<TARGET_FILE_DIR:test_subdirectory_function>
|
|
32
|
-
${_Python_EXECUTABLE}
|
|
33
|
-
${PROJECT_SOURCE_DIR}/../test.py
|
|
34
|
-
${PROJECT_NAME}
|
|
35
|
-
DEPENDS test_subdirectory_function)
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
cmake_minimum_required(VERSION 3.4)
|
|
2
|
-
|
|
3
|
-
# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with
|
|
4
|
-
# some versions of VS that have a patched CMake 3.11. This forces us to emulate
|
|
5
|
-
# the behavior using the following workaround:
|
|
6
|
-
if(${CMAKE_VERSION} VERSION_LESS 3.18)
|
|
7
|
-
cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION})
|
|
8
|
-
else()
|
|
9
|
-
cmake_policy(VERSION 3.18)
|
|
10
|
-
endif()
|
|
11
|
-
|
|
12
|
-
project(test_subdirectory_target CXX)
|
|
13
|
-
|
|
14
|
-
add_subdirectory("${pybind11_SOURCE_DIR}" pybind11)
|
|
15
|
-
|
|
16
|
-
add_library(test_subdirectory_target MODULE ../main.cpp)
|
|
17
|
-
set_target_properties(test_subdirectory_target PROPERTIES OUTPUT_NAME test_cmake_build)
|
|
18
|
-
|
|
19
|
-
target_link_libraries(test_subdirectory_target PRIVATE pybind11::module)
|
|
20
|
-
|
|
21
|
-
# Make sure result is, for example, test_installed_target.so, not libtest_installed_target.dylib
|
|
22
|
-
pybind11_extension(test_subdirectory_target)
|
|
23
|
-
|
|
24
|
-
if(DEFINED Python_EXECUTABLE)
|
|
25
|
-
set(_Python_EXECUTABLE "${Python_EXECUTABLE}")
|
|
26
|
-
elseif(DEFINED PYTHON_EXECUTABLE)
|
|
27
|
-
set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}")
|
|
28
|
-
else()
|
|
29
|
-
message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)")
|
|
30
|
-
endif()
|
|
31
|
-
|
|
32
|
-
add_custom_target(
|
|
33
|
-
check_subdirectory_target
|
|
34
|
-
${CMAKE_COMMAND}
|
|
35
|
-
-E
|
|
36
|
-
env
|
|
37
|
-
PYTHONPATH=$<TARGET_FILE_DIR:test_subdirectory_target>
|
|
38
|
-
${_Python_EXECUTABLE}
|
|
39
|
-
${PROJECT_SOURCE_DIR}/../test.py
|
|
40
|
-
${PROJECT_NAME}
|
|
41
|
-
DEPENDS test_subdirectory_target)
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
# -*- coding: utf-8 -*-
|
|
2
|
-
import sys
|
|
3
|
-
|
|
4
|
-
import test_cmake_build
|
|
5
|
-
|
|
6
|
-
if str is not bytes: # If not Python2
|
|
7
|
-
assert isinstance(__file__, str) # Test this is properly set
|
|
8
|
-
|
|
9
|
-
assert test_cmake_build.add(1, 2) == 3
|
|
10
|
-
print("{} imports, runs, and adds: 1 + 2 = 3".format(sys.argv[1]))
|
xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.cpp
DELETED
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
tests/test_constants_and_functions.cpp -- global constants and functions, enumerations, raw
|
|
3
|
-
byte strings
|
|
4
|
-
|
|
5
|
-
Copyright (c) 2016 Wenzel Jakob <wenzel.jakob@epfl.ch>
|
|
6
|
-
|
|
7
|
-
All rights reserved. Use of this source code is governed by a
|
|
8
|
-
BSD-style license that can be found in the LICENSE file.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
#include "pybind11_tests.h"
|
|
12
|
-
|
|
13
|
-
enum MyEnum { EFirstEntry = 1, ESecondEntry };
|
|
14
|
-
|
|
15
|
-
std::string test_function1() {
|
|
16
|
-
return "test_function()";
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
std::string test_function2(MyEnum k) {
|
|
20
|
-
return "test_function(enum=" + std::to_string(k) + ")";
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
std::string test_function3(int i) {
|
|
24
|
-
return "test_function(" + std::to_string(i) + ")";
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
py::str test_function4() { return "test_function()"; }
|
|
28
|
-
py::str test_function4(char *) { return "test_function(char *)"; }
|
|
29
|
-
py::str test_function4(int, float) { return "test_function(int, float)"; }
|
|
30
|
-
py::str test_function4(float, int) { return "test_function(float, int)"; }
|
|
31
|
-
|
|
32
|
-
py::bytes return_bytes() {
|
|
33
|
-
const char *data = "\x01\x00\x02\x00";
|
|
34
|
-
return std::string(data, 4);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
std::string print_bytes(const py::bytes &bytes) {
|
|
38
|
-
std::string ret = "bytes[";
|
|
39
|
-
const auto value = static_cast<std::string>(bytes);
|
|
40
|
-
for (size_t i = 0; i < value.length(); ++i) {
|
|
41
|
-
ret += std::to_string(static_cast<int>(value[i])) + " ";
|
|
42
|
-
}
|
|
43
|
-
ret.back() = ']';
|
|
44
|
-
return ret;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
// Test that we properly handle C++17 exception specifiers (which are part of the function signature
|
|
48
|
-
// in C++17). These should all still work before C++17, but don't affect the function signature.
|
|
49
|
-
namespace test_exc_sp {
|
|
50
|
-
// [workaround(intel)] Unable to use noexcept instead of noexcept(true)
|
|
51
|
-
// Make the f1 test basically the same as the f2 test in C++17 mode for the Intel compiler as
|
|
52
|
-
// it fails to compile with a plain noexcept (tested with icc (ICC) 2021.1 Beta 20200827).
|
|
53
|
-
#if defined(__INTEL_COMPILER) && defined(PYBIND11_CPP17)
|
|
54
|
-
int f1(int x) noexcept(true) { return x+1; }
|
|
55
|
-
#else
|
|
56
|
-
int f1(int x) noexcept { return x+1; }
|
|
57
|
-
#endif
|
|
58
|
-
int f2(int x) noexcept(true) { return x+2; }
|
|
59
|
-
int f3(int x) noexcept(false) { return x+3; }
|
|
60
|
-
#if defined(__GNUG__) && !defined(__INTEL_COMPILER)
|
|
61
|
-
# pragma GCC diagnostic push
|
|
62
|
-
# pragma GCC diagnostic ignored "-Wdeprecated"
|
|
63
|
-
#endif
|
|
64
|
-
// NOLINTNEXTLINE(modernize-use-noexcept)
|
|
65
|
-
int f4(int x) throw() { return x+4; } // Deprecated equivalent to noexcept(true)
|
|
66
|
-
#if defined(__GNUG__) && !defined(__INTEL_COMPILER)
|
|
67
|
-
# pragma GCC diagnostic pop
|
|
68
|
-
#endif
|
|
69
|
-
struct C {
|
|
70
|
-
int m1(int x) noexcept { return x-1; }
|
|
71
|
-
int m2(int x) const noexcept { return x-2; }
|
|
72
|
-
int m3(int x) noexcept(true) { return x-3; }
|
|
73
|
-
int m4(int x) const noexcept(true) { return x-4; }
|
|
74
|
-
int m5(int x) noexcept(false) { return x-5; }
|
|
75
|
-
int m6(int x) const noexcept(false) { return x-6; }
|
|
76
|
-
#if defined(__GNUG__) && !defined(__INTEL_COMPILER)
|
|
77
|
-
# pragma GCC diagnostic push
|
|
78
|
-
# pragma GCC diagnostic ignored "-Wdeprecated"
|
|
79
|
-
#endif
|
|
80
|
-
// NOLINTNEXTLINE(modernize-use-noexcept)
|
|
81
|
-
int m7(int x) throw() { return x - 7; }
|
|
82
|
-
// NOLINTNEXTLINE(modernize-use-noexcept)
|
|
83
|
-
int m8(int x) const throw() { return x - 8; }
|
|
84
|
-
#if defined(__GNUG__) && !defined(__INTEL_COMPILER)
|
|
85
|
-
# pragma GCC diagnostic pop
|
|
86
|
-
#endif
|
|
87
|
-
};
|
|
88
|
-
} // namespace test_exc_sp
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
TEST_SUBMODULE(constants_and_functions, m) {
|
|
92
|
-
// test_constants
|
|
93
|
-
m.attr("some_constant") = py::int_(14);
|
|
94
|
-
|
|
95
|
-
// test_function_overloading
|
|
96
|
-
m.def("test_function", &test_function1);
|
|
97
|
-
m.def("test_function", &test_function2);
|
|
98
|
-
m.def("test_function", &test_function3);
|
|
99
|
-
|
|
100
|
-
#if defined(PYBIND11_OVERLOAD_CAST)
|
|
101
|
-
m.def("test_function", py::overload_cast<>(&test_function4));
|
|
102
|
-
m.def("test_function", py::overload_cast<char *>(&test_function4));
|
|
103
|
-
m.def("test_function", py::overload_cast<int, float>(&test_function4));
|
|
104
|
-
m.def("test_function", py::overload_cast<float, int>(&test_function4));
|
|
105
|
-
#else
|
|
106
|
-
m.def("test_function", static_cast<py::str (*)()>(&test_function4));
|
|
107
|
-
m.def("test_function", static_cast<py::str (*)(char *)>(&test_function4));
|
|
108
|
-
m.def("test_function", static_cast<py::str (*)(int, float)>(&test_function4));
|
|
109
|
-
m.def("test_function", static_cast<py::str (*)(float, int)>(&test_function4));
|
|
110
|
-
#endif
|
|
111
|
-
|
|
112
|
-
py::enum_<MyEnum>(m, "MyEnum")
|
|
113
|
-
.value("EFirstEntry", EFirstEntry)
|
|
114
|
-
.value("ESecondEntry", ESecondEntry)
|
|
115
|
-
.export_values();
|
|
116
|
-
|
|
117
|
-
// test_bytes
|
|
118
|
-
m.def("return_bytes", &return_bytes);
|
|
119
|
-
m.def("print_bytes", &print_bytes);
|
|
120
|
-
|
|
121
|
-
// test_exception_specifiers
|
|
122
|
-
using namespace test_exc_sp;
|
|
123
|
-
py::class_<C>(m, "C")
|
|
124
|
-
.def(py::init<>())
|
|
125
|
-
.def("m1", &C::m1)
|
|
126
|
-
.def("m2", &C::m2)
|
|
127
|
-
.def("m3", &C::m3)
|
|
128
|
-
.def("m4", &C::m4)
|
|
129
|
-
.def("m5", &C::m5)
|
|
130
|
-
.def("m6", &C::m6)
|
|
131
|
-
.def("m7", &C::m7)
|
|
132
|
-
.def("m8", &C::m8)
|
|
133
|
-
;
|
|
134
|
-
m.def("f1", f1);
|
|
135
|
-
m.def("f2", f2);
|
|
136
|
-
#if defined(__INTEL_COMPILER)
|
|
137
|
-
# pragma warning push
|
|
138
|
-
# pragma warning disable 878 // incompatible exception specifications
|
|
139
|
-
#endif
|
|
140
|
-
m.def("f3", f3);
|
|
141
|
-
#if defined(__INTEL_COMPILER)
|
|
142
|
-
# pragma warning pop
|
|
143
|
-
#endif
|
|
144
|
-
m.def("f4", f4);
|
|
145
|
-
|
|
146
|
-
// test_function_record_leaks
|
|
147
|
-
struct LargeCapture {
|
|
148
|
-
// This should always be enough to trigger the alternative branch
|
|
149
|
-
// where `sizeof(capture) > sizeof(rec->data)`
|
|
150
|
-
uint64_t zeros[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
|
|
151
|
-
};
|
|
152
|
-
m.def("register_large_capture_with_invalid_arguments", [](py::module_ m) {
|
|
153
|
-
LargeCapture capture; // VS 2015's MSVC is acting up if we create the array here
|
|
154
|
-
m.def("should_raise", [capture](int) { return capture.zeros[9] + 33; }, py::kw_only(), py::arg());
|
|
155
|
-
});
|
|
156
|
-
m.def("register_with_raising_repr", [](py::module_ m, const py::object &default_value) {
|
|
157
|
-
m.def(
|
|
158
|
-
"should_raise",
|
|
159
|
-
[](int, int, const py::object &) { return 42; },
|
|
160
|
-
"some docstring",
|
|
161
|
-
py::arg_v("x", 42),
|
|
162
|
-
py::arg_v("y", 42, "<the answer>"),
|
|
163
|
-
py::arg_v("z", default_value));
|
|
164
|
-
});
|
|
165
|
-
}
|
xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.py
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
# -*- coding: utf-8 -*-
|
|
2
|
-
import pytest
|
|
3
|
-
|
|
4
|
-
m = pytest.importorskip("pybind11_tests.constants_and_functions")
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
def test_constants():
|
|
8
|
-
assert m.some_constant == 14
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
def test_function_overloading():
|
|
12
|
-
assert m.test_function() == "test_function()"
|
|
13
|
-
assert m.test_function(7) == "test_function(7)"
|
|
14
|
-
assert m.test_function(m.MyEnum.EFirstEntry) == "test_function(enum=1)"
|
|
15
|
-
assert m.test_function(m.MyEnum.ESecondEntry) == "test_function(enum=2)"
|
|
16
|
-
|
|
17
|
-
assert m.test_function() == "test_function()"
|
|
18
|
-
assert m.test_function("abcd") == "test_function(char *)"
|
|
19
|
-
assert m.test_function(1, 1.0) == "test_function(int, float)"
|
|
20
|
-
assert m.test_function(1, 1.0) == "test_function(int, float)"
|
|
21
|
-
assert m.test_function(2.0, 2) == "test_function(float, int)"
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
def test_bytes():
|
|
25
|
-
assert m.print_bytes(m.return_bytes()) == "bytes[1 0 2 0]"
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
def test_exception_specifiers():
|
|
29
|
-
c = m.C()
|
|
30
|
-
assert c.m1(2) == 1
|
|
31
|
-
assert c.m2(3) == 1
|
|
32
|
-
assert c.m3(5) == 2
|
|
33
|
-
assert c.m4(7) == 3
|
|
34
|
-
assert c.m5(10) == 5
|
|
35
|
-
assert c.m6(14) == 8
|
|
36
|
-
assert c.m7(20) == 13
|
|
37
|
-
assert c.m8(29) == 21
|
|
38
|
-
|
|
39
|
-
assert m.f1(33) == 34
|
|
40
|
-
assert m.f2(53) == 55
|
|
41
|
-
assert m.f3(86) == 89
|
|
42
|
-
assert m.f4(140) == 144
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
def test_function_record_leaks():
|
|
46
|
-
class RaisingRepr:
|
|
47
|
-
def __repr__(self):
|
|
48
|
-
raise RuntimeError("Surprise!")
|
|
49
|
-
|
|
50
|
-
with pytest.raises(RuntimeError):
|
|
51
|
-
m.register_large_capture_with_invalid_arguments(m)
|
|
52
|
-
with pytest.raises(RuntimeError):
|
|
53
|
-
m.register_with_raising_repr(m, RaisingRepr())
|
|
@@ -1,238 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
tests/test_copy_move_policies.cpp -- 'copy' and 'move' return value policies
|
|
3
|
-
and related tests
|
|
4
|
-
|
|
5
|
-
Copyright (c) 2016 Ben North <ben@redfrontdoor.org>
|
|
6
|
-
|
|
7
|
-
All rights reserved. Use of this source code is governed by a
|
|
8
|
-
BSD-style license that can be found in the LICENSE file.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
#include "pybind11_tests.h"
|
|
12
|
-
#include "constructor_stats.h"
|
|
13
|
-
#include <pybind11/stl.h>
|
|
14
|
-
|
|
15
|
-
template <typename derived>
|
|
16
|
-
struct empty {
|
|
17
|
-
static const derived& get_one() { return instance_; }
|
|
18
|
-
static derived instance_;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
struct lacking_copy_ctor : public empty<lacking_copy_ctor> {
|
|
22
|
-
lacking_copy_ctor() = default;
|
|
23
|
-
lacking_copy_ctor(const lacking_copy_ctor& other) = delete;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
template <> lacking_copy_ctor empty<lacking_copy_ctor>::instance_ = {};
|
|
27
|
-
|
|
28
|
-
struct lacking_move_ctor : public empty<lacking_move_ctor> {
|
|
29
|
-
lacking_move_ctor() = default;
|
|
30
|
-
lacking_move_ctor(const lacking_move_ctor& other) = delete;
|
|
31
|
-
lacking_move_ctor(lacking_move_ctor&& other) = delete;
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
template <> lacking_move_ctor empty<lacking_move_ctor>::instance_ = {};
|
|
35
|
-
|
|
36
|
-
/* Custom type caster move/copy test classes */
|
|
37
|
-
class MoveOnlyInt {
|
|
38
|
-
public:
|
|
39
|
-
MoveOnlyInt() { print_default_created(this); }
|
|
40
|
-
explicit MoveOnlyInt(int v) : value{v} { print_created(this, value); }
|
|
41
|
-
MoveOnlyInt(MoveOnlyInt &&m) noexcept {
|
|
42
|
-
print_move_created(this, m.value);
|
|
43
|
-
std::swap(value, m.value);
|
|
44
|
-
}
|
|
45
|
-
MoveOnlyInt &operator=(MoveOnlyInt &&m) noexcept {
|
|
46
|
-
print_move_assigned(this, m.value);
|
|
47
|
-
std::swap(value, m.value);
|
|
48
|
-
return *this;
|
|
49
|
-
}
|
|
50
|
-
MoveOnlyInt(const MoveOnlyInt &) = delete;
|
|
51
|
-
MoveOnlyInt &operator=(const MoveOnlyInt &) = delete;
|
|
52
|
-
~MoveOnlyInt() { print_destroyed(this); }
|
|
53
|
-
|
|
54
|
-
int value;
|
|
55
|
-
};
|
|
56
|
-
class MoveOrCopyInt {
|
|
57
|
-
public:
|
|
58
|
-
MoveOrCopyInt() { print_default_created(this); }
|
|
59
|
-
explicit MoveOrCopyInt(int v) : value{v} { print_created(this, value); }
|
|
60
|
-
MoveOrCopyInt(MoveOrCopyInt &&m) noexcept {
|
|
61
|
-
print_move_created(this, m.value);
|
|
62
|
-
std::swap(value, m.value);
|
|
63
|
-
}
|
|
64
|
-
MoveOrCopyInt &operator=(MoveOrCopyInt &&m) noexcept {
|
|
65
|
-
print_move_assigned(this, m.value);
|
|
66
|
-
std::swap(value, m.value);
|
|
67
|
-
return *this;
|
|
68
|
-
}
|
|
69
|
-
MoveOrCopyInt(const MoveOrCopyInt &c) { print_copy_created(this, c.value); value = c.value; }
|
|
70
|
-
MoveOrCopyInt &operator=(const MoveOrCopyInt &c) { print_copy_assigned(this, c.value); value = c.value; return *this; }
|
|
71
|
-
~MoveOrCopyInt() { print_destroyed(this); }
|
|
72
|
-
|
|
73
|
-
int value;
|
|
74
|
-
};
|
|
75
|
-
class CopyOnlyInt {
|
|
76
|
-
public:
|
|
77
|
-
CopyOnlyInt() { print_default_created(this); }
|
|
78
|
-
explicit CopyOnlyInt(int v) : value{v} { print_created(this, value); }
|
|
79
|
-
CopyOnlyInt(const CopyOnlyInt &c) { print_copy_created(this, c.value); value = c.value; }
|
|
80
|
-
CopyOnlyInt &operator=(const CopyOnlyInt &c) { print_copy_assigned(this, c.value); value = c.value; return *this; }
|
|
81
|
-
~CopyOnlyInt() { print_destroyed(this); }
|
|
82
|
-
|
|
83
|
-
int value;
|
|
84
|
-
};
|
|
85
|
-
PYBIND11_NAMESPACE_BEGIN(pybind11)
|
|
86
|
-
PYBIND11_NAMESPACE_BEGIN(detail)
|
|
87
|
-
template <> struct type_caster<MoveOnlyInt> {
|
|
88
|
-
PYBIND11_TYPE_CASTER(MoveOnlyInt, _("MoveOnlyInt"));
|
|
89
|
-
bool load(handle src, bool) { value = MoveOnlyInt(src.cast<int>()); return true; }
|
|
90
|
-
static handle cast(const MoveOnlyInt &m, return_value_policy r, handle p) { return pybind11::cast(m.value, r, p); }
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
template <> struct type_caster<MoveOrCopyInt> {
|
|
94
|
-
PYBIND11_TYPE_CASTER(MoveOrCopyInt, _("MoveOrCopyInt"));
|
|
95
|
-
bool load(handle src, bool) { value = MoveOrCopyInt(src.cast<int>()); return true; }
|
|
96
|
-
static handle cast(const MoveOrCopyInt &m, return_value_policy r, handle p) { return pybind11::cast(m.value, r, p); }
|
|
97
|
-
};
|
|
98
|
-
|
|
99
|
-
template <> struct type_caster<CopyOnlyInt> {
|
|
100
|
-
protected:
|
|
101
|
-
CopyOnlyInt value;
|
|
102
|
-
public:
|
|
103
|
-
static constexpr auto name = _("CopyOnlyInt");
|
|
104
|
-
bool load(handle src, bool) { value = CopyOnlyInt(src.cast<int>()); return true; }
|
|
105
|
-
static handle cast(const CopyOnlyInt &m, return_value_policy r, handle p) { return pybind11::cast(m.value, r, p); }
|
|
106
|
-
static handle cast(const CopyOnlyInt *src, return_value_policy policy, handle parent) {
|
|
107
|
-
if (!src) return none().release();
|
|
108
|
-
return cast(*src, policy, parent);
|
|
109
|
-
}
|
|
110
|
-
explicit operator CopyOnlyInt *() { return &value; }
|
|
111
|
-
explicit operator CopyOnlyInt &() { return value; }
|
|
112
|
-
template <typename T> using cast_op_type = pybind11::detail::cast_op_type<T>;
|
|
113
|
-
};
|
|
114
|
-
PYBIND11_NAMESPACE_END(detail)
|
|
115
|
-
PYBIND11_NAMESPACE_END(pybind11)
|
|
116
|
-
|
|
117
|
-
TEST_SUBMODULE(copy_move_policies, m) {
|
|
118
|
-
// test_lacking_copy_ctor
|
|
119
|
-
py::class_<lacking_copy_ctor>(m, "lacking_copy_ctor")
|
|
120
|
-
.def_static("get_one", &lacking_copy_ctor::get_one,
|
|
121
|
-
py::return_value_policy::copy);
|
|
122
|
-
// test_lacking_move_ctor
|
|
123
|
-
py::class_<lacking_move_ctor>(m, "lacking_move_ctor")
|
|
124
|
-
.def_static("get_one", &lacking_move_ctor::get_one,
|
|
125
|
-
py::return_value_policy::move);
|
|
126
|
-
|
|
127
|
-
// test_move_and_copy_casts
|
|
128
|
-
// NOLINTNEXTLINE(performance-unnecessary-value-param)
|
|
129
|
-
m.def("move_and_copy_casts", [](const py::object &o) {
|
|
130
|
-
int r = 0;
|
|
131
|
-
r += py::cast<MoveOrCopyInt>(o).value; /* moves */
|
|
132
|
-
r += py::cast<MoveOnlyInt>(o).value; /* moves */
|
|
133
|
-
r += py::cast<CopyOnlyInt>(o).value; /* copies */
|
|
134
|
-
auto m1(py::cast<MoveOrCopyInt>(o)); /* moves */
|
|
135
|
-
auto m2(py::cast<MoveOnlyInt>(o)); /* moves */
|
|
136
|
-
auto m3(py::cast<CopyOnlyInt>(o)); /* copies */
|
|
137
|
-
r += m1.value + m2.value + m3.value;
|
|
138
|
-
|
|
139
|
-
return r;
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
// test_move_and_copy_loads
|
|
143
|
-
m.def("move_only", [](MoveOnlyInt m) { return m.value; });
|
|
144
|
-
// Changing this breaks the existing test: needs careful review.
|
|
145
|
-
// NOLINTNEXTLINE(performance-unnecessary-value-param)
|
|
146
|
-
m.def("move_or_copy", [](MoveOrCopyInt m) { return m.value; });
|
|
147
|
-
// Changing this breaks the existing test: needs careful review.
|
|
148
|
-
// NOLINTNEXTLINE(performance-unnecessary-value-param)
|
|
149
|
-
m.def("copy_only", [](CopyOnlyInt m) { return m.value; });
|
|
150
|
-
m.def("move_pair", [](std::pair<MoveOnlyInt, MoveOrCopyInt> p) {
|
|
151
|
-
return p.first.value + p.second.value;
|
|
152
|
-
});
|
|
153
|
-
m.def("move_tuple", [](std::tuple<MoveOnlyInt, MoveOrCopyInt, MoveOnlyInt> t) {
|
|
154
|
-
return std::get<0>(t).value + std::get<1>(t).value + std::get<2>(t).value;
|
|
155
|
-
});
|
|
156
|
-
m.def("copy_tuple", [](std::tuple<CopyOnlyInt, CopyOnlyInt> t) {
|
|
157
|
-
return std::get<0>(t).value + std::get<1>(t).value;
|
|
158
|
-
});
|
|
159
|
-
m.def("move_copy_nested", [](std::pair<MoveOnlyInt, std::pair<std::tuple<MoveOrCopyInt, CopyOnlyInt, std::tuple<MoveOnlyInt>>, MoveOrCopyInt>> x) {
|
|
160
|
-
return x.first.value + std::get<0>(x.second.first).value + std::get<1>(x.second.first).value +
|
|
161
|
-
std::get<0>(std::get<2>(x.second.first)).value + x.second.second.value;
|
|
162
|
-
});
|
|
163
|
-
m.def("move_and_copy_cstats", []() {
|
|
164
|
-
ConstructorStats::gc();
|
|
165
|
-
// Reset counts to 0 so that previous tests don't affect later ones:
|
|
166
|
-
auto &mc = ConstructorStats::get<MoveOrCopyInt>();
|
|
167
|
-
mc.move_assignments = mc.move_constructions = mc.copy_assignments = mc.copy_constructions = 0;
|
|
168
|
-
auto &mo = ConstructorStats::get<MoveOnlyInt>();
|
|
169
|
-
mo.move_assignments = mo.move_constructions = mo.copy_assignments = mo.copy_constructions = 0;
|
|
170
|
-
auto &co = ConstructorStats::get<CopyOnlyInt>();
|
|
171
|
-
co.move_assignments = co.move_constructions = co.copy_assignments = co.copy_constructions = 0;
|
|
172
|
-
py::dict d;
|
|
173
|
-
d["MoveOrCopyInt"] = py::cast(mc, py::return_value_policy::reference);
|
|
174
|
-
d["MoveOnlyInt"] = py::cast(mo, py::return_value_policy::reference);
|
|
175
|
-
d["CopyOnlyInt"] = py::cast(co, py::return_value_policy::reference);
|
|
176
|
-
return d;
|
|
177
|
-
});
|
|
178
|
-
#ifdef PYBIND11_HAS_OPTIONAL
|
|
179
|
-
// test_move_and_copy_load_optional
|
|
180
|
-
m.attr("has_optional") = true;
|
|
181
|
-
m.def("move_optional", [](std::optional<MoveOnlyInt> o) {
|
|
182
|
-
return o->value;
|
|
183
|
-
});
|
|
184
|
-
m.def("move_or_copy_optional", [](std::optional<MoveOrCopyInt> o) {
|
|
185
|
-
return o->value;
|
|
186
|
-
});
|
|
187
|
-
m.def("copy_optional", [](std::optional<CopyOnlyInt> o) {
|
|
188
|
-
return o->value;
|
|
189
|
-
});
|
|
190
|
-
m.def("move_optional_tuple", [](std::optional<std::tuple<MoveOrCopyInt, MoveOnlyInt, CopyOnlyInt>> x) {
|
|
191
|
-
return std::get<0>(*x).value + std::get<1>(*x).value + std::get<2>(*x).value;
|
|
192
|
-
});
|
|
193
|
-
#else
|
|
194
|
-
m.attr("has_optional") = false;
|
|
195
|
-
#endif
|
|
196
|
-
|
|
197
|
-
// #70 compilation issue if operator new is not public - simple body added
|
|
198
|
-
// but not needed on most compilers; MSVC and nvcc don't like a local
|
|
199
|
-
// struct not having a method defined when declared, since it can not be
|
|
200
|
-
// added later.
|
|
201
|
-
struct PrivateOpNew {
|
|
202
|
-
int value = 1;
|
|
203
|
-
private:
|
|
204
|
-
void *operator new(size_t bytes) {
|
|
205
|
-
void *ptr = std::malloc(bytes);
|
|
206
|
-
if (ptr)
|
|
207
|
-
return ptr;
|
|
208
|
-
throw std::bad_alloc{};
|
|
209
|
-
}
|
|
210
|
-
};
|
|
211
|
-
py::class_<PrivateOpNew>(m, "PrivateOpNew").def_readonly("value", &PrivateOpNew::value);
|
|
212
|
-
m.def("private_op_new_value", []() { return PrivateOpNew(); });
|
|
213
|
-
m.def("private_op_new_reference", []() -> const PrivateOpNew & {
|
|
214
|
-
static PrivateOpNew x{};
|
|
215
|
-
return x;
|
|
216
|
-
}, py::return_value_policy::reference);
|
|
217
|
-
|
|
218
|
-
// test_move_fallback
|
|
219
|
-
// #389: rvp::move should fall-through to copy on non-movable objects
|
|
220
|
-
struct MoveIssue1 {
|
|
221
|
-
int v;
|
|
222
|
-
explicit MoveIssue1(int v) : v{v} {}
|
|
223
|
-
MoveIssue1(const MoveIssue1 &c) = default;
|
|
224
|
-
MoveIssue1(MoveIssue1 &&) = delete;
|
|
225
|
-
};
|
|
226
|
-
py::class_<MoveIssue1>(m, "MoveIssue1").def(py::init<int>()).def_readwrite("value", &MoveIssue1::v);
|
|
227
|
-
|
|
228
|
-
struct MoveIssue2 {
|
|
229
|
-
int v;
|
|
230
|
-
explicit MoveIssue2(int v) : v{v} {}
|
|
231
|
-
MoveIssue2(MoveIssue2 &&) = default;
|
|
232
|
-
};
|
|
233
|
-
py::class_<MoveIssue2>(m, "MoveIssue2").def(py::init<int>()).def_readwrite("value", &MoveIssue2::v);
|
|
234
|
-
|
|
235
|
-
// #2742: Don't expect ownership of raw pointer to `new`ed object to be transferred with `py::return_value_policy::move`
|
|
236
|
-
m.def("get_moveissue1", [](int i) { return std::unique_ptr<MoveIssue1>(new MoveIssue1(i)); }, py::return_value_policy::move);
|
|
237
|
-
m.def("get_moveissue2", [](int i) { return MoveIssue2(i); }, py::return_value_policy::move);
|
|
238
|
-
}
|