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.1.1.tar.gz (286.9 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.1.1-py3-none-any.whl (342.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ptr_editor-0.1.1.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

Hashes for ptr_editor-0.1.1.tar.gz
Algorithm Hash digest
SHA256 c89ced06c9f8d03247488cdc99f8adf60d7a0f16317e46f8a2a539ecff6d746c
MD5 2a615f48eff5a233b73aaa080291a229
BLAKE2b-256 d3a82ecfc9803f337c8d19320a849dd19ff957bf2a74b63018bb7c436761171e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ptr_editor-0.1.1-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

Hashes for ptr_editor-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d02de2f6bf21f4579c54fd67d38d77d9ac6cbae781bf28ec24e8d7261817a59d
MD5 57a0a567426d1abd082e3121fb63d4bd
BLAKE2b-256 4e6fd1a67b936d523b78daa6d14df77e456d6738169e65ed6b70a3351602826f

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