Skip to content

PizzasBear/russx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

russx

Documentation Latest version

Russx implements a template rendering engine based on rstml. It generates Rust code from your templates at compile time using a macro. This crate is inpired by both Askama and Leptos.

Features

  • Template instantiation
  • For loops, if-else statements, if-let statements, match statements
  • Full rust variables
  • Opt-out HTML escaping
  • Optional built-in support for Actix-Web, Axum, Gotham, Rocket, Tide, and warp web frameworks.

How to get started

First, add the russx dependancy to your crate's Cargo.toml:

cargo add russx

In any Rust file inside your crate, add the following:

use russx::Template;

russx::templates! {
    pub fn hello<'a>(name: &'a str) {
        <p>Hello, {name}!</p>
    }
}

fn main() {
    let html = hello("world").render().unwrap();
    println!("{html}");
}

You should be able to compile and run this code.

About

A rust template library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages