Skip to main content

A Python-based static site generator. Bring your own content and templates and it'll quickly generate you a deployable HTML website/blog.

Project description

beemo

A Python-based static site generator. Bring your own content and templates and it'll quickly generate you a deployable HTML website/blog.

PyPI

Features

  • Content as HTML, markdown or reStructuredText
  • Pages
  • Posts
  • Tags
  • Archives (index, years and months)
  • XML sitemap
  • Atom feed
  • Custom Chameleon templates
  • Custom CSS, JS and other static files

Usage

Create content directories e.g. posts, pages, static and templates.

Posts

Populate your posts directory with your blog posts. Each post must be in its own directory but can be organised in any hierarchy e.g. by year, year/month or just flat. Post directories must contain a meta.yml and a content file (index.html, index.md or index.rst), and can contain images in an images directory, used within your post.

Pages

Populate your pages directory with your pages. Each page must be in its own directory. Post directories must contain a meta.yml and a content file (index.html, index.md or index.rst).

Static

Any files in your static directory will be copied into the site build root. Keep your CSS files and such in this directory.

Templates

Create Chameleon templates for your site in the templates directory. See the Chameleon docs for reference.

Configuration

The Beemo config file is a YAML file specifying some basic config about your site build.

For example, here pages_dir and posts_dir are both specified, and the site will be built with both pages and blog posts:

posts_dir: content/posts
pages_dir: content/pages
static_dir: static
templates_dir: templates
blog_root: blog
output_dir: www

If pages_dir is not specified, the site will be built without pages (i.e. blog only mode), e.g:

posts_dir: posts
static_dir: static
templates_dir: templates
output_dir: www

If posts_dir is not specified, the site will be built without pages (i.e. pages only mode), e.g:

pages_dir: pages
static_dir: static
templates_dir: templates
output_dir: www

If posts_dir is specified, this comes with archives, tag indexes and such which cannot currently be disabled.

Environment variables

The only environment variable required is BEEMO_CONFIG which must point to your site's config file:

export BEEMO_CONFIG=config.yml

Install

Install the latest release with:

pip install beemo

Development

Create a virtual environment and run make develop to install the library and its dependencies.

This can be served locally with e.g. python -m http.server -d www and viewed at e.g. http://localhost:8000.

Build

Build your site by running the command beemo with the environment variable BEEMO_CONFIG set pointing at a valid config file. It will build your site into your configured output_dir.

Examples

Sites built with Beemo:

If you wish to use this project for your own website, these examples will be a useful reference.

Licence

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

beemo-0.3.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

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

beemo-0.3.0-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file beemo-0.3.0.tar.gz.

File metadata

  • Download URL: beemo-0.3.0.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for beemo-0.3.0.tar.gz
Algorithm Hash digest
SHA256 e6834eedd5eda7220c8fd689cf9455b615a96485f9e6eabf48e5f0d13438738d
MD5 01ff684689bf38e0e0cf2179ff3f8e45
BLAKE2b-256 bf7a31790cd654206748fbd1f2c96d47e13297c49f1d605b055369ad30aadb8e

See more details on using hashes here.

File details

Details for the file beemo-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: beemo-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for beemo-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d0eaa5e80acc503af952ce74b5fd5d87c929b8522547bf35e602df5c9439e2f6
MD5 40059a915322d4c3bde4ba1e1a5d0eb1
BLAKE2b-256 394847e0583c44aa30126cba69abab49b89ec82ddd681bb9f643db5363914d16

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