Skip to main content

Utilities to edit PTR files.

Project description

Ptr Editor

PyPI PyPI - Python Version PyPI - License Coookiecutter - Wolt


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:

  1. Copy the example environment file:

    cp .env.example .env
    
  2. Edit .env and 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

ptr_editor-0.4.1.tar.gz (352.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ptr_editor-0.4.1-py3-none-any.whl (419.3 kB view details)

Uploaded Python 3

File details

Details for the file ptr_editor-0.4.1.tar.gz.

File metadata

  • Download URL: ptr_editor-0.4.1.tar.gz
  • Upload date:
  • Size: 352.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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

Hashes for ptr_editor-0.4.1.tar.gz
Algorithm Hash digest
SHA256 85015261e48397c2348affed9a5e54cb054d9973cd24e9868ed0800f4bbe618f
MD5 cb1d58014652844d30068477893a2039
BLAKE2b-256 d4130bad445a67b79b763adaea3a1489e41a08687908fd9fc80df2d0752f09d4

See more details on using hashes here.

File details

Details for the file ptr_editor-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: ptr_editor-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 419.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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

Hashes for ptr_editor-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b9eaa96628e5444f7b84a4837a975799726892e08fe25f244667bddccb197625
MD5 8468c578a3a3d672b5b2cac5e3d3d472
BLAKE2b-256 c15f83d221c238ce5e719b8d6e6436391f37e896b2d58de42af3caa956e09533

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page