Crates.io | rust-tags |
lib.rs | rust-tags |
version | 0.3.1 |
source | src |
created_at | 2018-02-17 07:40:46.128281 |
updated_at | 2018-02-18 21:44:53.105353 |
description | An HTML templating library for Rust |
homepage | https://github.com/longshorej/rust-tags |
repository | https://github.com/longshorej/rust-tags |
max_upload_size | |
id | 51553 |
size | 41,511 |
This project is a work-in-progress.
This is an HTML templating library for the Rust Programming Language. It's strongly inspired by Scalatags.
It differs from other templating libraries in that your documents are simply defined as plain function calls. This, among other things, allows you to safely construct documents that are free from XSS vulerabilities.
One other advantage to this approach is that features such as partial templates, etc. are easily expressed using Rust, having all of its power available.
extern crate rust_tags;
use rust_tags::tags::*;
use rust_tags::tags::title;
use rust_tags::attributes::*;
fn main() {
let frag = html(&[
head(&[title(&["My Blog".into()])]),
body(&[
div(&[
"Jason Longshore".into(),
hr(&[]),
// note that the hello world is escaped
a(&[href("#"), "My Blog <hello world />".into()]),
br(),
br()
])
])
]);
println!("{}", frag.data);
}
rust-tags
Fix a bug in attribute value escaping.
Initial usable release.
Cargo.toml
README.md
git tag v<version>; git push origin v<version>
cargo publish
Jason Longshore hello@jasonlongshore.com
Copyright (C) 2018 Jason Longshore (https://longshore.info/).
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this project except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.