rust/src/comp/front/ast.rs

339 lines
7.8 KiB
Rust
Raw Normal View History

import std.map.hashmap;
2010-11-03 17:10:37 -07:00
import std.option;
import std._vec;
import util.common.span;
import util.common.spanned;
import util.common.ty_mach;
type ident = str;
type path_ = rec(vec[ident] idents, vec[@ty] types);
type path = spanned[path_];
type crate_num = int;
type def_num = int;
type def_id = tup(crate_num, def_num);
type ty_param = rec(ident ident, def_id id);
// Annotations added during successive passes.
tag ann {
ann_none;
ann_type(@middle.ty.t);
}
tag def {
def_fn(def_id);
2010-12-14 15:32:13 -08:00
def_obj(def_id);
2010-12-30 15:27:19 -08:00
def_obj_field(def_id);
def_mod(def_id);
def_const(def_id);
def_arg(def_id);
def_local(def_id);
2010-12-01 10:19:20 -08:00
def_variant(def_id /* tag */, def_id /* variant */);
def_ty(def_id);
def_ty_arg(def_id);
2010-12-10 18:08:32 -08:00
def_binding(def_id);
def_use(def_id);
def_native_ty(def_id);
def_native_fn(def_id);
}
type crate = spanned[crate_];
type crate_ = rec(_mod module);
2010-12-30 11:21:37 -05:00
type meta_item = spanned[meta_item_];
type meta_item_ = rec(ident name, str value);
type block = spanned[block_];
type block_ = rec(vec[@stmt] stmts,
option.t[@expr] expr,
hashmap[ident,uint] index);
type variant_def = tup(def_id /* tag */, def_id /* variant */);
2010-11-24 14:42:01 -08:00
type pat = spanned[pat_];
tag pat_ {
2010-11-24 15:45:59 -08:00
pat_wild(ann);
2010-12-10 17:24:53 -08:00
pat_bind(ident, def_id, ann);
pat_tag(path, vec[@pat], option.t[variant_def], ann);
2010-11-24 14:42:01 -08:00
}
tag mutability {
mut;
imm;
}
2010-12-03 18:03:28 -08:00
tag layer {
layer_value;
layer_state;
layer_gc;
}
tag effect {
eff_pure;
eff_impure;
eff_unsafe;
}
tag binop {
2010-09-28 10:30:34 -07:00
add;
sub;
mul;
div;
rem;
and;
or;
bitxor;
bitand;
bitor;
lsl;
lsr;
asr;
eq;
lt;
le;
ne;
ge;
gt;
}
tag unop {
2010-09-28 10:30:34 -07:00
box;
deref;
bitnot;
not;
neg;
}
2010-12-03 18:03:28 -08:00
tag mode {
val;
alias;
}
type stmt = spanned[stmt_];
tag stmt_ {
stmt_decl(@decl);
2010-11-03 17:10:37 -07:00
stmt_ret(option.t[@expr]);
stmt_be(@expr);
stmt_log(@expr);
stmt_check_expr(@expr);
2011-01-28 00:09:26 -05:00
stmt_fail;
stmt_expr(@expr);
}
2010-11-03 17:10:37 -07:00
type local = rec(option.t[@ty] ty,
bool infer,
ident ident,
2010-11-03 17:10:37 -07:00
option.t[@expr] init,
def_id id,
ann ann);
type decl = spanned[decl_];
tag decl_ {
decl_local(@local);
decl_item(@item);
}
2010-12-10 18:08:32 -08:00
type arm = rec(@pat pat, block block, hashmap[ident,def_id] index);
2010-11-24 15:45:59 -08:00
type elt = rec(mutability mut, @expr expr);
type field = rec(mutability mut, ident ident, @expr expr);
type expr = spanned[expr_];
tag expr_ {
expr_vec(vec[@expr], ann);
expr_tup(vec[elt], ann);
expr_rec(vec[field], ann);
expr_call(@expr, vec[@expr], ann);
2010-12-20 18:58:18 -08:00
expr_bind(@expr, vec[option.t[@expr]], ann);
expr_binary(binop, @expr, @expr, ann);
expr_unary(unop, @expr, ann);
expr_lit(@lit, ann);
expr_cast(@expr, @ty, ann);
2011-02-01 16:23:48 -08:00
expr_if(@expr, block, vec[tup(@expr, block)], option.t[block], ann);
expr_while(@expr, block, ann);
expr_for(@decl, @expr, block, ann);
expr_do_while(block, @expr, ann);
2010-11-24 14:42:01 -08:00
expr_alt(@expr, vec[arm], ann);
expr_block(block, ann);
expr_assign(@expr /* TODO: @expr|is_lval */, @expr, ann);
expr_assign_op(binop, @expr /* TODO: @expr|is_lval */, @expr, ann);
expr_field(@expr, ident, ann);
expr_index(@expr, @expr, ann);
expr_path(path, option.t[def], ann);
}
type lit = spanned[lit_];
tag lit_ {
lit_str(str);
lit_char(char);
lit_int(int);
lit_uint(uint);
lit_mach_int(ty_mach, int);
lit_nil;
lit_bool(bool);
}
2010-11-03 16:43:12 -07:00
// NB: If you change this, you'll probably want to change the corresponding
// type structure in middle/ty.rs as well.
2010-12-03 18:03:28 -08:00
type ty_field = rec(ident ident, @ty ty);
2010-12-03 18:03:28 -08:00
type ty_arg = rec(mode mode, @ty ty);
2010-12-14 17:42:12 -08:00
// TODO: effect
type ty_method = rec(ident ident, vec[ty_arg] inputs, @ty output);
type ty = spanned[ty_];
tag ty_ {
ty_nil;
ty_bool;
ty_int;
ty_uint;
ty_machine(util.common.ty_mach);
ty_char;
ty_str;
ty_box(@ty);
2010-10-13 10:55:20 -07:00
ty_vec(@ty);
ty_tup(vec[@ty]);
ty_rec(vec[ty_field]);
2010-12-03 18:03:28 -08:00
ty_fn(vec[ty_arg], @ty); // TODO: effect
2010-12-14 17:42:12 -08:00
ty_obj(vec[ty_method]);
2010-11-03 17:10:37 -07:00
ty_path(path, option.t[def]);
2010-11-29 12:29:57 -08:00
ty_mutable(@ty);
2011-02-01 14:56:21 -08:00
ty_type;
}
type arg = rec(mode mode, @ty ty, ident ident, def_id id);
2011-02-04 11:10:04 -05:00
type fn_decl = rec(effect effect,
vec[arg] inputs,
@ty output);
type _fn = rec(fn_decl decl,
bool is_iter,
block body);
2010-12-14 15:32:13 -08:00
2010-12-16 18:34:04 -08:00
type method_ = rec(ident ident, _fn meth, def_id id, ann ann);
2010-12-14 15:32:13 -08:00
type method = spanned[method_];
2010-12-16 18:34:04 -08:00
type obj_field = rec(@ty ty, ident ident, def_id id, ann ann);
2010-12-14 15:32:13 -08:00
type _obj = rec(vec[obj_field] fields,
vec[@method] methods);
2010-12-01 10:19:20 -08:00
tag mod_index_entry {
mie_view_item(@view_item);
mie_item(@item);
mie_tag_variant(@item /* tag item */, uint /* variant index */);
2010-12-01 10:19:20 -08:00
}
type mod_index = hashmap[ident,mod_index_entry];
type _mod = rec(vec[@view_item] view_items,
vec[@item] items,
mod_index index);
type native_mod = rec(str native_name,
vec[@native_item] items,
native_mod_index index);
type native_mod_index = hashmap[ident,@native_item];
type variant_arg = rec(@ty ty, def_id id);
type variant = rec(str name, vec[variant_arg] args, def_id id, ann ann);
type view_item = spanned[view_item_];
tag view_item_ {
view_item_use(ident, vec[@meta_item], def_id);
view_item_import(ident, vec[ident], def_id, option.t[def]);
}
type item = spanned[item_];
tag item_ {
item_const(ident, @ty, @expr, def_id, ann);
2010-11-24 16:52:49 -08:00
item_fn(ident, _fn, vec[ty_param], def_id, ann);
item_mod(ident, _mod, def_id);
item_native_mod(ident, native_mod, def_id);
2010-11-24 17:36:22 -08:00
item_ty(ident, @ty, vec[ty_param], def_id, ann);
2010-11-24 17:15:54 -08:00
item_tag(ident, vec[variant], vec[ty_param], def_id);
2010-12-14 15:32:13 -08:00
item_obj(ident, _obj, vec[ty_param], def_id, ann);
}
type native_item = spanned[native_item_];
tag native_item_ {
native_item_ty(ident, def_id);
2011-02-04 11:10:04 -05:00
native_item_fn(ident, fn_decl, vec[ty_param], def_id);
}
fn index_view_item(mod_index index, @view_item it) {
alt (it.node) {
case(ast.view_item_use(?id, _, _)) {
index.insert(id, ast.mie_view_item(it));
}
case(ast.view_item_import(?def_ident,_,_,_)) {
index.insert(def_ident, ast.mie_view_item(it));
}
}
}
fn index_item(mod_index index, @item it) {
alt (it.node) {
case (ast.item_const(?id, _, _, _, _)) {
index.insert(id, ast.mie_item(it));
}
case (ast.item_fn(?id, _, _, _, _)) {
index.insert(id, ast.mie_item(it));
}
case (ast.item_mod(?id, _, _)) {
index.insert(id, ast.mie_item(it));
}
case (ast.item_native_mod(?id, _, _)) {
index.insert(id, ast.mie_item(it));
}
case (ast.item_ty(?id, _, _, _, _)) {
index.insert(id, ast.mie_item(it));
}
case (ast.item_tag(?id, ?variants, _, _)) {
index.insert(id, ast.mie_item(it));
let uint variant_idx = 0u;
for (ast.variant v in variants) {
index.insert(v.name,
ast.mie_tag_variant(it, variant_idx));
variant_idx += 1u;
}
}
case (ast.item_obj(?id, _, _, _, _)) {
index.insert(id, ast.mie_item(it));
}
}
}
2010-08-12 10:27:50 -07:00
fn index_native_item(native_mod_index index, @native_item it) {
alt (it.node) {
case (ast.native_item_ty(?id, _)) {
index.insert(id, it);
}
2011-02-04 11:10:04 -05:00
case (ast.native_item_fn(?id, _, _, _)) {
index.insert(id, it);
}
}
}
fn is_call_expr(@expr e) -> bool {
alt (e.node) {
case (expr_call(_, _, _)) {
ret true;
}
case (_) {
ret false;
}
}
}
2010-08-12 10:27:50 -07:00
//
// Local Variables:
// mode: rust
// fill-column: 78;
// indent-tabs-mode: nil
// c-basic-offset: 4
// buffer-file-coding-system: utf-8-unix
// compile-command: "make -k -C ../.. 2>&1 | sed -e 's/\\/x\\//x:\\//g'";
// End:
//