octospacc 6aa5fe8eb1 | ||
---|---|---|
Locale | ||
Source | ||
.gitignore | ||
LICENSE.md | ||
README.md | ||
TODO |
README.md
staticoso
staticoso (from Italian statico [static] + coso [thingy]) is an unpretentious static site generator.
I'm making this because I need a simple and kind-of-minimal program to serve me as a static site generator with (limited) CMS features. Just the features I need.
This won't replace any of the big projects out there that do the same thing but, as all of my projects, I'm releasing it as free libre software, in the hope that someone would find it useful.
Also, this software is needed for someone to edit and compile my personal sub-website sitoctt from its source. Being that site too released under a libre license that allows modifications, I have to also release the tools I use to build it.
Everything is still an heavy WIP, and features might break across commits, but feel free to experiment with all of this stuff!
Documentation
Documentation can be found at octtspacc.gitlab.io/staticoso-docs.
Obviously, it's built with staticoso itself 😁️. Its source repo can be found at gitlab.com/octtspacc/staticoso-docs.
Keep in mind that, currently, it's still very incomplete. Any help, from writing the documentation to creating a decent HTML+CSS template for its site, is more than welcome.
Dependencies
- Python == 3.10.4
- (Included) Python Markdown == 3.3.7
- (Included) Third-Party Extensions for Python Markdown: markdown_del_ins, mdx_subscript, mdx_superscript
- (Included) Beautiful Soup == 4.11.1
- (Included) feedgen == 0.9.0
- (Included) htmlmin == 0.1.12
Optional dependencies
Needed for Pug input support:
- node == 12.22.5 - npm == 7.5.2
- (Included) pug-cli == 1.0.0-alpha6
Needed for Gemtext output support:
Features roadmap
- File name used as a title for pages without one
- Custom category names in header links
- Choosing custom name for Blog and Uncategorized categories
- Choosing to use a template for all pages in a folder
- Configuration with both INI files and CLI arguments
- Category-based feeds
- Support for multi-language sites
- The
title
attribute added to images which only havealt
(for desktop accessibility) - Local (per-page) and global (per-site) macros
- ActivityPub (Mastodon) support (Feed + embedded comments)
- Polished Gemtext generation
- Autodetection of pages and posts
- Info for posts shown on their page
- HTML minification
- Full Open Graph support
- Custom categories for posts
- Custom static and dynamic page parts
- Showing creation and modified date for posts
- Generation of category pages (ex. page with list of blog posts)
- Custom and automatic page sorting
- SCSS compilation support for CSS templates
- Pug support for base templates and page side parts
- Differential recompile (to optimize resource waste on non-ephemeral servers)
- Hot-recompile (for website development)
- TXT sitemap generation
- Atom + RSS feed generation
- Generation of global website menu as a tree or as a line
- Generation of page (titles) menu as a tree
- Auto-detection of titles in a page
- HTML, TXT, Extended Markdown, and Pug supported for input page files
- Out of heavy-WIP state