Skip to main content

PNG handler for embedding and extracting XMP packets in Swarmauri runtimes.

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_xmp_png


swarmauri_xmp_png

swarmauri_xmp_png packages the production-grade PNGXMP handler. It reads, writes, and removes XMP packets stored in uncompressed iTXt chunks that follow Adobe's keyword guidance, making it immediately compatible with downstream asset pipelines.

Features

  • Registry-ready – inherits from EmbedXmpBase so Swarmauri's dynamic registry can auto-discover the handler.
  • Spec compliant – emits iTXt chunks with the XML:com.adobe.xmp keyword and UTF-8 payloads.
  • Safety guards_ensure_xml performs a minimal RDF/XML check before embedding metadata.

Installation

Choose the tool that matches your workflow:

# pip
pip install swarmauri_xmp_png

# uv
uv add swarmauri_xmp_png

Usage

from pathlib import Path

from swarmauri_xmp_png import PNGXMP

handler = PNGXMP()
image_path = Path("example.png")
xmp_packet = """<x:xmpmeta xmlns:x='adobe:ns:meta/'><rdf:RDF>...</rdf:RDF></x:xmpmeta>"""

# Embed an XMP packet
updated_bytes = handler.write_xmp(image_path.read_bytes(), xmp_packet)
image_path.write_bytes(updated_bytes)

# Verify the packet can be recovered
restored_xml = handler.read_xmp(updated_bytes)
print(restored_xml)

# Remove XMP if necessary
clean_bytes = handler.remove_xmp(updated_bytes)

Why it works

  • Dynamic discovery – the handler is automatically registered with DynamicBase consumers via inheritance.
  • Standards alignment – PNG metadata lives in an iTXt chunk per ISO 16684 guidance.
  • Predictable behavior – read/write/remove flows mirror each other so pipelines remain idempotent.

Project Resources

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

swarmauri_xmp_png-0.1.1.dev35.tar.gz (3.4 kB view details)

Uploaded Source

Built Distribution

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

swarmauri_xmp_png-0.1.1.dev35-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file swarmauri_xmp_png-0.1.1.dev35.tar.gz.

File metadata

  • Download URL: swarmauri_xmp_png-0.1.1.dev35.tar.gz
  • Upload date:
  • Size: 3.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for swarmauri_xmp_png-0.1.1.dev35.tar.gz
Algorithm Hash digest
SHA256 b739668ddb3f10f5fe71836c49787ea8c1606022e7e5d8bfac036f00955f5c70
MD5 aa33573e6be439fa53483c673f27264e
BLAKE2b-256 74f63b1fc16f4741b3757233d03094476106f4a6d29a407fa471bbd39db5cfbe

See more details on using hashes here.

File details

Details for the file swarmauri_xmp_png-0.1.1.dev35-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_xmp_png-0.1.1.dev35-py3-none-any.whl
  • Upload date:
  • Size: 4.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for swarmauri_xmp_png-0.1.1.dev35-py3-none-any.whl
Algorithm Hash digest
SHA256 4d8a10f2c3c8fa30504158201ae530ad26bc208e1d481616c4424eac42f5b19f
MD5 cde8a343ceedadcaea285c3ed79938b1
BLAKE2b-256 18fedafc4fb90485990a1d8df547cbfea804bac8a32ab8d30894ac42f5a956fa

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