Skip to main content

This Pelican plugin optimizes images (jpg and png).

Project description

Optimize Images is a plugin for Pelican, a static site generator written in Python.

Optimize Images applies lossless compression on JPEG and PNG images, with no effect on image quality. It uses jpegtran and OptiPNG.

PyPI version number Changelog Supported Python version License Download Count

Installation

The easiest way to install Optimize Images is through the use of pip. This will also install the required Python dependencies automatically.

pip install minchin.pelican.plugins.optimize_images

It is assumed both jpegtran and OptiPNG are installed on system path.

If you are using Pelican 4.5, it should automatically be activated (through my AutoLoader plugin).

If you are using an earlier version of Pelican or autoloading isn’t working, then in your pelicanconf.py file, add Optimize Images to your list of plugins:

PLUGINS = [
    # others...
    "minchin.pelican.plugins.optimize_images",
    # ...
]

Requirements

Optimize Images depends on (and is really only useful with) Pelican. This can be manually installed with pip:

pip install pelican

It is assumed both jpegtran and OptiPNG are installed on system path. On Windows, installers are available at each respective website. On Ubuntu systems, the two can be installed via apt-get:

apt-get install optipng libjpeg-progs

Configuration and Usage

The plugin will activate and optimize images upon finalized signal of pelican.

If add OPTIMIZE_IMAGES_DEV_MODE = True to your pelicanconf.py, this will disable the plugin, which is useful when developing your site locally.

Known Issues

Image manipulation like this can take some time to run. You may consider only adding this plugin to your publishconf.py (rather than your base pelicanconf.py) or add OPTIMIZE_IMAGES_DEV_MODE = True to your pelicanconf.py, which will then only run this image optimization in preparation for site publication.

An issue, as such, is that there is no formal test suite. Testing is currently limited to my in-use observations. I also run a basic check upon uploaded the package to PyPI that it can be downloaded and loaded into Python.

The package is tested in Python 3.10; compatibility with other version of Python is unknown, but there should be nothing particular keeping it from working with other “modern” versions of Python.

Credits

Original plugin from the Pelican-Plugins repo.

License

The plugin code is assumed to be under the AGPLv3 license (this is the license of the Pelican-Plugins repo).

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

Built Distribution

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

File details

Details for the file minchin_pelican_plugins_optimize_images-1.3.0.tar.gz.

File metadata

File hashes

Hashes for minchin_pelican_plugins_optimize_images-1.3.0.tar.gz
Algorithm Hash digest
SHA256 efbea2a966eeafd3befabbfa94522f9eb67a92b417360a9af1f789e33bc5ca93
MD5 91f1ccaa25b8d874f02cbcbbab1f9fa6
BLAKE2b-256 6ea82539cc4729ff84866b5189f682841f9e1574edf870f9ed27244a91e41078

See more details on using hashes here.

File details

Details for the file minchin_pelican_plugins_optimize_images-1.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for minchin_pelican_plugins_optimize_images-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 af2d62831c00b50487d6544a4b0695ee42301a2751a0701d009c5bc5f94e785a
MD5 a738d138ee3b1b3634b9d4b8c475678b
BLAKE2b-256 cde8472cbcc1745765ce4321786e73429ea526a5b2463c9368b2c351177c1d0f

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