A Clojure's Hiccup inspired macro. At the moment support for inline code execution is not guaranteed. The main objective of this lib is to prevent unclosed html tags.
The macro hiccup! receives a mutable string as the first argument and mutates the string to emit the HTML.
The order of the elemnts is:
1.
tagas the first element.
2. Optional attribute inside the tag should follow the tag name as
{attribute1=>"value1 vlaue2 ... valuen", attr=>"value"}. Also, the attributes should be inside
{...}and separate each key value pair by
,.
The element should be written as
key=>"value", where key is a symbol, followed by an arrow (
=>), and then the value as a string
"value".
3. After the tag name or the attributes
{...}tou should include
[...]that can have other tags, such as
p["text"]` or regular string values.
[:a {:href "http://github.com"} "GitHub"]
a{href=>"http://github.com"}["GitHub"]
Add dependency to cargo.toml
:
toml
[dependencies]
hiccup = "0.1.1"
Code example with hiccup!
macro:
```rust extern crate hiccup;
use hiccup::hiccup;
fn main() { let mut html = String::new();
let _ = hiccup!(&mut html,
html[
head[meta{name=>"author", content=>"Julia Naomi"}[]
title["Hiccup guide"]]
body{class=>"amazing hiccup guide"}[
h1{font=>"bold"}["Hiccup is the best!"]
p["please lookup clojure's hiccup for better ideas on this macro"]]
]);
assert_eq!(html,"<html><head><meta name=\"author\" content=\"Julia Naomi\"></meta>\
<title>Hiccup guide</title></head><body class=\"amazing hiccup guide\">\
<h1 font=\"bold\">Hiccup is the best!</h1>\
<p>please lookup clojure\'s hiccup for better ideas on this macro</p></body></html>");
} ```
Add the feature you included in the macro as the name of the PR *with tests