76f1d38e8b5269f2fcb2a0e7666efe98978b7671
[isl.git] / include / isl / ast.h
blob76f1d38e8b5269f2fcb2a0e7666efe98978b7671
1 #ifndef ISL_AST_H
2 #define ISL_AST_H
4 #include <isl/ctx.h>
5 #include <isl/id.h>
6 #include <isl/val.h>
7 #include <isl/list.h>
8 #include <isl/printer.h>
10 #if defined(__cplusplus)
11 extern "C" {
12 #endif
14 struct isl_ast_expr;
15 typedef struct isl_ast_expr isl_ast_expr;
17 struct isl_ast_node;
18 typedef struct isl_ast_node isl_ast_node;
20 enum isl_ast_op_type {
21 isl_ast_op_error = -1,
22 isl_ast_op_and,
23 isl_ast_op_and_then,
24 isl_ast_op_or,
25 isl_ast_op_or_else,
26 isl_ast_op_max,
27 isl_ast_op_min,
28 isl_ast_op_minus,
29 isl_ast_op_add,
30 isl_ast_op_sub,
31 isl_ast_op_mul,
32 isl_ast_op_div,
33 isl_ast_op_fdiv_q, /* Round towards -infty */
34 isl_ast_op_pdiv_q, /* Dividend is non-negative */
35 isl_ast_op_pdiv_r, /* Dividend is non-negative */
36 isl_ast_op_cond,
37 isl_ast_op_select,
38 isl_ast_op_eq,
39 isl_ast_op_le,
40 isl_ast_op_lt,
41 isl_ast_op_ge,
42 isl_ast_op_gt,
43 isl_ast_op_call
46 enum isl_ast_expr_type {
47 isl_ast_expr_error = -1,
48 isl_ast_expr_op,
49 isl_ast_expr_id,
50 isl_ast_expr_int
53 enum isl_ast_node_type {
54 isl_ast_node_error = -1,
55 isl_ast_node_for = 1,
56 isl_ast_node_if,
57 isl_ast_node_block,
58 isl_ast_node_user
61 struct isl_ast_print_options;
62 typedef struct isl_ast_print_options isl_ast_print_options;
64 ISL_DECLARE_LIST(ast_expr)
65 ISL_DECLARE_LIST(ast_node)
67 int isl_options_set_ast_iterator_type(isl_ctx *ctx, const char *val);
68 const char *isl_options_get_ast_iterator_type(isl_ctx *ctx);
70 __isl_give isl_ast_expr *isl_ast_expr_from_val(__isl_take isl_val *v);
71 __isl_give isl_ast_expr *isl_ast_expr_from_id(__isl_take isl_id *id);
72 __isl_give isl_ast_expr *isl_ast_expr_neg(__isl_take isl_ast_expr *expr);
73 __isl_give isl_ast_expr *isl_ast_expr_add(__isl_take isl_ast_expr *expr1,
74 __isl_take isl_ast_expr *expr2);
75 __isl_give isl_ast_expr *isl_ast_expr_sub(__isl_take isl_ast_expr *expr1,
76 __isl_take isl_ast_expr *expr2);
77 __isl_give isl_ast_expr *isl_ast_expr_mul(__isl_take isl_ast_expr *expr1,
78 __isl_take isl_ast_expr *expr2);
79 __isl_give isl_ast_expr *isl_ast_expr_div(__isl_take isl_ast_expr *expr1,
80 __isl_take isl_ast_expr *expr2);
81 __isl_give isl_ast_expr *isl_ast_expr_and(__isl_take isl_ast_expr *expr1,
82 __isl_take isl_ast_expr *expr2);
83 __isl_give isl_ast_expr *isl_ast_expr_or(__isl_take isl_ast_expr *expr1,
84 __isl_take isl_ast_expr *expr2);
86 __isl_give isl_ast_expr *isl_ast_expr_copy(__isl_keep isl_ast_expr *expr);
87 void *isl_ast_expr_free(__isl_take isl_ast_expr *expr);
89 isl_ctx *isl_ast_expr_get_ctx(__isl_keep isl_ast_expr *expr);
90 enum isl_ast_expr_type isl_ast_expr_get_type(__isl_keep isl_ast_expr *expr);
91 __isl_give isl_val *isl_ast_expr_get_val(__isl_keep isl_ast_expr *expr);
92 __isl_give isl_id *isl_ast_expr_get_id(__isl_keep isl_ast_expr *expr);
94 enum isl_ast_op_type isl_ast_expr_get_op_type(__isl_keep isl_ast_expr *expr);
95 int isl_ast_expr_get_op_n_arg(__isl_keep isl_ast_expr *expr);
96 __isl_give isl_ast_expr *isl_ast_expr_get_op_arg(__isl_keep isl_ast_expr *expr,
97 int pos);
99 int isl_ast_expr_is_equal(__isl_keep isl_ast_expr *expr1,
100 __isl_keep isl_ast_expr *expr2);
102 __isl_give isl_printer *isl_printer_print_ast_expr(__isl_take isl_printer *p,
103 __isl_keep isl_ast_expr *expr);
104 void isl_ast_expr_dump(__isl_keep isl_ast_expr *expr);
105 __isl_give char *isl_ast_expr_to_str(__isl_keep isl_ast_expr *expr);
107 __isl_give isl_ast_node *isl_ast_node_alloc_user(__isl_take isl_ast_expr *expr);
108 __isl_give isl_ast_node *isl_ast_node_copy(__isl_keep isl_ast_node *node);
109 void *isl_ast_node_free(__isl_take isl_ast_node *node);
111 isl_ctx *isl_ast_node_get_ctx(__isl_keep isl_ast_node *node);
112 enum isl_ast_node_type isl_ast_node_get_type(__isl_keep isl_ast_node *node);
114 __isl_give isl_ast_node *isl_ast_node_set_annotation(
115 __isl_take isl_ast_node *node, __isl_take isl_id *annotation);
116 __isl_give isl_id *isl_ast_node_get_annotation(__isl_keep isl_ast_node *node);
118 __isl_give isl_ast_expr *isl_ast_node_for_get_iterator(
119 __isl_keep isl_ast_node *node);
120 __isl_give isl_ast_expr *isl_ast_node_for_get_init(
121 __isl_keep isl_ast_node *node);
122 __isl_give isl_ast_expr *isl_ast_node_for_get_cond(
123 __isl_keep isl_ast_node *node);
124 __isl_give isl_ast_expr *isl_ast_node_for_get_inc(
125 __isl_keep isl_ast_node *node);
126 __isl_give isl_ast_node *isl_ast_node_for_get_body(
127 __isl_keep isl_ast_node *node);
128 int isl_ast_node_for_is_degenerate(__isl_keep isl_ast_node *node);
130 __isl_give isl_ast_expr *isl_ast_node_if_get_cond(
131 __isl_keep isl_ast_node *node);
132 __isl_give isl_ast_node *isl_ast_node_if_get_then(
133 __isl_keep isl_ast_node *node);
134 int isl_ast_node_if_has_else(__isl_keep isl_ast_node *node);
135 __isl_give isl_ast_node *isl_ast_node_if_get_else(
136 __isl_keep isl_ast_node *node);
138 __isl_give isl_ast_node_list *isl_ast_node_block_get_children(
139 __isl_keep isl_ast_node *node);
141 __isl_give isl_ast_expr *isl_ast_node_user_get_expr(
142 __isl_keep isl_ast_node *node);
144 __isl_give isl_printer *isl_printer_print_ast_node(__isl_take isl_printer *p,
145 __isl_keep isl_ast_node *node);
146 void isl_ast_node_dump(__isl_keep isl_ast_node *node);
148 __isl_give isl_ast_print_options *isl_ast_print_options_alloc(isl_ctx *ctx);
149 __isl_give isl_ast_print_options *isl_ast_print_options_copy(
150 __isl_keep isl_ast_print_options *options);
151 void *isl_ast_print_options_free(__isl_take isl_ast_print_options *options);
152 isl_ctx *isl_ast_print_options_get_ctx(
153 __isl_keep isl_ast_print_options *options);
155 __isl_give isl_ast_print_options *isl_ast_print_options_set_print_user(
156 __isl_take isl_ast_print_options *options,
157 __isl_give isl_printer *(*print_user)(__isl_take isl_printer *p,
158 __isl_take isl_ast_print_options *options,
159 __isl_keep isl_ast_node *node, void *user),
160 void *user);
161 __isl_give isl_ast_print_options *isl_ast_print_options_set_print_for(
162 __isl_take isl_ast_print_options *options,
163 __isl_give isl_printer *(*print_for)(__isl_take isl_printer *p,
164 __isl_take isl_ast_print_options *options,
165 __isl_keep isl_ast_node *node, void *user),
166 void *user);
168 int isl_ast_node_foreach_ast_op_type(__isl_keep isl_ast_node *node,
169 int (*fn)(enum isl_ast_op_type type, void *user), void *user);
170 __isl_give isl_printer *isl_ast_op_type_print_macro(
171 enum isl_ast_op_type type, __isl_take isl_printer *p);
172 __isl_give isl_printer *isl_ast_node_print_macros(
173 __isl_keep isl_ast_node *node, __isl_take isl_printer *p);
174 __isl_give isl_printer *isl_ast_node_print(__isl_keep isl_ast_node *node,
175 __isl_take isl_printer *p,
176 __isl_take isl_ast_print_options *options);
177 __isl_give isl_printer *isl_ast_node_for_print(__isl_keep isl_ast_node *node,
178 __isl_take isl_printer *p,
179 __isl_take isl_ast_print_options *options);
180 __isl_give isl_printer *isl_ast_node_if_print(__isl_keep isl_ast_node *node,
181 __isl_take isl_printer *p,
182 __isl_take isl_ast_print_options *options);
184 #if defined(__cplusplus)
186 #endif
188 #endif