# HSX HSX (Hypertext S-expression) is a simple and powerful HTML (Living Standard) generation library for Common Lisp. This project is a fork of [ailisp/flute](https://github.com/ailisp/flute/). ## Warning This software is still in ALPHA quality. The APIs are likely to change. Please check the [release notes](https://code.skyizwhite.dev/paku/hsx/releases) for updates. ## Getting Started ### Basic Usage Use the `hsx` macro to create HTML elements. Attributes are specified using a property list after the element name, and child elements are nested directly inside. ```lisp (hsx (div :id "example" :class "container" (h1 "Welcome to HSX") (p "This is an example paragraph."))) ``` This generates: ```html
This is an example paragraph.
Condition not met!
First paragraph.
Second paragraph.
``` ### Creating Components You can define reusable components using the `defcomp` macro. Component names must begin with a tilde (`~`). Properties should be declared using `&key`, `&rest`, or both. The body must return an HSX element. ```lisp (defcomp ~card (&key title children) (hsx (div :class "card" (h1 title) children))) ``` Alternatively, you can use a property list: ```lisp (defcomp ~card (&rest props) (hsx (div :class "card" (h1 (getf props :title)) (getf props :children)))) ``` Usage example: ```lisp (hsx (~card :title "Card Title" (p "This is a card component."))) ``` Generates: ```htmlThis is a card component.