summaryrefslogtreecommitdiff
path: root/src/include/ast.h
blob: 77c3bc6c272683fe1829755f8119fcae9eb0051b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#ifndef AST_H
#define AST_H
#include <stdbool.h>

typedef struct AST_STRUCT {
  enum {
    /* root node */
    AST_ROOT,
    /* complex types */
    AST_PAIR,
    AST_SYMBOL,
    /* self evaluating types */
    AST_STRING,
    AST_BOOL,
    AST_INT,
    AST_FLOAT,
    AST_FUNCTION,
  } type;
  /* we need to know the amount of expressions in the root node */
  int root_size;
  struct AST_STRUCT **subnodes;

  /* For functions, the car will be a list of variables, and the cdr will be the
   * expression. */
  int argument_number; /* number of arguments that function accepts. Used for
                          speeding up stuff. */
  struct AST_STRUCT *car;
  struct AST_STRUCT *cdr;

  char *string_value; /* Also is symbol value */
  int int_value;
  long double float_value;
  bool bool_value;
} ast_t;

ast_t *init_ast(int type);

ast_t *init_ast_string(char *value);

ast_t *init_ast_int(int value);

ast_t *init_ast_float(long double value);

ast_t *init_ast_pair(ast_t *car, ast_t *cdr);

ast_t *init_ast_bool(bool value);

ast_t *init_ast_symbol(char *value);

ast_t *init_ast_function(ast_t *car, ast_t *cdr);

ast_t *init_ast_root(ast_t **subnodes, int size);

void ast_type_print(ast_t *e);

bool is_proper_list(ast_t *e);

void ast_free(ast_t *e);
#endif