Go to file
Kogia-sima 31bbcaebc8 Avoid capacity overflow in Buffer::with_capacity 2020-07-22 03:25:07 +09:00
benches Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
docs Add filter documentation in User Guide 2020-07-17 18:06:06 +09:00
examples Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
resources Resize icon for docs.rs 2020-06-18 01:04:10 +09:00
sailfish Avoid capacity overflow in Buffer::with_capacity 2020-07-22 03:25:07 +09:00
sailfish-compiler Allow proc-macro2 v1.0.19 as a dependency 2020-07-21 07:22:34 +09:00
sailfish-macros Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
sailfish-tests Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
scripts skip test in 1.42.0 2020-06-16 22:59:58 +09:00
syntax fix: Fix vim syntax highlighting 2020-07-18 09:31:23 +09:00
.gitattributes Add .gitattributes 2020-06-10 00:00:20 +09:00
.gitignore Add source code 2020-06-05 22:31:38 +09:00
.travis.yml Fix Rust version in .travis.yml 2020-06-16 22:32:49 +09:00
CHANGELOG.md Add CHANGELOG.md 2020-07-18 02:34:22 +09:00
Cargo.lock Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
Cargo.toml Exclude examples/ directory from workspaces 2020-07-15 00:06:01 +09:00
LICENSE Add source code 2020-06-05 22:31:38 +09:00
README.md Bump version (0.1.3 => 0.2.0) 2020-07-17 04:48:29 +09:00
appveyor.yml Speedup appveyor build 2020-06-10 19:15:39 +09:00
netlify.toml Add documentation sources 2020-06-09 21:19:59 +09:00
requirements.txt Add documentation sources 2020-06-09 21:19:59 +09:00
runtime.txt Update Python version 2020-06-09 21:34:46 +09:00
rustfmt.toml Add source code 2020-06-05 22:31:38 +09:00

README.md

SailFish

Simple, small, and extremely fast template engine for Rust

Build Status Build status Version License: MIT

User Guide | API Docs | Examples

Features

  • Simple and intuitive syntax inspired by EJS
  • Relatively small number of dependencies (<15 crates in total)
  • Extremely fast (See benchmarks)
  • Better error message
  • Template rendering NEVER fails unless you explicitly return error.
  • Syntax highlighting support (vscode, vim)
  • Automatically re-compile sources when template file is updated.
  • Works on Rust 1.42 or later

🐟 Example

Dependencies:

[dependencies]
sailfish = "0.2.0"
sailfish-macros = "0.2.0"

Template file (templates/hello.stpl):

<html>
  <body>
    <% for msg in &messages { %>
      <div><%= msg %></div>
    <% } %>
  </body>
</html>

Code:

#[macro_use]
extern crate sailfish_macros;  // enable derive macro

use sailfish::TemplateOnce;

#[derive(TemplateOnce)]
#[template(path = "hello.stpl")]
struct HelloTemplate {
    messages: Vec<String>
}

fn main() {
    let ctx = HelloTemplate {
        messages: vec![String::from("foo"), String::from("bar")]
    }
    println!("{}", ctx.render_once().unwrap());
}

You can find more examples in examples directory.

🐾 Roadmap

  • Template trait (RFC)
  • Template inheritance (block, partials, etc.)
  • Whitespace suppressing
  • Dynamic template compilation (RFC)
  • format_templates!(fmt, args..) macro

👤 Author

🇯🇵 Ryohei Machida

🤝 Contributing

Contributions, issues and feature requests are welcome!

Since sailfish is an immature library, there are many planned features that is on a stage of RFC. Please leave a comment if you have an idea about its design!

Also I welcome any pull requests to improve sailfish! Find issue with Status: PR Welcome label, and let's create a new pull request!

Show your support

Give a if this project helped you!

📝 License

Copyright © 2020 Ryohei Machida.

This project is MIT licensed.


This README was generated with ❤️ by readme-md-generator