Crates.io | cwf |
lib.rs | cwf |
version | 0.0.2 |
source | src |
created_at | 2020-07-09 22:29:37.651698 |
updated_at | 2020-07-19 20:46:09.274821 |
description | Compiled web framework based on CSS syntax |
homepage | |
repository | https://github.com/thisminute/cascading-wasm-framework |
max_upload_size | |
id | 263033 |
size | 14,816 |
Cwf is a front end web language implemented with Rust procedural macros.
To install, you will need:
Then:
git clone --recurse-submodules https://github.com/thisminute/cascading-wasm-framework.git
cd cascading-wasm-framework
For windows users, run in the root directory:
rustup toolchain install stable-x86_64-pc-windows-gnu
rustup default stable-x86_64-pc-windows-gnu
The code is divided at a high level into 4 parts:
Parse
Macro
Page Initialization
Execution
First, the cwf syntax is parsed into data structures that Rust can work with. Both the data structures and the rules for parsing are in src/tokens.rs
.
Next, the data structures are turned into Rust code by the proc_macro
defined in src/lib.rs
. This logic is the code OUTside of quote! {}
blocks, and the code INside of those blocks eventually runs in a browser.
Some of the code in the quote! {} blocks belongs to the 3rd group, and sets up the components and data bindings on a page when it is launched.
Though not entirely distinct from the initialization step, the rest of the code can be thought of as running as the page is in use, especially code triggered by event listeners.
./tests
has a collection of cwf examples that render different features. Currently, they just check to see that the examples compile.