cgse 2023.38.0__py3-none-any.whl → 2024.1.4__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.
- README.md +27 -0
- bump.py +85 -0
- cgse-2024.1.4.dist-info/METADATA +38 -0
- cgse-2024.1.4.dist-info/RECORD +5 -0
- {cgse-2023.38.0.dist-info → cgse-2024.1.4.dist-info}/WHEEL +1 -2
- cgse-2023.38.0.dist-info/COPYING +0 -674
- cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
- cgse-2023.38.0.dist-info/METADATA +0 -144
- cgse-2023.38.0.dist-info/RECORD +0 -649
- cgse-2023.38.0.dist-info/entry_points.txt +0 -75
- cgse-2023.38.0.dist-info/top_level.txt +0 -2
- egse/__init__.py +0 -12
- egse/__main__.py +0 -32
- egse/aeu/aeu.py +0 -5235
- egse/aeu/aeu_awg.yaml +0 -265
- egse/aeu/aeu_crio.yaml +0 -273
- egse/aeu/aeu_cs.py +0 -626
- egse/aeu/aeu_devif.py +0 -321
- egse/aeu/aeu_main_ui.py +0 -912
- egse/aeu/aeu_metrics.py +0 -131
- egse/aeu/aeu_protocol.py +0 -463
- egse/aeu/aeu_psu.yaml +0 -204
- egse/aeu/aeu_ui.py +0 -873
- egse/aeu/arbdata/FccdRead.arb +0 -2
- egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
- egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/ccdRead25.arb +0 -2
- egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead50.arb +0 -2
- egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
- egse/alert/__init__.py +0 -1049
- egse/alert/alertman.yaml +0 -37
- egse/alert/alertman_cs.py +0 -234
- egse/alert/alertman_ui.py +0 -603
- egse/alert/gsm/beaglebone.py +0 -138
- egse/alert/gsm/beaglebone.yaml +0 -51
- egse/alert/gsm/beaglebone_cs.py +0 -108
- egse/alert/gsm/beaglebone_devif.py +0 -130
- egse/alert/gsm/beaglebone_protocol.py +0 -48
- egse/bits.py +0 -318
- egse/camera.py +0 -44
- egse/collimator/__init__.py +0 -0
- egse/collimator/fcul/__init__.py +0 -0
- egse/collimator/fcul/ogse.py +0 -1077
- egse/collimator/fcul/ogse.yaml +0 -14
- egse/collimator/fcul/ogse_cs.py +0 -154
- egse/collimator/fcul/ogse_devif.py +0 -358
- egse/collimator/fcul/ogse_protocol.py +0 -129
- egse/collimator/fcul/ogse_sim.py +0 -431
- egse/collimator/fcul/ogse_ui.py +0 -1108
- egse/command.py +0 -699
- egse/config.py +0 -410
- egse/confman/__init__.py +0 -1015
- egse/confman/confman.yaml +0 -67
- egse/confman/confman_cs.py +0 -239
- egse/confman/confman_ui.py +0 -381
- egse/confman/setup_ui.py +0 -565
- egse/control.py +0 -442
- egse/coordinates/__init__.py +0 -531
- egse/coordinates/avoidance.py +0 -103
- egse/coordinates/cslmodel.py +0 -127
- egse/coordinates/laser_tracker_to_dict.py +0 -120
- egse/coordinates/point.py +0 -707
- egse/coordinates/pyplot.py +0 -195
- egse/coordinates/referenceFrame.py +0 -1279
- egse/coordinates/refmodel.py +0 -737
- egse/coordinates/rotationMatrix.py +0 -85
- egse/coordinates/transform3d_addon.py +0 -419
- egse/csl/__init__.py +0 -50
- egse/csl/commanding.py +0 -78
- egse/csl/icons/hexapod-connected-selected.svg +0 -30
- egse/csl/icons/hexapod-connected.svg +0 -30
- egse/csl/icons/hexapod-homing-selected.svg +0 -68
- egse/csl/icons/hexapod-homing.svg +0 -68
- egse/csl/icons/hexapod-retract-selected.svg +0 -56
- egse/csl/icons/hexapod-retract.svg +0 -51
- egse/csl/icons/hexapod-zero-selected.svg +0 -56
- egse/csl/icons/hexapod-zero.svg +0 -56
- egse/csl/icons/logo-puna.svg +0 -92
- egse/csl/icons/stop.svg +0 -1
- egse/csl/initialisation.py +0 -102
- egse/csl/mech_pos_settings.yaml +0 -18
- egse/das.py +0 -1247
- egse/das.yaml +0 -7
- egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
- egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
- egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
- egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
- egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
- egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
- egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
- egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
- egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
- egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
- egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
- egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
- egse/decorators.py +0 -415
- egse/device.py +0 -269
- egse/dpu/__init__.py +0 -2681
- egse/dpu/ccd_ui.py +0 -508
- egse/dpu/dpu.py +0 -786
- egse/dpu/dpu.yaml +0 -153
- egse/dpu/dpu_cs.py +0 -272
- egse/dpu/dpu_ui.py +0 -668
- egse/dpu/fitsgen.py +0 -2077
- egse/dpu/fitsgen_test.py +0 -752
- egse/dpu/fitsgen_ui.py +0 -399
- egse/dpu/hdf5_model.py +0 -332
- egse/dpu/hdf5_ui.py +0 -277
- egse/dpu/hdf5_viewer.py +0 -506
- egse/dpu/hk_ui.py +0 -468
- egse/dpu_commands.py +0 -81
- egse/dsi/constants.py +0 -220
- egse/dsi/esl.py +0 -870
- egse/dsi/rmap.py +0 -1042
- egse/dsi/rmapci.py +0 -37
- egse/dsi/spw.py +0 -154
- egse/dsi/spw_state.py +0 -29
- egse/dummy.py +0 -258
- egse/dyndummy.py +0 -179
- egse/env.py +0 -278
- egse/exceptions.py +0 -88
- egse/fdir/__init__.py +0 -28
- egse/fdir/fdir_manager.py +0 -85
- egse/fdir/fdir_manager.yaml +0 -51
- egse/fdir/fdir_manager_controller.py +0 -228
- egse/fdir/fdir_manager_cs.py +0 -164
- egse/fdir/fdir_manager_interface.py +0 -25
- egse/fdir/fdir_remote.py +0 -73
- egse/fdir/fdir_remote.yaml +0 -37
- egse/fdir/fdir_remote_controller.py +0 -50
- egse/fdir/fdir_remote_cs.py +0 -97
- egse/fdir/fdir_remote_interface.py +0 -14
- egse/fdir/fdir_remote_popup.py +0 -31
- egse/fee/__init__.py +0 -114
- egse/fee/f_fee_register.yaml +0 -43
- egse/fee/fee.py +0 -631
- egse/fee/feesim.py +0 -750
- egse/fee/n_fee_hk.py +0 -761
- egse/fee/nfee.py +0 -187
- egse/filterwheel/__init__.py +0 -4
- egse/filterwheel/eksma/__init__.py +0 -24
- egse/filterwheel/eksma/fw8smc4.py +0 -661
- egse/filterwheel/eksma/fw8smc4.yaml +0 -121
- egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
- egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
- egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
- egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
- egse/filterwheel/eksma/fw8smc5.py +0 -111
- egse/filterwheel/eksma/fw8smc5.yaml +0 -105
- egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
- egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
- egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
- egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
- egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
- egse/filterwheel/eksma/testpythonfw.py +0 -215
- egse/fov/__init__.py +0 -65
- egse/fov/fov_hk.py +0 -712
- egse/fov/fov_ui.py +0 -861
- egse/fov/fov_ui_controller.py +0 -140
- egse/fov/fov_ui_model.py +0 -200
- egse/fov/fov_ui_view.py +0 -345
- egse/gimbal/__init__.py +0 -32
- egse/gimbal/symetrie/__init__.py +0 -26
- egse/gimbal/symetrie/alpha.py +0 -586
- egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
- egse/gimbal/symetrie/gimbal.py +0 -877
- egse/gimbal/symetrie/gimbal.yaml +0 -168
- egse/gimbal/symetrie/gimbal_cs.py +0 -183
- egse/gimbal/symetrie/gimbal_protocol.py +0 -135
- egse/gimbal/symetrie/gimbal_ui.py +0 -361
- egse/gimbal/symetrie/pmac.py +0 -1006
- egse/gimbal/symetrie/pmac_regex.py +0 -83
- egse/graph.py +0 -132
- egse/gui/__init__.py +0 -47
- egse/gui/buttons.py +0 -378
- egse/gui/focalplane.py +0 -1281
- egse/gui/formatter.py +0 -10
- egse/gui/led.py +0 -162
- egse/gui/limitswitch.py +0 -143
- egse/gui/mechanisms.py +0 -588
- egse/gui/states.py +0 -148
- egse/gui/stripchart.py +0 -729
- egse/gui/switch.py +0 -112
- egse/h5.py +0 -274
- egse/help/__init__.py +0 -0
- egse/help/help_ui.py +0 -126
- egse/hexapod/__init__.py +0 -32
- egse/hexapod/symetrie/__init__.py +0 -138
- egse/hexapod/symetrie/alpha.py +0 -874
- egse/hexapod/symetrie/dynalpha.py +0 -1387
- egse/hexapod/symetrie/hexapod_ui.py +0 -1516
- egse/hexapod/symetrie/pmac.py +0 -1010
- egse/hexapod/symetrie/pmac_regex.py +0 -83
- egse/hexapod/symetrie/puna.py +0 -1167
- egse/hexapod/symetrie/puna.yaml +0 -193
- egse/hexapod/symetrie/puna_cs.py +0 -196
- egse/hexapod/symetrie/puna_protocol.py +0 -131
- egse/hexapod/symetrie/puna_ui.py +0 -434
- egse/hexapod/symetrie/punaplus.py +0 -107
- egse/hexapod/symetrie/zonda.py +0 -872
- egse/hexapod/symetrie/zonda.yaml +0 -337
- egse/hexapod/symetrie/zonda_cs.py +0 -172
- egse/hexapod/symetrie/zonda_devif.py +0 -415
- egse/hexapod/symetrie/zonda_protocol.py +0 -119
- egse/hexapod/symetrie/zonda_ui.py +0 -449
- egse/hk.py +0 -765
- egse/icons/aeu-cs-start.svg +0 -117
- egse/icons/aeu-cs-stop.svg +0 -118
- egse/icons/aeu-cs.svg +0 -107
- egse/icons/aeu_cs-started.svg +0 -112
- egse/icons/aeu_cs-stopped.svg +0 -112
- egse/icons/aeu_cs.svg +0 -55
- egse/icons/alert.svg +0 -1
- egse/icons/arrow-double-left.png +0 -0
- egse/icons/arrow-double-right.png +0 -0
- egse/icons/arrow-up.svg +0 -11
- egse/icons/backward.svg +0 -1
- egse/icons/busy.svg +0 -1
- egse/icons/cleaning.svg +0 -115
- egse/icons/color-scheme.svg +0 -1
- egse/icons/cs-connected-alert.svg +0 -91
- egse/icons/cs-connected-disabled.svg +0 -43
- egse/icons/cs-connected.svg +0 -89
- egse/icons/cs-not-connected.svg +0 -44
- egse/icons/double-left-arrow.svg +0 -1
- egse/icons/double-right-arrow.svg +0 -1
- egse/icons/erase-disabled.svg +0 -19
- egse/icons/erase.svg +0 -59
- egse/icons/fitsgen-start.svg +0 -47
- egse/icons/fitsgen-stop.svg +0 -48
- egse/icons/fitsgen.svg +0 -1
- egse/icons/forward.svg +0 -1
- egse/icons/fov-hk-start.svg +0 -33
- egse/icons/fov-hk-stop.svg +0 -37
- egse/icons/fov-hk.svg +0 -1
- egse/icons/front-desk.svg +0 -1
- egse/icons/home-actioned.svg +0 -15
- egse/icons/home-disabled.svg +0 -15
- egse/icons/home.svg +0 -13
- egse/icons/info.svg +0 -1
- egse/icons/invalid.png +0 -0
- egse/icons/led-green.svg +0 -20
- egse/icons/led-grey.svg +0 -20
- egse/icons/led-orange.svg +0 -20
- egse/icons/led-red.svg +0 -20
- egse/icons/led-square-green.svg +0 -134
- egse/icons/led-square-grey.svg +0 -134
- egse/icons/led-square-orange.svg +0 -134
- egse/icons/led-square-red.svg +0 -134
- egse/icons/limit-switch-all-green.svg +0 -115
- egse/icons/limit-switch-all-red.svg +0 -117
- egse/icons/limit-switch-el+.svg +0 -116
- egse/icons/limit-switch-el-.svg +0 -117
- egse/icons/location-marker.svg +0 -1
- egse/icons/logo-dpu.svg +0 -48
- egse/icons/logo-gimbal.svg +0 -112
- egse/icons/logo-huber.svg +0 -23
- egse/icons/logo-ogse.svg +0 -31
- egse/icons/logo-puna.svg +0 -92
- egse/icons/logo-tcs.svg +0 -29
- egse/icons/logo-zonda.svg +0 -66
- egse/icons/maximize.svg +0 -1
- egse/icons/meter.svg +0 -1
- egse/icons/more.svg +0 -45
- egse/icons/n-fee-hk-start.svg +0 -24
- egse/icons/n-fee-hk-stop.svg +0 -25
- egse/icons/n-fee-hk.svg +0 -83
- egse/icons/observing-off.svg +0 -46
- egse/icons/observing-on.svg +0 -46
- egse/icons/open-document-hdf5.png +0 -0
- egse/icons/open-document-hdf5.svg +0 -21
- egse/icons/ops-mode.svg +0 -1
- egse/icons/play-green.svg +0 -17
- egse/icons/plugged-disabled.svg +0 -27
- egse/icons/plugged.svg +0 -21
- egse/icons/pm_ui.svg +0 -1
- egse/icons/power-button-green.svg +0 -27
- egse/icons/power-button-red.svg +0 -27
- egse/icons/power-button.svg +0 -27
- egse/icons/radar.svg +0 -1
- egse/icons/radioactive.svg +0 -2
- egse/icons/reload.svg +0 -1
- egse/icons/remote-control-off.svg +0 -28
- egse/icons/remote-control-on.svg +0 -28
- egse/icons/repeat-blue.svg +0 -15
- egse/icons/repeat.svg +0 -1
- egse/icons/settings.svg +0 -1
- egse/icons/shrink.svg +0 -1
- egse/icons/shutter.svg +0 -1
- egse/icons/sign-off.svg +0 -1
- egse/icons/sign-on.svg +0 -1
- egse/icons/sim-mode.svg +0 -1
- egse/icons/small-buttons-go.svg +0 -20
- egse/icons/small-buttons-minus.svg +0 -51
- egse/icons/small-buttons-plus.svg +0 -51
- egse/icons/sponge.svg +0 -220
- egse/icons/start-button-disabled.svg +0 -84
- egse/icons/start-button.svg +0 -50
- egse/icons/stop-button-disabled.svg +0 -84
- egse/icons/stop-button.svg +0 -50
- egse/icons/stop-red.svg +0 -17
- egse/icons/stop.svg +0 -1
- egse/icons/switch-disabled-square.svg +0 -87
- egse/icons/switch-disabled.svg +0 -15
- egse/icons/switch-off-square.svg +0 -87
- egse/icons/switch-off.svg +0 -72
- egse/icons/switch-on-square.svg +0 -87
- egse/icons/switch-on.svg +0 -61
- egse/icons/temperature-control.svg +0 -44
- egse/icons/th_ui_logo.svg +0 -1
- egse/icons/unplugged.svg +0 -23
- egse/icons/unvalid.png +0 -0
- egse/icons/user-interface.svg +0 -1
- egse/icons/vacuum.svg +0 -1
- egse/icons/valid.png +0 -0
- egse/icons/zoom-to-pixel-dark.svg +0 -64
- egse/icons/zoom-to-pixel-white.svg +0 -36
- egse/images/big-rotation-stage.png +0 -0
- egse/images/connected-100.png +0 -0
- egse/images/cross.svg +0 -6
- egse/images/disconnected-100.png +0 -0
- egse/images/gui-icon.png +0 -0
- egse/images/home.svg +0 -6
- egse/images/info-icon.png +0 -0
- egse/images/led-black.svg +0 -89
- egse/images/led-green.svg +0 -85
- egse/images/led-orange.svg +0 -85
- egse/images/led-red.svg +0 -85
- egse/images/load-icon.png +0 -0
- egse/images/load-setup.png +0 -0
- egse/images/load.png +0 -0
- egse/images/pause.png +0 -0
- egse/images/play-button.svg +0 -8
- egse/images/play.png +0 -0
- egse/images/process-status.png +0 -0
- egse/images/restart.png +0 -0
- egse/images/search.png +0 -0
- egse/images/sma.png +0 -0
- egse/images/start.png +0 -0
- egse/images/stop-button.svg +0 -8
- egse/images/stop.png +0 -0
- egse/images/switch-off.svg +0 -48
- egse/images/switch-on.svg +0 -48
- egse/images/undo.png +0 -0
- egse/images/update-button.svg +0 -11
- egse/imageviewer/exposureselection.py +0 -475
- egse/imageviewer/imageviewer.py +0 -198
- egse/imageviewer/matchfocalplane.py +0 -179
- egse/imageviewer/subfieldposition.py +0 -133
- egse/lampcontrol/__init__.py +0 -4
- egse/lampcontrol/beaglebone/beaglebone.py +0 -178
- egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
- egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
- egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
- egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
- egse/lampcontrol/energetiq/__init__.py +0 -22
- egse/lampcontrol/energetiq/eq99.yaml +0 -98
- egse/lampcontrol/energetiq/lampEQ99.py +0 -283
- egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
- egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
- egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
- egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
- egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
- egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
- egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
- egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
- egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
- egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
- egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
- egse/lib/ximc/libximc.framework/libbindy.so +0 -0
- egse/lib/ximc/libximc.framework/libximc +0 -0
- egse/lib/ximc/libximc.framework/libximc.so +0 -0
- egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
- egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
- egse/lib/ximc/pyximc.py +0 -922
- egse/listener.py +0 -73
- egse/logger/__init__.py +0 -243
- egse/logger/log_cs.py +0 -321
- egse/metrics.py +0 -98
- egse/mixin.py +0 -464
- egse/monitoring.py +0 -95
- egse/ni/alarms/__init__.py +0 -26
- egse/ni/alarms/cdaq9375.py +0 -300
- egse/ni/alarms/cdaq9375.yaml +0 -89
- egse/ni/alarms/cdaq9375_cs.py +0 -130
- egse/ni/alarms/cdaq9375_devif.py +0 -183
- egse/ni/alarms/cdaq9375_protocol.py +0 -48
- egse/obs_inspection.py +0 -163
- egse/observer.py +0 -41
- egse/obsid.py +0 -163
- egse/powermeter/__init__.py +0 -0
- egse/powermeter/ni/__init__.py +0 -38
- egse/powermeter/ni/cdaq9184.py +0 -224
- egse/powermeter/ni/cdaq9184.yaml +0 -73
- egse/powermeter/ni/cdaq9184_cs.py +0 -130
- egse/powermeter/ni/cdaq9184_devif.py +0 -201
- egse/powermeter/ni/cdaq9184_protocol.py +0 -48
- egse/powermeter/ni/cdaq9184_ui.py +0 -544
- egse/powermeter/thorlabs/__init__.py +0 -25
- egse/powermeter/thorlabs/pm100a.py +0 -380
- egse/powermeter/thorlabs/pm100a.yaml +0 -132
- egse/powermeter/thorlabs/pm100a_cs.py +0 -136
- egse/powermeter/thorlabs/pm100a_devif.py +0 -127
- egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
- egse/powermeter/thorlabs/pm100a_ui.py +0 -725
- egse/process.py +0 -451
- egse/procman/__init__.py +0 -811
- egse/procman/cannot_start_process_popup.py +0 -43
- egse/procman/procman.yaml +0 -49
- egse/procman/procman_cs.py +0 -201
- egse/procman/procman_ui.py +0 -2081
- egse/protocol.py +0 -603
- egse/proxy.py +0 -522
- egse/randomwalk.py +0 -140
- egse/reg.py +0 -585
- egse/reload.py +0 -122
- egse/reprocess.py +0 -675
- egse/resource.py +0 -333
- egse/rst.py +0 -135
- egse/search.py +0 -182
- egse/serialdevice.py +0 -190
- egse/services.py +0 -212
- egse/services.yaml +0 -51
- egse/settings.py +0 -379
- egse/settings.yaml +0 -980
- egse/setup.py +0 -1180
- egse/shutter/__init__.py +0 -0
- egse/shutter/thorlabs/__init__.py +0 -19
- egse/shutter/thorlabs/ksc101.py +0 -205
- egse/shutter/thorlabs/ksc101.yaml +0 -105
- egse/shutter/thorlabs/ksc101_cs.py +0 -136
- egse/shutter/thorlabs/ksc101_devif.py +0 -201
- egse/shutter/thorlabs/ksc101_protocol.py +0 -69
- egse/shutter/thorlabs/ksc101_ui.py +0 -548
- egse/shutter/thorlabs/sc10.py +0 -82
- egse/shutter/thorlabs/sc10.yaml +0 -52
- egse/shutter/thorlabs/sc10_controller.py +0 -81
- egse/shutter/thorlabs/sc10_cs.py +0 -108
- egse/shutter/thorlabs/sc10_interface.py +0 -25
- egse/shutter/thorlabs/sc10_simulator.py +0 -30
- egse/simulator.py +0 -41
- egse/slack.py +0 -61
- egse/socketdevice.py +0 -218
- egse/sockets.py +0 -218
- egse/spw.py +0 -1479
- egse/stages/__init__.py +0 -12
- egse/stages/aerotech/ensemble.py +0 -247
- egse/stages/aerotech/ensemble.yaml +0 -205
- egse/stages/aerotech/ensemble_controller.py +0 -275
- egse/stages/aerotech/ensemble_cs.py +0 -110
- egse/stages/aerotech/ensemble_interface.py +0 -132
- egse/stages/aerotech/ensemble_parameters.py +0 -433
- egse/stages/aerotech/ensemble_simulator.py +0 -27
- egse/stages/aerotech/mgse_sim.py +0 -193
- egse/stages/arun/smd3.py +0 -111
- egse/stages/arun/smd3.yaml +0 -68
- egse/stages/arun/smd3_controller.py +0 -472
- egse/stages/arun/smd3_cs.py +0 -112
- egse/stages/arun/smd3_interface.py +0 -53
- egse/stages/arun/smd3_simulator.py +0 -27
- egse/stages/arun/smd3_stop.py +0 -16
- egse/stages/huber/__init__.py +0 -49
- egse/stages/huber/smc9300.py +0 -904
- egse/stages/huber/smc9300.yaml +0 -63
- egse/stages/huber/smc9300_cs.py +0 -178
- egse/stages/huber/smc9300_devif.py +0 -345
- egse/stages/huber/smc9300_protocol.py +0 -111
- egse/stages/huber/smc9300_sim.py +0 -547
- egse/stages/huber/smc9300_ui.py +0 -973
- egse/state.py +0 -173
- egse/statemachine.py +0 -274
- egse/storage/__init__.py +0 -1004
- egse/storage/persistence.py +0 -2295
- egse/storage/storage.yaml +0 -72
- egse/storage/storage_cs.py +0 -214
- egse/styles/dark.qss +0 -343
- egse/styles/default.qss +0 -48
- egse/synoptics/__init__.py +0 -412
- egse/synoptics/syn.yaml +0 -9
- egse/synoptics/syn_cs.py +0 -195
- egse/system.py +0 -1408
- egse/tcs/__init__.py +0 -14
- egse/tcs/tcs.py +0 -874
- egse/tcs/tcs.yaml +0 -14
- egse/tcs/tcs_cs.py +0 -202
- egse/tcs/tcs_devif.py +0 -292
- egse/tcs/tcs_protocol.py +0 -177
- egse/tcs/tcs_sim.py +0 -177
- egse/tcs/tcs_ui.py +0 -543
- egse/tdms.py +0 -171
- egse/tempcontrol/__init__.py +0 -23
- egse/tempcontrol/agilent/agilent34970.py +0 -109
- egse/tempcontrol/agilent/agilent34970.yaml +0 -44
- egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
- egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
- egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
- egse/tempcontrol/agilent/agilent34972.py +0 -111
- egse/tempcontrol/agilent/agilent34972.yaml +0 -44
- egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
- egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
- egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
- egse/tempcontrol/beaglebone/beaglebone.py +0 -342
- egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
- egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
- egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
- egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
- egse/tempcontrol/digalox/digalox.py +0 -107
- egse/tempcontrol/digalox/digalox.yaml +0 -36
- egse/tempcontrol/digalox/digalox_cs.py +0 -112
- egse/tempcontrol/digalox/digalox_protocol.py +0 -55
- egse/tempcontrol/keithley/__init__.py +0 -33
- egse/tempcontrol/keithley/daq6510.py +0 -662
- egse/tempcontrol/keithley/daq6510.yaml +0 -105
- egse/tempcontrol/keithley/daq6510_cs.py +0 -163
- egse/tempcontrol/keithley/daq6510_devif.py +0 -343
- egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
- egse/tempcontrol/keithley/daq6510_sim.py +0 -186
- egse/tempcontrol/lakeshore/__init__.py +0 -33
- egse/tempcontrol/lakeshore/lsci.py +0 -361
- egse/tempcontrol/lakeshore/lsci.yaml +0 -162
- egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
- egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
- egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
- egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
- egse/tempcontrol/ni/__init__.py +0 -0
- egse/tempcontrol/spid/spid.py +0 -109
- egse/tempcontrol/spid/spid.yaml +0 -81
- egse/tempcontrol/spid/spid_controller.py +0 -279
- egse/tempcontrol/spid/spid_cs.py +0 -136
- egse/tempcontrol/spid/spid_protocol.py +0 -107
- egse/tempcontrol/spid/spid_ui.py +0 -727
- egse/tempcontrol/srs/__init__.py +0 -22
- egse/tempcontrol/srs/ptc10.py +0 -875
- egse/tempcontrol/srs/ptc10.yaml +0 -227
- egse/tempcontrol/srs/ptc10_cs.py +0 -128
- egse/tempcontrol/srs/ptc10_devif.py +0 -118
- egse/tempcontrol/srs/ptc10_protocol.py +0 -42
- egse/tempcontrol/srs/ptc10_ui.py +0 -906
- egse/ups/apc/apc.py +0 -236
- egse/ups/apc/apc.yaml +0 -45
- egse/ups/apc/apc_cs.py +0 -101
- egse/ups/apc/apc_protocol.py +0 -125
- egse/user.yaml +0 -7
- egse/vacuum/beaglebone/beaglebone.py +0 -149
- egse/vacuum/beaglebone/beaglebone.yaml +0 -44
- egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
- egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
- egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
- egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
- egse/vacuum/instrutech/igm402.py +0 -92
- egse/vacuum/instrutech/igm402.yaml +0 -90
- egse/vacuum/instrutech/igm402_controller.py +0 -128
- egse/vacuum/instrutech/igm402_cs.py +0 -108
- egse/vacuum/instrutech/igm402_interface.py +0 -49
- egse/vacuum/instrutech/igm402_simulator.py +0 -36
- egse/vacuum/keller/kellerBus.py +0 -256
- egse/vacuum/keller/leo3.py +0 -102
- egse/vacuum/keller/leo3.yaml +0 -38
- egse/vacuum/keller/leo3_controller.py +0 -83
- egse/vacuum/keller/leo3_cs.py +0 -101
- egse/vacuum/keller/leo3_interface.py +0 -33
- egse/vacuum/mks/evision.py +0 -86
- egse/vacuum/mks/evision.yaml +0 -75
- egse/vacuum/mks/evision_cs.py +0 -101
- egse/vacuum/mks/evision_devif.py +0 -316
- egse/vacuum/mks/evision_interface.py +0 -60
- egse/vacuum/mks/evision_simulator.py +0 -24
- egse/vacuum/mks/evision_ui.py +0 -704
- egse/vacuum/pfeiffer/acp40.py +0 -87
- egse/vacuum/pfeiffer/acp40.yaml +0 -60
- egse/vacuum/pfeiffer/acp40_controller.py +0 -117
- egse/vacuum/pfeiffer/acp40_cs.py +0 -109
- egse/vacuum/pfeiffer/acp40_interface.py +0 -40
- egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
- egse/vacuum/pfeiffer/tc400.py +0 -113
- egse/vacuum/pfeiffer/tc400.yaml +0 -83
- egse/vacuum/pfeiffer/tc400_controller.py +0 -140
- egse/vacuum/pfeiffer/tc400_cs.py +0 -109
- egse/vacuum/pfeiffer/tc400_interface.py +0 -70
- egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
- egse/vacuum/pfeiffer/tpg261.py +0 -81
- egse/vacuum/pfeiffer/tpg261.yaml +0 -66
- egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
- egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
- egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
- egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
- egse/version.py +0 -174
- egse/visitedpositions.py +0 -398
- egse/windowing.py +0 -213
- egse/zmq/__init__.py +0 -28
- egse/zmq/spw.py +0 -160
- egse/zmq_ser.py +0 -41
- scripts/alerts/cold.yaml +0 -278
- scripts/alerts/example_alerts.yaml +0 -54
- scripts/alerts/transition.yaml +0 -14
- scripts/alerts/warm.yaml +0 -49
- scripts/analyse_n_fee_hk_data.py +0 -44
- scripts/check_hdf5_files.py +0 -192
- scripts/check_register_sync.py +0 -47
- scripts/create_hdf5_report.py +0 -295
- scripts/csl_model.py +0 -436
- scripts/csl_restore_setup.py +0 -230
- scripts/export-grafana-dashboards.py +0 -50
- scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
- scripts/fdir/fdir_table.yaml +0 -70
- scripts/fdir/fdir_test_recovery.py +0 -11
- scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
- scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
- scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
- scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
- scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
- scripts/fix_csv.py +0 -80
- scripts/n_fee_supply_voltage_calculation.py +0 -92
- scripts/playground.py +0 -30
- scripts/print_hdf5_hk_data.py +0 -68
- scripts/print_register_map.py +0 -43
- scripts/sron/commanding/control_heaters.py +0 -44
- scripts/sron/commanding/pumpdown.py +0 -46
- scripts/sron/commanding/set_pid_setpoint.py +0 -19
- scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
- scripts/sron/commanding/shutdown_pumps.py +0 -33
- scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
- scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
- scripts/sron/tm_gen/tm_gen_spid.py +0 -13
- scripts/update_operational_cgse.py +0 -268
- scripts/update_operational_cgse_old.py +0 -273
egse/reg.py
DELETED
|
@@ -1,585 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
This module defines classes and methods for working with the register
|
|
3
|
-
as defined in the N-FEE and the F-FEE. The register is basically a memory
|
|
4
|
-
map that is 32-bit aligned and contains configuration values for the
|
|
5
|
-
front-end electronics (FEE) of the PLATO cameras.
|
|
6
|
-
|
|
7
|
-
The class RegisterMap has all definitions of the registers as they are
|
|
8
|
-
defined for the two cameras in PLATO.
|
|
9
|
-
|
|
10
|
-
The class Register is basically a set of RegisterValue objects and defines
|
|
11
|
-
all the parameters for this registry in the registry map. A Registry is
|
|
12
|
-
a 32-bit field in the registry map.
|
|
13
|
-
|
|
14
|
-
The class RegisterValue is the definition of one value or parameter in
|
|
15
|
-
the register map and contains all the information needed to encode and
|
|
16
|
-
decode the register value.
|
|
17
|
-
|
|
18
|
-
The RegisterMap is initialized from a YAML configuration file that
|
|
19
|
-
is loaded for the N-FEE or F-FEE. The name of the configuration file is
|
|
20
|
-
read from the general Settings configuration file, i.e. the REGISTER_MAP
|
|
21
|
-
for the N-FEE and the F-FEE settings.
|
|
22
|
-
|
|
23
|
-
Examples:
|
|
24
|
-
```
|
|
25
|
-
reg_map: RegisterMap = RegisterMap('N-FEE')
|
|
26
|
-
|
|
27
|
-
# get window size for CCD#1
|
|
28
|
-
|
|
29
|
-
x_size = reg_map.get_value('reg_8_config', 'ccd1_win_size_x')
|
|
30
|
-
y_size = reg_map.get_value('reg_8_config', 'ccd1_win_size_y')
|
|
31
|
-
```
|
|
32
|
-
You can also use the shortcut and only specify the variable name as a key. This works as long
|
|
33
|
-
as the variable name is unique for the whole register map.
|
|
34
|
-
```
|
|
35
|
-
x_size = reg_map["ccd1_win_size_x"]
|
|
36
|
-
y_size = reg_map["ccd1_win_size_y"]
|
|
37
|
-
```
|
|
38
|
-
"""
|
|
39
|
-
import logging
|
|
40
|
-
from typing import List
|
|
41
|
-
from typing import Union
|
|
42
|
-
|
|
43
|
-
import numpy as np
|
|
44
|
-
from rich.table import Table
|
|
45
|
-
|
|
46
|
-
from egse.bits import beautify_binary
|
|
47
|
-
from egse.bits import clear_bit
|
|
48
|
-
from egse.bits import set_bit
|
|
49
|
-
from egse.bits import set_bits
|
|
50
|
-
from egse.settings import Settings
|
|
51
|
-
from egse.setup import SetupError
|
|
52
|
-
from egse.state import GlobalState
|
|
53
|
-
|
|
54
|
-
n_fee_settings = Settings.load("N-FEE")
|
|
55
|
-
|
|
56
|
-
LOGGER = logging.getLogger(__name__)
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
def decode_ccd_order(ccd_order: int) -> str:
|
|
60
|
-
"""
|
|
61
|
-
The readout order of the CCDs for the N-FEE. The `ccd_order` is the value that is returned when
|
|
62
|
-
reading the variable from the RegisterMap.
|
|
63
|
-
|
|
64
|
-
Example:
|
|
65
|
-
>>> decode_ccd_order(0x4E) # new convention
|
|
66
|
-
'ccd_order=0b01001110 ( 78) CCD1 -> CCD2 -> CCD3 -> CCD4'
|
|
67
|
-
|
|
68
|
-
Args:
|
|
69
|
-
ccd_order: 8-bit field decoded CCD order
|
|
70
|
-
|
|
71
|
-
Returns:
|
|
72
|
-
A string representing the readout order of the CCDs.
|
|
73
|
-
"""
|
|
74
|
-
msg = f"ccd_order=0b{ccd_order:08b} ({ccd_order:3d}) "
|
|
75
|
-
|
|
76
|
-
try:
|
|
77
|
-
ccd_id = GlobalState.setup.camera.fee.ccd_numbering.CCD_ID
|
|
78
|
-
except AttributeError:
|
|
79
|
-
raise SetupError("No entry in the setup for camera.fee.ccd_numbering.CCD_ID")
|
|
80
|
-
|
|
81
|
-
order = [f"{ccd_id[(ccd_order >> idx * 2) & 0b11]}" for idx in range(4)]
|
|
82
|
-
msg += " -> ".join(order)
|
|
83
|
-
return msg
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
def encode_ccd_order(ccd_order: List = None) -> int:
|
|
87
|
-
"""
|
|
88
|
-
Given a list of strings that represent the CCD ID, return the encoded ccd_order that can be
|
|
89
|
-
stored in the RegisterMap.
|
|
90
|
-
|
|
91
|
-
CCD IDs are "CCD1", "CCD2", "CCD3", "CCD4".
|
|
92
|
-
|
|
93
|
-
Example:
|
|
94
|
-
>>> encode_ccd_order(["CCD1", "CCD2", "CCD3", "CCD4"])
|
|
95
|
-
'0b1001110'
|
|
96
|
-
|
|
97
|
-
Args:
|
|
98
|
-
ccd_order: a list with strings that represent the CCD order
|
|
99
|
-
|
|
100
|
-
Returns:
|
|
101
|
-
The decoded value (int) of the CCD order.
|
|
102
|
-
"""
|
|
103
|
-
|
|
104
|
-
try:
|
|
105
|
-
ccd_id = GlobalState.setup.camera.fee.ccd_numbering.CCD_ID
|
|
106
|
-
except AttributeError:
|
|
107
|
-
raise SetupError("No entry in the setup for camera.fee.ccd_numbering.CCD_ID")
|
|
108
|
-
|
|
109
|
-
order = 0
|
|
110
|
-
keys_list = list(ccd_id.keys())
|
|
111
|
-
values_list = list(ccd_id.values())
|
|
112
|
-
for idx, name in enumerate(ccd_order):
|
|
113
|
-
ccd_id = keys_list[values_list.index(name)]
|
|
114
|
-
order |= ccd_id << idx * 2
|
|
115
|
-
|
|
116
|
-
return order
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
class Register:
|
|
120
|
-
"""
|
|
121
|
-
Represents a memory register as defined in the front-end electronics (FEE).
|
|
122
|
-
|
|
123
|
-
A Register is a 32-bit field in the FEE memory map and consists of a number
|
|
124
|
-
of sub-registers or RegisterValues.
|
|
125
|
-
"""
|
|
126
|
-
|
|
127
|
-
def __init__(self, name: str, address: int):
|
|
128
|
-
"""
|
|
129
|
-
Args:
|
|
130
|
-
name (str): the name of this register
|
|
131
|
-
address (int): the memory address of the register in the FEE memory map
|
|
132
|
-
(shall be 32-bit aligned)
|
|
133
|
-
Raises:
|
|
134
|
-
ValueError when address is not 32-bit aligned.
|
|
135
|
-
"""
|
|
136
|
-
if address & 0x03:
|
|
137
|
-
raise ValueError(f"The given memory address is not 4-byte (32-bit) aligned. "
|
|
138
|
-
f"[address=0x{address:02x}]")
|
|
139
|
-
self._name = name
|
|
140
|
-
self._address = address
|
|
141
|
-
self._values = {}
|
|
142
|
-
|
|
143
|
-
@property
|
|
144
|
-
def name(self):
|
|
145
|
-
"""The name of the 32-bit register."""
|
|
146
|
-
return self._name
|
|
147
|
-
|
|
148
|
-
@property
|
|
149
|
-
def address(self):
|
|
150
|
-
"""The memory address of the register in the N-FEE memory map."""
|
|
151
|
-
return self._address
|
|
152
|
-
|
|
153
|
-
def values(self):
|
|
154
|
-
"""Returns a view on the values in the register. This view is iterable."""
|
|
155
|
-
return self._values.values()
|
|
156
|
-
|
|
157
|
-
def keys(self):
|
|
158
|
-
"""Returns the top-level keys, i.e. register names."""
|
|
159
|
-
return self._values.keys()
|
|
160
|
-
|
|
161
|
-
def items(self):
|
|
162
|
-
"""Returns the keys-value pairs of the registers from this RegisterMap."""
|
|
163
|
-
return self._values.items()
|
|
164
|
-
|
|
165
|
-
def __setitem__(self, key, value):
|
|
166
|
-
self._values[key] = value
|
|
167
|
-
|
|
168
|
-
def __getitem__(self, key):
|
|
169
|
-
return self._values[key]
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
class RegisterValue:
|
|
173
|
-
"""
|
|
174
|
-
Represents one value from a memory register as used by the front-end electronics (FEE).
|
|
175
|
-
|
|
176
|
-
A register value can be a bit-field or an n-bit integer. A bit-field needs to be decoded
|
|
177
|
-
separately and is treated here as an integer.
|
|
178
|
-
"""
|
|
179
|
-
|
|
180
|
-
def __init__(self, register: Register, name: str, offset: int, width: int, default: int):
|
|
181
|
-
"""
|
|
182
|
-
Args:
|
|
183
|
-
register (Register): the register to which this value belongs (back reference)
|
|
184
|
-
name (str): the name of this register value
|
|
185
|
-
offset (int): the offset for the value in the 32-bit register [number of bits]
|
|
186
|
-
width (int): the width of the register value [number of bits]
|
|
187
|
-
default (int): the default register value
|
|
188
|
-
"""
|
|
189
|
-
self._register = register
|
|
190
|
-
self._name = name
|
|
191
|
-
self._offset = offset
|
|
192
|
-
self._width = width
|
|
193
|
-
self._default = default
|
|
194
|
-
|
|
195
|
-
def __repr__(self):
|
|
196
|
-
return (
|
|
197
|
-
f"Register('{self.register.name}', '{self.name}', "
|
|
198
|
-
f"0x{self.register.address:0X}, {self.offset}, {self.width}, {self.default})"
|
|
199
|
-
)
|
|
200
|
-
|
|
201
|
-
@property
|
|
202
|
-
def register(self):
|
|
203
|
-
return self._register
|
|
204
|
-
|
|
205
|
-
@property
|
|
206
|
-
def name(self):
|
|
207
|
-
return self._name
|
|
208
|
-
|
|
209
|
-
@property
|
|
210
|
-
def offset(self):
|
|
211
|
-
return self._offset
|
|
212
|
-
|
|
213
|
-
@property
|
|
214
|
-
def width(self):
|
|
215
|
-
return self._width
|
|
216
|
-
|
|
217
|
-
@property
|
|
218
|
-
def default(self):
|
|
219
|
-
return self._default
|
|
220
|
-
|
|
221
|
-
def get_value(self, data: bytes) -> int:
|
|
222
|
-
"""Read the value of this register variable from the given data.
|
|
223
|
-
|
|
224
|
-
The data argument shall be at least 4 bytes long. The register value is assumed to fall
|
|
225
|
-
within the first 32-bits of the data argument.
|
|
226
|
-
|
|
227
|
-
This method is usually used when a register has been read from the memory map and a
|
|
228
|
-
register value needs to be extracted. Alternatively, you can use the
|
|
229
|
-
`get_value(reg_name, var_name)` method of the RegisterMap class.
|
|
230
|
-
|
|
231
|
-
Args:
|
|
232
|
-
data (bytes): a register data field
|
|
233
|
-
|
|
234
|
-
Returns:
|
|
235
|
-
value: the value of the given register variable.
|
|
236
|
-
"""
|
|
237
|
-
data = int.from_bytes(data[:4], "big")
|
|
238
|
-
value = (data >> self.offset) & set_bits(0x0, (0, self.width))
|
|
239
|
-
return value
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
class RegisterMap:
|
|
243
|
-
"""
|
|
244
|
-
The RegisterMap keeps track of the complete register map of the front-end electronics.
|
|
245
|
-
|
|
246
|
-
When the given name argument is 'N-FEE' or 'F-FEE' the register map will be loaded from
|
|
247
|
-
the corresponding configuration file and the memory map will be initialized with the
|
|
248
|
-
default values. All other names will create an empty register map.
|
|
249
|
-
|
|
250
|
-
When no name is given, or another name than 'N-FEE' or 'F-FEE', an empty register is created
|
|
251
|
-
with the given name and the memory map will be initialised to zero.
|
|
252
|
-
|
|
253
|
-
The RegisterMap only contains the critical, general and housekeeping areas. The windowing
|
|
254
|
-
area is treated differently. That means the register map is 0x0800 (2048) bytes. The windowing
|
|
255
|
-
area is 0x0080_0000 bytes (8MB) in size.
|
|
256
|
-
|
|
257
|
-
"""
|
|
258
|
-
|
|
259
|
-
def __init__(self,
|
|
260
|
-
name: str = None, *,
|
|
261
|
-
size: int = 0,
|
|
262
|
-
memory_map: Union[bytearray, np.ndarray] = None):
|
|
263
|
-
"""
|
|
264
|
-
Note: size and memory_map are keyword-only arguments, i.e. these arguments
|
|
265
|
-
must be specified using the keyword.
|
|
266
|
-
|
|
267
|
-
Args:
|
|
268
|
-
name (str): the name for the register map.
|
|
269
|
-
size (int): the size of the memory buffer in bytes (32-bit aligned!)
|
|
270
|
-
memory_map: the memory map to be used for initialising the RegisterMap.
|
|
271
|
-
The type of the memory_map can be a bytearray or a Numpy ndarray.
|
|
272
|
-
"""
|
|
273
|
-
size = size or 0x0000_0800
|
|
274
|
-
self._memory_map = bytearray(size)
|
|
275
|
-
if name in ("N-FEE", "F-FEE"):
|
|
276
|
-
self._name = name.upper()
|
|
277
|
-
self._register_map = self._load_register_map()
|
|
278
|
-
if isinstance(memory_map, np.ndarray):
|
|
279
|
-
memory_map = bytearray(memory_map.tobytes())
|
|
280
|
-
self._init_memory_map(memory_map)
|
|
281
|
-
else:
|
|
282
|
-
self._name = name
|
|
283
|
-
self._register_map = {}
|
|
284
|
-
|
|
285
|
-
def __iter__(self):
|
|
286
|
-
return self._register_map.__iter__()
|
|
287
|
-
|
|
288
|
-
def __str__(self):
|
|
289
|
-
msg = f"Register Map for {self._name}\n"
|
|
290
|
-
for reg_name in self:
|
|
291
|
-
reg = self.get_register(reg_name)
|
|
292
|
-
msg += f"{reg_name}:\n"
|
|
293
|
-
for var_name in reg.keys():
|
|
294
|
-
msg += f" {var_name}={self.get_value(reg.name, var_name)}\n"
|
|
295
|
-
return msg
|
|
296
|
-
|
|
297
|
-
def __rich__(self):
|
|
298
|
-
|
|
299
|
-
# Create a table with — for each HK parameter — the HEX value, the binary, the decimal, and the
|
|
300
|
-
# calibrated value.
|
|
301
|
-
#
|
|
302
|
-
# To calibrate a value:
|
|
303
|
-
# * get the list of parameter names for temperatures from
|
|
304
|
-
# We don't want this!!!
|
|
305
|
-
# supply_voltage_calibration = GlobalState.setup.camera.fee.calibration.supply_voltages
|
|
306
|
-
# temperature_calibration = GlobalState.setup.camera.fee.calibration.temperatures
|
|
307
|
-
|
|
308
|
-
table = Table("Register", "Parameter", "Value (int)", "Value (hex)")
|
|
309
|
-
|
|
310
|
-
for reg_name in self:
|
|
311
|
-
reg = self.get_register(reg_name)
|
|
312
|
-
for var_name in reg.keys():
|
|
313
|
-
value = self.get_value(reg.name, var_name)
|
|
314
|
-
table.add_row(reg_name, var_name, str(value), hex(value))
|
|
315
|
-
|
|
316
|
-
return table
|
|
317
|
-
|
|
318
|
-
def get_memory_map_as_ndarray(self) -> np.ndarray:
|
|
319
|
-
"""
|
|
320
|
-
Returns the memory map of the RegisterMap object. This memory map represents the memory
|
|
321
|
-
area that is used in the N-FEE to store the configuration variables.
|
|
322
|
-
|
|
323
|
-
Returns:
|
|
324
|
-
A Numpy array of `dtype=uint8`.
|
|
325
|
-
"""
|
|
326
|
-
return np.frombuffer(self._memory_map.copy(), dtype=np.uint8)
|
|
327
|
-
|
|
328
|
-
def _init_memory_map(self, memory_map: bytearray = None):
|
|
329
|
-
if memory_map is None:
|
|
330
|
-
for reg in self._register_map.values():
|
|
331
|
-
for var in reg.values():
|
|
332
|
-
self.set_value(reg.name, var.name, var.default)
|
|
333
|
-
else:
|
|
334
|
-
self._memory_map = memory_map
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
def _load_register_map(self) -> dict:
|
|
338
|
-
|
|
339
|
-
# This is not a good idea, the RegisterMap is not really instantiated in a critical context,
|
|
340
|
-
# but this might happen. Instantiation of this class should be fast.
|
|
341
|
-
|
|
342
|
-
fee_reg = GlobalState.setup.camera.fee.register_map
|
|
343
|
-
|
|
344
|
-
register_map = {}
|
|
345
|
-
|
|
346
|
-
for reg_name in fee_reg:
|
|
347
|
-
# each register has the 'reg_address' as a mandatory field
|
|
348
|
-
reg = Register(reg_name, fee_reg[reg_name]["reg_address"])
|
|
349
|
-
for var_name in fee_reg[reg_name]:
|
|
350
|
-
if var_name == "reg_address":
|
|
351
|
-
continue
|
|
352
|
-
offset, width, default = fee_reg[reg_name][var_name]
|
|
353
|
-
reg[var_name] = RegisterValue(reg, var_name, offset, width, default)
|
|
354
|
-
register_map[reg_name] = reg
|
|
355
|
-
|
|
356
|
-
return register_map
|
|
357
|
-
|
|
358
|
-
def get_value(self, reg_name: str, var_name: str) -> int:
|
|
359
|
-
"""
|
|
360
|
-
Return the current value for the given register variable name.
|
|
361
|
-
|
|
362
|
-
This is equivalent to:
|
|
363
|
-
|
|
364
|
-
```value = reg_map[(reg_name, var_name)]```
|
|
365
|
-
|
|
366
|
-
Args:
|
|
367
|
-
reg_name (str): the name of the register
|
|
368
|
-
var_name (str): the name of the sub-register, i.e. the name of the value
|
|
369
|
-
|
|
370
|
-
Returns:
|
|
371
|
-
value: the value of the variable from the register map.
|
|
372
|
-
|
|
373
|
-
Raises:
|
|
374
|
-
KeyError: when the var_name doesn't match a RegisterValue in the Register for reg_name.
|
|
375
|
-
"""
|
|
376
|
-
reg: Register = self._register_map[reg_name]
|
|
377
|
-
var: RegisterValue = reg[var_name]
|
|
378
|
-
|
|
379
|
-
data = self._memory_map[reg.address : reg.address + 4]
|
|
380
|
-
value = int.from_bytes(data, "big")
|
|
381
|
-
value = (value >> var.offset) & set_bits(0x0, (0, var.width))
|
|
382
|
-
|
|
383
|
-
return value
|
|
384
|
-
|
|
385
|
-
def set_value(self, reg_name: str, var_name: str, value: int) -> None:
|
|
386
|
-
"""
|
|
387
|
-
Set the value for the given register variable name.
|
|
388
|
-
|
|
389
|
-
This is equivalent to:
|
|
390
|
-
|
|
391
|
-
```reg_map[(reg_name, var_name)] = value```
|
|
392
|
-
|
|
393
|
-
Args:
|
|
394
|
-
reg_name (str): the name of the register
|
|
395
|
-
var_name (str): the name of the sub-register, i.e. the name of the value
|
|
396
|
-
value (int): the new register value
|
|
397
|
-
|
|
398
|
-
Raises:
|
|
399
|
-
KeyError: when the var_name doesn't match a RegisterValue in the Register for reg_name.
|
|
400
|
-
"""
|
|
401
|
-
reg: Register = self._register_map[reg_name]
|
|
402
|
-
var: RegisterValue = reg[var_name]
|
|
403
|
-
|
|
404
|
-
orig_value = temp = int.from_bytes(self._memory_map[reg.address : reg.address + 4], "big")
|
|
405
|
-
start = var.offset
|
|
406
|
-
for bit in range(var.width):
|
|
407
|
-
temp = (
|
|
408
|
-
set_bit(temp, start + bit) if value & (1 << bit) else clear_bit(temp, start + bit)
|
|
409
|
-
)
|
|
410
|
-
self._memory_map[reg.address : reg.address + 4] = temp.to_bytes(4, "big")
|
|
411
|
-
if temp != orig_value:
|
|
412
|
-
LOGGER.debug(
|
|
413
|
-
f"set new value for register {reg_name}:{var_name}: "
|
|
414
|
-
f"0b{beautify_binary(temp, size=32)} (was 0b{beautify_binary(orig_value, size=32)})"
|
|
415
|
-
)
|
|
416
|
-
|
|
417
|
-
def add_register(self, reg: Register):
|
|
418
|
-
"""
|
|
419
|
-
Add a new Register to the register map and set the default values for all its variables.
|
|
420
|
-
"""
|
|
421
|
-
self._register_map[reg.name] = reg
|
|
422
|
-
for var in reg.values():
|
|
423
|
-
self.set_value(reg.name, var.name, var.default)
|
|
424
|
-
|
|
425
|
-
def get_register(self, reg_name: str) -> Register:
|
|
426
|
-
"""Returns the Register for the given name.
|
|
427
|
-
|
|
428
|
-
Args:
|
|
429
|
-
reg_name (str): the name of a Register in the RegisterMap
|
|
430
|
-
|
|
431
|
-
Returns:
|
|
432
|
-
register: the Register for the given name.
|
|
433
|
-
|
|
434
|
-
Raises:
|
|
435
|
-
KeyError: when no Register with the given name exists in the RegisterMap
|
|
436
|
-
"""
|
|
437
|
-
|
|
438
|
-
# FIXME:
|
|
439
|
-
# This exposes a Register that is part of the RegisterMap and allows to make changes
|
|
440
|
-
# that can potentially invalidate the RegisterMap!
|
|
441
|
-
# Should we return a copy of the Register?
|
|
442
|
-
return self._register_map[reg_name]
|
|
443
|
-
|
|
444
|
-
def get_register_data(self, reg_name: str) -> bytes:
|
|
445
|
-
"""Returns the value of the register variable. A 32-bit bytes array."""
|
|
446
|
-
reg: Register = self._register_map[reg_name]
|
|
447
|
-
return self._memory_map[reg.address : reg.address + 4]
|
|
448
|
-
|
|
449
|
-
def set_register_data(self, reg_name: str, data: bytes) -> None:
|
|
450
|
-
"""Writes the register data into the memory map."""
|
|
451
|
-
reg: Register = self._register_map[reg_name]
|
|
452
|
-
self._memory_map[reg.address : reg.address + 4] = data
|
|
453
|
-
|
|
454
|
-
def get_data(self, address: int, length: int) -> bytes:
|
|
455
|
-
"""
|
|
456
|
-
Read a range of bytes from the FEE memory map.
|
|
457
|
-
|
|
458
|
-
Args:
|
|
459
|
-
address: start address from where to start reading
|
|
460
|
-
length: the number of bytes to read
|
|
461
|
-
|
|
462
|
-
Returns:
|
|
463
|
-
bytes from the requested address range.
|
|
464
|
-
|
|
465
|
-
Raises:
|
|
466
|
-
IndexError: when the address range falls out of the allowed range.
|
|
467
|
-
"""
|
|
468
|
-
size = len(self._memory_map)
|
|
469
|
-
if 0x0000_0000 <= address <= size - length:
|
|
470
|
-
return self._memory_map[address : address + length]
|
|
471
|
-
else:
|
|
472
|
-
raise IndexError(
|
|
473
|
-
f"The given address + length ({address} + {length} = {address+length}) fall out "
|
|
474
|
-
f"of the addressable range of the memory map."
|
|
475
|
-
)
|
|
476
|
-
|
|
477
|
-
def set_data(self, address: int, data: bytes, length: int = 4) -> None:
|
|
478
|
-
"""
|
|
479
|
-
Writes the register data into the memory map.
|
|
480
|
-
|
|
481
|
-
This method can be used to replace single register values or even the complete register.
|
|
482
|
-
By default, one single register will be set, i.e. 4 bytes.
|
|
483
|
-
|
|
484
|
-
Args:
|
|
485
|
-
address (int): start address from where to start writing (32-bit aligned)
|
|
486
|
-
data (bytes): the data to write to the memory map
|
|
487
|
-
length (int): the length of the data [default=4 bytes]
|
|
488
|
-
|
|
489
|
-
Raises:
|
|
490
|
-
ValueError when address is not 32-bit aligned.
|
|
491
|
-
"""
|
|
492
|
-
if address & 0x03:
|
|
493
|
-
raise ValueError(
|
|
494
|
-
f"The given memory address is not 4-byte (32-bit) aligned. "
|
|
495
|
-
f"[address=0x{address:02x}]"
|
|
496
|
-
)
|
|
497
|
-
self._memory_map[address : address + length] = data[:length]
|
|
498
|
-
|
|
499
|
-
def __getitem__(self, item):
|
|
500
|
-
"""Return the current value for the given register variable.
|
|
501
|
-
This equivalent to ``value = reg_map[reg_name, var_name]``.
|
|
502
|
-
"""
|
|
503
|
-
if isinstance(item, str):
|
|
504
|
-
return self._get_unambiguous_value(item)
|
|
505
|
-
if not isinstance(item, (tuple, list)):
|
|
506
|
-
raise KeyError(f"Expected a tuple or list with register name and variable name.")
|
|
507
|
-
return self.get_value(item[0], item[1])
|
|
508
|
-
|
|
509
|
-
def __setitem__(self, key, value):
|
|
510
|
-
"""Set the value for the given register variable.
|
|
511
|
-
This equivalent to ``reg_map[reg_name, var_name] = value``.
|
|
512
|
-
"""
|
|
513
|
-
if not isinstance(key, (tuple, list)):
|
|
514
|
-
raise KeyError(
|
|
515
|
-
f"Expected the 'key' argument to be a tuple or list with the register name "
|
|
516
|
-
f"and the variable name as elements.")
|
|
517
|
-
self.set_value(key[0], key[1], value)
|
|
518
|
-
|
|
519
|
-
def _get_unambiguous_value(self, item):
|
|
520
|
-
value = [self.get_value(reg_name, key)
|
|
521
|
-
for reg_name in self
|
|
522
|
-
for key in self.get_register(reg_name).keys()
|
|
523
|
-
if key == item]
|
|
524
|
-
|
|
525
|
-
if len(value) == 0:
|
|
526
|
-
raise KeyError(f"'{item}' is not a valid variable name in this Register map.")
|
|
527
|
-
if len(value) > 1:
|
|
528
|
-
raise KeyError(f"'{item}' is ambiguous and used in {len(value)} registers. Use the 'get_value()' method.")
|
|
529
|
-
|
|
530
|
-
return value[0]
|
|
531
|
-
|
|
532
|
-
def as_dict(self, flatten: bool = False):
|
|
533
|
-
"""
|
|
534
|
-
Returns the RegisterMap as a dictionary. The register map is a nested data structure where
|
|
535
|
-
each register contains a number of variables. When represented as a dictionary, the first
|
|
536
|
-
level keys are the register names, the seconds level are the variable names and their
|
|
537
|
-
values. When the registered map is returned as a flattened dict, the keys are constructed
|
|
538
|
-
from the register name and the variable name, separated by a colon.
|
|
539
|
-
|
|
540
|
-
Args:
|
|
541
|
-
flatten (bool): return the RegisterMap as a flattened dictionary
|
|
542
|
-
Returns:
|
|
543
|
-
The RegisterMap as an (optionally flattened) dictionary.
|
|
544
|
-
"""
|
|
545
|
-
_dict = {}
|
|
546
|
-
if flatten:
|
|
547
|
-
for reg in self._register_map.values():
|
|
548
|
-
for var in reg.values():
|
|
549
|
-
value = self.get_value(reg.name, var.name)
|
|
550
|
-
_dict[f"{reg.name}:{var.name}"] = value
|
|
551
|
-
else:
|
|
552
|
-
for reg in self._register_map.values():
|
|
553
|
-
vars_dict = {}
|
|
554
|
-
for var in reg.values():
|
|
555
|
-
value = self.get_value(reg.name, var.name)
|
|
556
|
-
vars_dict[var.name] = value
|
|
557
|
-
_dict[reg.name] = vars_dict
|
|
558
|
-
|
|
559
|
-
return _dict
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
def compare_register_maps(reg_map_1: RegisterMap, reg_map_2: RegisterMap):
|
|
563
|
-
"""
|
|
564
|
-
Compare two Register maps by content and variable names. The Register map is iterated over all
|
|
565
|
-
registers and variables in registers and their names and values are compared element wise.
|
|
566
|
-
|
|
567
|
-
When you only need to check the content, it might be better to use the
|
|
568
|
-
`get_memory_map_as_ndarray()` method and compare the numpy arrays element wise, e.g.
|
|
569
|
-
|
|
570
|
-
Args:
|
|
571
|
-
reg_map_1 (RegisterMap): a register map
|
|
572
|
-
reg_map_2 (RegisterMap): anothe register map
|
|
573
|
-
|
|
574
|
-
Returns:
|
|
575
|
-
A list with a description of the changes for each difference.
|
|
576
|
-
"""
|
|
577
|
-
d1 = reg_map_1.as_dict(flatten=True)
|
|
578
|
-
d2 = reg_map_2.as_dict(flatten=True)
|
|
579
|
-
|
|
580
|
-
diff = [
|
|
581
|
-
f"{k}: 0x{d1[k]:02x} -> 0x{d2[k]:02x}"
|
|
582
|
-
for k, _ in set(d2.items()) - set(d1.items())
|
|
583
|
-
]
|
|
584
|
-
|
|
585
|
-
return sorted(diff)
|
egse/reload.py
DELETED
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
A slightly better approach to reloading modules and function than the standard importlib.reload()
|
|
3
|
-
function. The functions in this modules are for interactive used in a Python REPL.
|
|
4
|
-
|
|
5
|
-
* reload_module(module): reloads the given module and all its parent modules
|
|
6
|
-
* reload_function(func): reloads and returns the given function
|
|
7
|
-
|
|
8
|
-
NOTE: It might be possible that after the module or function has been reloaded that an extra
|
|
9
|
-
import is needed to import the proper module attributes in your namespace.
|
|
10
|
-
|
|
11
|
-
Module dependency
|
|
12
|
-
|
|
13
|
-
When you make a change in a module or function that you are not calling directly, but call
|
|
14
|
-
through another function from another module, you need to reload the module where you made
|
|
15
|
-
the change and, after that, reload the function that calls that module.
|
|
16
|
-
|
|
17
|
-
Example:
|
|
18
|
-
|
|
19
|
-
* module x.a contains function func_a
|
|
20
|
-
* module x.b contains function func_b which calls func_a
|
|
21
|
-
|
|
22
|
-
when you make a change in func_a you have to relaod the module x.a and then reload
|
|
23
|
-
the function func_b:
|
|
24
|
-
|
|
25
|
-
>>> from x.b import func_b
|
|
26
|
-
>>> func_b()
|
|
27
|
-
# make some changes in func_a
|
|
28
|
-
>>> reload_module('x.a')
|
|
29
|
-
>>> func_b = reload_function(func_b)
|
|
30
|
-
>>> func_b() # will show the changes done in func_a
|
|
31
|
-
|
|
32
|
-
"""
|
|
33
|
-
import importlib
|
|
34
|
-
import itertools
|
|
35
|
-
import typing
|
|
36
|
-
import types
|
|
37
|
-
|
|
38
|
-
import rich
|
|
39
|
-
|
|
40
|
-
from egse.exceptions import Abort
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
def reload_module(module: typing.Union[types.ModuleType, str], walk: bool = True):
|
|
44
|
-
"""
|
|
45
|
-
Reloads the given module and all its parent modules. The modules will be reloaded starting
|
|
46
|
-
from their top-level module. Reloading the 'egse.hexapod.symetry.puna' module will reload
|
|
47
|
-
'egse', 'egse.hexapod', 'egse.hexapod.symetry', and 'egse.hexapod.symetry.puna' in that order.
|
|
48
|
-
|
|
49
|
-
NOTE: If you pass the module argument as a module, make sure the top level module is
|
|
50
|
-
imported in your session or you will get a NameError. To prevent this (if you don't want
|
|
51
|
-
to import the top-level module, pass the module as a string.
|
|
52
|
-
|
|
53
|
-
Usage:
|
|
54
|
-
>>> import egse
|
|
55
|
-
>>> reload_module(egse.system)
|
|
56
|
-
or
|
|
57
|
-
>>> reload_module('egse.system')
|
|
58
|
-
|
|
59
|
-
Args:
|
|
60
|
-
module: The module that needs to be reloaded
|
|
61
|
-
walk: walk up the module hierarchy and import all modules [default=True]
|
|
62
|
-
|
|
63
|
-
"""
|
|
64
|
-
full_module_name = module.__name__ if isinstance(module, types.ModuleType) else module
|
|
65
|
-
|
|
66
|
-
module_names = itertools.accumulate(full_module_name.split('.'),
|
|
67
|
-
lambda x, y: f"{x}.{y}") if walk else [full_module_name]
|
|
68
|
-
|
|
69
|
-
for module_name in module_names:
|
|
70
|
-
try:
|
|
71
|
-
module = importlib.import_module(module_name)
|
|
72
|
-
importlib.reload(module)
|
|
73
|
-
except (Exception,) as exc:
|
|
74
|
-
rich.print(f'[red]Failed to reload {module_name}[/red], {exc=}')
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
def reload_function(func: types.FunctionType):
|
|
78
|
-
"""
|
|
79
|
-
Reloads and returns the given function. In order for this to work, you should catch the
|
|
80
|
-
return value to replace the given function with its reloaded counterpart.
|
|
81
|
-
|
|
82
|
-
This will also work if you import the function again instead of catching it.
|
|
83
|
-
|
|
84
|
-
NOTE: that this mechanism doesn't work for functions that were defined in the __main__ module.
|
|
85
|
-
|
|
86
|
-
Usage:
|
|
87
|
-
func = reload_function(func)
|
|
88
|
-
|
|
89
|
-
reload_function(func)
|
|
90
|
-
from egse.some_module import func
|
|
91
|
-
|
|
92
|
-
Args:
|
|
93
|
-
func: the function that needs to be reloaded
|
|
94
|
-
|
|
95
|
-
Returns:
|
|
96
|
-
The reloaded function.
|
|
97
|
-
|
|
98
|
-
Raises:
|
|
99
|
-
An Abort when the function is not the proper type or when the function is define
|
|
100
|
-
in the __main__ module.
|
|
101
|
-
"""
|
|
102
|
-
|
|
103
|
-
# Why do I raise an Abort instead of just printing a message and returning?
|
|
104
|
-
#
|
|
105
|
-
# The function is usually called catching the return value and replacing the same function with
|
|
106
|
-
# its reloaded counterpart. If we would just return (None) when an error occurs, the original
|
|
107
|
-
# function will be overwritten with None. Raising an Exception leaves the original as it was
|
|
108
|
-
# before the call.
|
|
109
|
-
|
|
110
|
-
if not isinstance(func, types.FunctionType):
|
|
111
|
-
raise Abort(f"The 'func' argument shall be a function, not {type(func)}")
|
|
112
|
-
|
|
113
|
-
module_name = func.__module__
|
|
114
|
-
func_name = func.__name__
|
|
115
|
-
|
|
116
|
-
if module_name == '__main__':
|
|
117
|
-
raise Abort("Cannot reload a function that is defined in the __main__ module.")
|
|
118
|
-
|
|
119
|
-
reload_module(module_name)
|
|
120
|
-
|
|
121
|
-
module = __import__(module_name, fromlist=[func_name])
|
|
122
|
-
return getattr(module, func_name)
|