A content-first static site generator crafted in Rust, optimized for performance, accessibility, and search engine visibility.
β’ Website β’ Documentation β’ Report Bug β’ Request Feature β’ Contributing Guidelines
Shokunin is a high-performance static site generator (SSG) engineered in Rust that prioritises:
- Content-first development approach
- Lightning-fast site generation
- WCAG 2.1 Level AA accessibility compliance
- Advanced SEO optimization
- Type-safe operations with comprehensive error handling
- β‘ Exceptional Performance: Zero-cost abstractions through Rust
- π± SEO Optimization: Built-in enhancements for search visibility
- βΏ Accessibility: Automatic WCAG 2.1 Level AA compliance
- π οΈ Multi-format Support: Handles Markdown, YAML, JSON, and TOML
- π Feed Generation: Automatic Atom and RSS feed creation
- π Analytics: Native Google and Bing Analytics integration
- π¨ Theming: Custom HTML themes and template support
- π§ CLI Tools: Comprehensive command-line interface
- π Dev Server: Built-in Rust server for local development
- π Hot Reload: Automatic content updates during development
- π Type Safety: Guaranteed memory and thread safety
- β‘ Async Support: Full asynchronous operation capabilities
Add to your Cargo.toml
:
[dependencies]
ssg = "0.0.32"
Or install via Cargo:
cargo install ssg
use staticdatagen::compiler::service::compile;
use std::{path::Path, error::Error};
fn main() -> Result<(), Box<dyn Error>> {
// Define directory paths
let build_dir = Path::new("./examples/build"); // Build directory
let content_dir = Path::new("./examples/content"); // Content directory
let public_dir = Path::new("./examples/public"); // Public directory
let template_dir = Path::new("./examples/templates"); // Templates
// Generate site
compile(build_dir, content_dir, public_dir, template_dir)?;
println!("β¨ Site generated successfully!");
Ok(())
}
Create a new site:
# Full command syntax
ssg --content=content --template=templates --serve=public
# Short form
ssg -c=content -t=templates -o=output -s=public
# Using cargo run
cargo run --bin ssg -- -c="./examples/content" -t="./examples/templates" -s="./examples/public"
Option | Short | Description | Required |
---|---|---|---|
--content |
-c |
Content path | Yes |
--template |
-t |
Template path | Yes |
--serve |
-s |
Server Public path | Yes |
Try our example implementations:
# Basic example
## Convert Markdown to static sites effortlessly, with templates, organized builds, and instant local hosting.
git clone https://github.com/sebastienrousseau/shokunin.git
cd shokunin
cargo run --example basic
# Quick start example
## Create, compile, and host a static site effortlessly with Shokunin: simple setup, error handling, and instant local server for previews.
cargo run --example quickstart
# Multilingual example
## Build multilingual static sites effortlessly: generate language-specific sites, create a language selector, and serve all from a single directory.
cargo run --example multilingual
We welcome contributions! Please see our Contributing Guidelines for details on:
- Code of Conduct
- Development Process
- Pull Request Guidelines
- Issue Reporting
This project is dual-licensed under:
at your option.
Special thanks to all contributors who have helped build Shokunin.