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.dev32.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.dev32-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: swarmauri_xmp_png-0.1.1.dev32.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.dev32.tar.gz
Algorithm Hash digest
SHA256 c99376cb7d45e01c31b329436b133e821418fb2f397cd6bcfc577d75d866edae
MD5 2828fc6a04aa65b063f6913bb2aeaf8a
BLAKE2b-256 e1afe56724a9d79c0346beb8db1852bedff8ad0a881cb9f66790c52ae88918f4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: swarmauri_xmp_png-0.1.1.dev32-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.dev32-py3-none-any.whl
Algorithm Hash digest
SHA256 3ae094984826ea70cc33e20fbb31fb9069f4ffad6a23f3e17c2a2c5d4e063a24
MD5 71e8ae232f1968d709cdedb7b74f75fa
BLAKE2b-256 1b1684114b678ae220c1894e952acf771832ed8481467917987d5a34a1a4524c

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