vanous/python-psn
Python only parsing library for PSN, PosiStageNet https://posistage.net/
| .github/workflows | initial commit | |
| examples | Add start/stop methods, complete trigger example | |
| pypsn | Add start/stop methods, complete trigger example | |
| tests | Add info packet data, new tests, new test data | |
| .gitignore | initial commit | |
| conftest.py | initial commit | |
| LICENSE | initial commit | |
| README.md | Add start/stop methods, complete trigger example | |
| setup.py | initial commit | |
python-psn
Python only parsing library for PSN V2 - PosiStageNet
PSN specification as per GitHub repo
Installation
To install from git, run pip:
python -m pip install https://codeload.github.com/open-stage/python-psn/zip/refs/heads/master
Usage
import pypsn
# define a callback function
def callback_function(data):
if isinstance(data, pypsn_module.psn_data_packet): # packet type: psn.psn_data_packet
for tracker in data.trackers: # loop through all trackers
print(tracker.pos) # print the received coordinates
if isinstance(data, pypsn_module.psn_info_packet): # packet type: psn.psn_info_packet
print(data.name) # print server name
for tracker in data.trackers: # loop through all trackers
print(tracker.tracker_name) # print the received tracker name
# provide a callback function and an IP address
receiver = pypsn.receiver(callback_function, "10.0.0.1")
receiver.start() # start the receiving thread
receiver.stop() # stop receiving
See examples folder for some more examples.
Development, status
- Supporting PSN V2
- Parsing only, not sending
- Using threading module
- Linux, Windows and macOS tested
- Typed
- Initial pytest testing provided together with CI/CD setup
Type hints
- At this point, the
--no-strict-optionalis needed for mypy tests to pass:
mypy pypsn/*py --pretty --no-strict-optional
Format
- to format, use
black
Testing
- to test, use
pytest - to test typing with mypy use
pytest --mypy -m mypy pypsn/*py