Skip to main content

An uber-quick tool to create a Pelican static-site and deploy it to GitHub Pages.

Project description

turbopelican logo

turbopelican

turbopelican PyPI Version uv

An uber-quick tool to create a Pelican static-site and deploy it to GitHub Pages.

Explanation

GitHub lets you host static websites at your own subdomain. If your GitHub username is mrjohndoe, you can host a website at https://mrjohndoe.github.io. The same applies for organizations. If your GitHub organization is called MySpecialOrg, you can host a website at https://myspecialorg.github.io.

turbopelican is a tool which swiftly creates a static website to deploy at your subdomain. Any developer with a GitHub account and uv installed (see here) can deploy a website in minutes.

Usage

Before you run turbopelican, create a new repository where you will keep the source for your website.

ℹ️ NOTE: Make sure that the site-url uses the GitHub repository's name. For example, if you want the website to be https://johndoe.github.io, your GitHub repository will need to be called johndoe.github.io.

Create your repository on GitHub

After your repository is created, copy the git repository URL. You'll need it later.

Obtain your repository URL

Then enter your settings for your repository, and under "Code and automation" click "Pages". The section "Build and deployment" allows you to choose a source. Chose "GitHub actions".

Configure site publication

Next, you need to run turbopelican. Users are recommended to run turbopelican using uvx:

Run turbopelican

You can use the defaults, or choose your own values. In the example above, I have decided to give the website a non-default name, but I have left the other settings. turbopelican then creates a new repository my-turbopelican-website, with everything ready to push to GitHub.

ℹ️ NOTE: Make sure that the site-url uses the GitHub repository's name. For example, if you want the website to be https://johndoe.github.io, your GitHub repository will need to be called johndoe.github.io.

You will then need to push your code to GitHub:

cd my-turbopelican-website
git add .
git commit -q -m "Initial commit."
git remote add origin git@github.com:my-turbopelican-website/my-turbopelican-website.github.io.git # Use your own git repo reference
git push -q --set-upstream origin main

Now look at your repository on GitHub. You should be able to see the repository:

View new repository

If you navigate back to the settings for GitHub Pages, you should see a message informing you that your website is already live.

ℹ️ NOTE: It may take a minute for this prompt to appear, because GitHub Actions must first deploy your website.

Site is live

If you follow the link, you should be able to see your newly deployed website.

View website

You can learn more about Pelican here.

Configuration

Pelican still targets Python 3.9, which does not bundle built-in support for reading TOML configuration. Projects using turbopelican require Python 3.11 or higher, and therefore adopt the newer convention of placing configuration in a TOML file rather than Python scripts. Generally, you should only need to modify turbopelican.toml, rather than pelicanconf.py or publishconf.py.

Development

Ensure you have uv and git installed. You will need to create a fork of the repository. Then you should navigate to GitHub Actions (https://github.com/yourusername/turbopelican/actions) and enable workflows on your repository. After that, you can clone your fork onto your computer.

git clone git@github.com:yourusername/turbopelican.git
cd turbopelican
uv sync

When you need to check that the branch can pass CI, you can run the Makefile like so:

make ci

Once you push your branch to GitHub, the workflow "Run CI" should run. If you have not enabled workflows yet, do so, and then run the workflow manually. Pull requests should be made only for branches which pass CI. Once it has passed, you should then open a pull request. If you are contributing a new feature or breaking changes, you should set the base reference to the current feature branch. Otherwise, you should set the base reference to main.

NeoVim

Contributors to turbopelican are encouraged to use NeoVim as their IDE during development, in conjunction with nvim-lspconfig. When you launch NeoVim, you should pass the project's IDE settings like so:

. .venv/bin/activate
nvim -u init.lua

This will ensure that you receive Ruff and Pyright warnings in your editor. It will also automatically format any Python code on write.

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

turbopelican-0.5.1.tar.gz (957.2 kB view details)

Uploaded Source

Built Distribution

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

turbopelican-0.5.1-py3-none-any.whl (84.0 kB view details)

Uploaded Python 3

File details

Details for the file turbopelican-0.5.1.tar.gz.

File metadata

  • Download URL: turbopelican-0.5.1.tar.gz
  • Upload date:
  • Size: 957.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.8

File hashes

Hashes for turbopelican-0.5.1.tar.gz
Algorithm Hash digest
SHA256 0835df2f9e17ff6e6d79c2306741c110a9964897c2ae7b7546e69863e157da30
MD5 4cf71851bf25bf50c101f79a795bca90
BLAKE2b-256 ea17746c53124a460a7226ce076ff60eff1d8f431b4f4755f03817ff10a2b7e5

See more details on using hashes here.

File details

Details for the file turbopelican-0.5.1-py3-none-any.whl.

File metadata

File hashes

Hashes for turbopelican-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 736a3c24f5b513d6af54dab1e7b2c0361092e78e791c63e35f9d1d4e1df6cd8c
MD5 7dd3daec81742ea27da3b9f8ef84e615
BLAKE2b-256 9e6f5afd6d30250b32243069823060788c1a14bcaa7351e0489f147eaeb14b1e

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