Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

## [Unreleased]

### Fixed

- Add proper typing @overload to `zimscraperlib.image.optimize_xxx` methods (#273)

## [5.3.0] - 2025-11-14

### Changed
Expand Down
37 changes: 37 additions & 0 deletions src/zimscraperlib/image/optimization.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import pathlib
import subprocess
from dataclasses import dataclass
from typing import overload

import piexif # pyright: ignore[reportMissingTypeStubs]
from optimize_images.img_aux_processing import ( # pyright: ignore[reportMissingTypeStubs]
Expand Down Expand Up @@ -78,6 +79,18 @@ class OptimizePngOptions:
remove_transparency: bool | None = False


@overload
def optimize_png(
src: pathlib.Path | io.BytesIO,
dst: io.BytesIO | None = None,
options: OptimizePngOptions | None = None,
) -> io.BytesIO: ...
@overload
def optimize_png(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path,
options: OptimizePngOptions | None = None,
) -> pathlib.Path: ...
def optimize_png(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path | io.BytesIO | None = None,
Expand Down Expand Up @@ -128,6 +141,18 @@ class OptimizeJpgOptions:
keep_exif: bool | None = True


@overload
def optimize_jpeg(
src: pathlib.Path | io.BytesIO,
dst: io.BytesIO | None = None,
options: OptimizeJpgOptions | None = None,
) -> io.BytesIO: ...
@overload
def optimize_jpeg(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path,
options: OptimizeJpgOptions | None = None,
) -> pathlib.Path: ...
def optimize_jpeg(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path | io.BytesIO | None = None,
Expand Down Expand Up @@ -218,6 +243,18 @@ class OptimizeWebpOptions:
lossless: bool | None = False


@overload
def optimize_webp(
src: pathlib.Path | io.BytesIO,
dst: io.BytesIO | None = None,
options: OptimizeWebpOptions | None = None,
) -> io.BytesIO: ...
@overload
def optimize_webp(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path,
options: OptimizeWebpOptions | None = None,
) -> pathlib.Path: ...
def optimize_webp(
src: pathlib.Path | io.BytesIO,
dst: pathlib.Path | io.BytesIO | None = None,
Expand Down