Utilities to edit PTR files.
Project description
Ptr Editor
Documentation: https://juice-soc-public.io.esa.int/python/ptr-editor/main/
Source Code: https://juice-soc-public.io.esa.int/python/ptr-editor/main/
PyPI: https://pypi.org/project/ptr-editor/
Installation
Basic Installation
pip install ptr-editor
Optional Features
CLI Module
To use the command-line interface (optional), install with CLI dependencies:
pip install "ptr-editor[cli]"
Then you can use commands like:
ptr-editor validate path/to/file.ptx
Configuration
Logging
By default, logging is disabled in non-Jupyter environments and set to WARNING level in Jupyter notebooks. You can configure the log level using a .env file:
-
Copy the example environment file:
cp .env.example .env
-
Edit
.envand set your desired log level:PTR_EDITOR_LOG_LEVEL=INFO
Valid log levels are: TRACE, DEBUG, INFO, SUCCESS, WARNING, ERROR, CRITICAL
Alternatively, you can set the environment variable directly:
export PTR_EDITOR_LOG_LEVEL=DEBUG
Or in Python before importing ptr_editor:
import os
os.environ["PTR_EDITOR_LOG_LEVEL"] = "DEBUG"
import ptr_editor
Development
- Clone this repository
- Requirements:
- uv
- Python 3.10+
- Create a virtual environment and install the dependencies, by:
cd ptr-editor
uv sync --all-groups
Running
The package is mainly intended to be used as a library within jupyter notebooks or python scripts.
To quickly start a jupyter notebook with the package installed, you can use:
uv run jupyter lab tutorial
note: for this to work you need to have installed the package with uv as above.
Testing
uv run pytest
Documentation
Documentation is currently available here, as part of the tutorials verion.
to be updated: The documentation is automatically generated from the content of the docs directory and from the docstrings of the public signatures of the source code. The documentation is updated and published as a Github Pages page automatically as part each release.
Tutorials
A collection of example notebooks is available in the tutorial folder and distributed in Gitlab Pages though the CI. They can be rebuild them locally with:
uv run --group tutorials jupyter book start
Releasing
Manual release
Releases are done with the command, e.g. incrementing patch:
uv run just bump patch
# also push, of course:
git push origin main --tags
this will update the changelog, commit it, and make a corresponding tag.
as the CI is not yet configured for publish on pypi it can be done by hand:
uv build
uv publish --build path/to/wheel
Automatic release - to be fixed
Trigger the Draft release workflow (press Run workflow). This will update the changelog & version and create a GitHub release which is in Draft state.
Find the draft release from the GitHub releases and publish it. When a release is published, it'll trigger release workflow which creates PyPI release and deploys updated documentation.
Updating with copier
To update the skeleton of the project using copier:
uvx copier update --defaults
Pre-commit
Pre-commit hooks run all the auto-formatting (ruff format), linters (e.g. ruff and mypy), and other quality
checks to make sure the changeset is in good shape before a commit/push happens.
You can install the hooks with (runs for each commit):
pre-commit install
Or if you want them to run only for each push:
pre-commit install -t pre-push
Or if you want e.g. want to run all checks manually for all files:
pre-commit run --all-files
Development Tools
This project was developed with assistance from AI tools, particularly Claude Sonnet 3.5, which was used extensively for:
- Initial boilerplate code creation
- Bootstrapping the test suite
- General text file editing and modification
- Code refactoring and improvements
While AI tools provided significant assistance in accelerating development, all code has been reviewed, tested, and integrated by human developers.
This project was generated using a fork of the wolt-python-package-cookiecutter template.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ptr_editor-0.2.0.tar.gz.
File metadata
- Download URL: ptr_editor-0.2.0.tar.gz
- Upload date:
- Size: 286.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c38b094a5c4850f3df6002a258d7711d35ff1168aea2ae5190b58b03d2a2d913
|
|
| MD5 |
2fca71d72104522358ddc1902036bc2b
|
|
| BLAKE2b-256 |
2a8f3bbde27f314fabf7a2c22e17f34dbdc25ba828d8970345bb0cfd146040fb
|
File details
Details for the file ptr_editor-0.2.0-py3-none-any.whl.
File metadata
- Download URL: ptr_editor-0.2.0-py3-none-any.whl
- Upload date:
- Size: 342.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7b18573e4eb41c45f1f7d1c0cd2606d2d854e6adfc92b19244d1a9e62c15f0ff
|
|
| MD5 |
f174c0554ccf442b5c40db3f11df5f5a
|
|
| BLAKE2b-256 |
9c77ccfd890d0cd826c06538a582589c234700f81d55ce97b736ee595e306af0
|