# Program
Status: 🟢
Assertions: 1
```rustleaf
assert("hello, world" == "hello, world");
```
# Output
```
parse_program: starting
parse_program: parsing statement at position 0 (Ident(assert))
parse_statement: starting at position 0 (Ident(assert))
consume_token: position 0 consumed Ident
parse_statement: falling back to expression statement
parse_expression: starting at position 0 (Ident(assert))
consume_token: position 0 consumed Ident
parse_primary: success - parsed identifier (assert)
consume_token: position 1 consumed LeftParen
parse_expression: starting at position 2 (String(hello, world))
consume_token: position 2 consumed String
parse_primary: success - parsed numeric/string literal
consume_token: position 3 consumed EqualEqual
consume_token: position 4 consumed String
parse_primary: success - parsed numeric/string literal
parse_expression: success - parsed precedence expression
consume_token: position 5 consumed RightParen
parse_expression: success - parsed precedence expression
consume_token: position 6 consumed Semicolon
parse_program: parsed 1 statements
```
# Result
```rust
Ok(
Unit,
)
```
# Lex
```rust
Ok(
[
0: Token(Ident, "assert"),
1: Token(LeftParen),
2: Token(String, "hello, world"),
3: Token(EqualEqual),
4: Token(String, "hello, world"),
5: Token(RightParen),
6: Token(Semicolon),
7: Token(Eof)
],
)
```
# Parse
```rust
Ok(
Program(
[
Expression(
FunctionCall(
Identifier(
"assert",
),
[
Eq(
Literal(
String(
"hello, world",
),
),
Literal(
String(
"hello, world",
),
),
),
],
),
),
],
),
)
```
# Eval
```rust
Ok(
RustValue(<unknown>),
)
```