Skip to main content

A generator for Pelican allowing flexible referencing of static content

Project description

A plugin for Pelican that adds automatic resolution of static files.

While the original static generator included in Pelican requires the hardcoding of static paths in the configuration file, pelican-autostatic provides facilities to dinamically add static content independent of its location, just by referencing it.

Install

To install the library, you can use pip

$ pip install pelican-autostatic

Usage

  1. Update pelicanconf.py:

    1. Add autostatic to PLUGINS.

      You should add it before any metadata-affecting plugins.

      PLUGINS = ['autostatic', ...]
  2. Reference static content in your Markdown/rST metadata/text by using the {static} substitution:

    {static url/to/content key1=val1 key2="val 2" ...}

    or:

    {static "url/to/content/with spaces" key1=val1 key2="val 2" ...}

    Example (in markdown):

    [Markdown example file]({static file/example.zip key1=val1 key2="val 2" ...})

    You can also use | instead of spaces if you wish (for use with Markdown inline image syntax which doesn’t accept spaces for the url for instance):

    ![Markdown example image]({static|file/example.png|key1=val1} "Image title")
  3. An index of these references will be automatically built and those files will be copied to the output folder preserving the path structure:

    • If using a relative path, the file will be copied to the same path relative to the directory where the .html file is output.

    • If using an absolute path, the file is copied to that same path relative to the base output folder (e.g: output).

Options

Autostatic references can have a number of options after the url for the content. This allows modifications to the content being referenced.

Core options

  • output: Allows changing the output path (and the url) of the file in the generated .html.

    Example:

    {static /images/example.png output=/images/example_2.png}

    Will copy content/images/example.png to output/images/example_2.png and the reference will be replaced by $SITEURL/images/example_2.png.

  • url: Allows changing the url of the file in the generated .html without changing the output path.

    Example:

    {static /images/example.png url=/images/example_2.png}

    Will copy content/images/example.png to output/images/example.png and the reference will be replaced by $SITEURL/images/example_2.png.

Third-party options

  • pelican-advthumbnailer adds a thumb option that changes the url of the static image reference so that a thumbnail of that image is generated and linked and not the image itself.

Configuration

You can set the following options in your pelicanconf.py:

  • AUTOSTATIC_REFERENCE_PATTERN (String) - Change the regex of the static reference pattern. It needs to have the following groups:

    • path - This should have the path used in the reference.

    • extra - This should have the key1=val1 key2="val 2" ... string.

    For reference, the default pattern is:

    r"""{static(?:\s+|\|)((?:"|')?)(?P<path>[^\1=]+?)\1(?:(?:\s+|\|)(?P<extra>.*))?\s*}"""
  • AUTOSTATIC_USE_PELICANLIKE_REF (Boolean) - Activate the usage of a different format of the static reference that is similar to Pelican’s {filename} syntax:

    ![Markdown example image]({static|key1=val1}images/example.png "Image title")

    NOTE: I haven’t actually benchmarked this but this mechanism (the same used by Pelican with {filename}) should be slightly slower than the default one used in this plugin. This is because the {filename} mechanism does matching over all html tags which will surely result in a lot of backtracks on a HTML document.

Extending

Available signals

  • autostatic_path_found: Signalled when a new autostatic reference is found.

    Parameters:

    • sender: Always None

    • autostatic_path: Object containing:

      • source: Read-only property containing source path of reference.

      • destination: Read/write property containing destination of referenced file.

      • original_destination: Read-only property containing default destination of referenced file.

      • url: Read/write property containing url to be substituted for the reference.

      • original_url: Read-only property containing default url to be substituted for the reference.

      • extra: Dictionary containing the options specified in addition to the path. Can be possibly empty.

pelican-advthumbnailer contains an example usage of this signal.

Example

For a working example check my site and my site’s source code.

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

pelican-autostatic-1.0.0.tar.gz (10.1 kB view details)

Uploaded Source

Built Distribution

pelican_autostatic-1.0.0-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file pelican-autostatic-1.0.0.tar.gz.

File metadata

  • Download URL: pelican-autostatic-1.0.0.tar.gz
  • Upload date:
  • Size: 10.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.10.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.10

File hashes

Hashes for pelican-autostatic-1.0.0.tar.gz
Algorithm Hash digest
SHA256 b3d1eb7cccc034dd20b9a0a953b356a36290e229f8dec8f6c3db3643aa6bac01
MD5 cd72a60f9b4122977c198d46826226d1
BLAKE2b-256 18e8c157241e0dca63bb7b75f84962886f073b2b2748f8cf1121086940a00551

See more details on using hashes here.

File details

Details for the file pelican_autostatic-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: pelican_autostatic-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.10.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.10

File hashes

Hashes for pelican_autostatic-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ad656056f3d7d013c909abc016836d23455223e1ec18f312a48bac7b0c2bc295
MD5 471f4c941ef956e5ef53815d65c61be6
BLAKE2b-256 75ed6a35d5de489a6a7e8670f4ccf2542f5a2629581868f9139078f68d943790

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page