rustc: "tag" -> "enum"
This commit is contained in:
parent
e6a7383a5f
commit
bdb8f6cf52
@ -22,7 +22,7 @@ import lib::llvm::mk_target_data;
|
|||||||
import lib::llvm::False;
|
import lib::llvm::False;
|
||||||
import util::filesearch;
|
import util::filesearch;
|
||||||
|
|
||||||
tag output_type {
|
enum output_type {
|
||||||
output_type_none;
|
output_type_none;
|
||||||
output_type_bitcode;
|
output_type_bitcode;
|
||||||
output_type_assembly;
|
output_type_assembly;
|
||||||
|
@ -107,7 +107,7 @@ fn mk_handler(cm: codemap::codemap,
|
|||||||
} as handler
|
} as handler
|
||||||
}
|
}
|
||||||
|
|
||||||
tag level {
|
enum level {
|
||||||
fatal;
|
fatal;
|
||||||
error;
|
error;
|
||||||
warning;
|
warning;
|
||||||
|
@ -18,7 +18,7 @@ import option::{some, none};
|
|||||||
import getopts::{optopt, optmulti, optflag, optflagopt, opt_present};
|
import getopts::{optopt, optmulti, optflag, optflagopt, opt_present};
|
||||||
import back::{x86, x86_64};
|
import back::{x86, x86_64};
|
||||||
|
|
||||||
tag pp_mode { ppm_normal; ppm_expanded; ppm_typed; ppm_identified; }
|
enum pp_mode { ppm_normal; ppm_expanded; ppm_typed; ppm_identified; }
|
||||||
|
|
||||||
fn default_configuration(sess: session, argv0: str, input: str) ->
|
fn default_configuration(sess: session, argv0: str, input: str) ->
|
||||||
ast::crate_cfg {
|
ast::crate_cfg {
|
||||||
|
@ -127,7 +127,7 @@ fails without recording a fatal error then we've encountered a compiler
|
|||||||
bug and need to present an error.
|
bug and need to present an error.
|
||||||
*/
|
*/
|
||||||
fn monitor(f: fn~(diagnostic::emitter)) {
|
fn monitor(f: fn~(diagnostic::emitter)) {
|
||||||
tag monitor_msg {
|
enum monitor_msg {
|
||||||
fatal;
|
fatal;
|
||||||
done;
|
done;
|
||||||
};
|
};
|
||||||
|
@ -10,11 +10,11 @@ import util::filesearch;
|
|||||||
import back::target_strs;
|
import back::target_strs;
|
||||||
import middle::lint;
|
import middle::lint;
|
||||||
|
|
||||||
tag os { os_win32; os_macos; os_linux; os_freebsd; }
|
enum os { os_win32; os_macos; os_linux; os_freebsd; }
|
||||||
|
|
||||||
tag arch { arch_x86; arch_x86_64; arch_arm; }
|
enum arch { arch_x86; arch_x86_64; arch_arm; }
|
||||||
|
|
||||||
tag crate_type { bin_crate; lib_crate; unknown_crate; }
|
enum crate_type { bin_crate; lib_crate; unknown_crate; }
|
||||||
|
|
||||||
type config =
|
type config =
|
||||||
{os: os,
|
{os: os,
|
||||||
|
@ -15,7 +15,7 @@ const False: Bool = 0;
|
|||||||
|
|
||||||
// Consts for the LLVM CallConv type, pre-cast to uint.
|
// Consts for the LLVM CallConv type, pre-cast to uint.
|
||||||
// FIXME: figure out a way to merge these with the native
|
// FIXME: figure out a way to merge these with the native
|
||||||
// typedef and/or a tag type in the native module below.
|
// typedef and/or a enum type in the native module below.
|
||||||
|
|
||||||
const LLVMCCallConv: uint = 0u;
|
const LLVMCCallConv: uint = 0u;
|
||||||
const LLVMFastCallConv: uint = 8u;
|
const LLVMFastCallConv: uint = 8u;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// EBML tag definitions and utils shared by the encoder and decoder
|
// EBML enum definitions and utils shared by the encoder and decoder
|
||||||
|
|
||||||
import str;
|
import str;
|
||||||
|
|
||||||
|
@ -36,11 +36,11 @@ type crate_metadata = @{name: str,
|
|||||||
cnum: ast::crate_num};
|
cnum: ast::crate_num};
|
||||||
|
|
||||||
// This is a bit of an experiment at encapsulating the data in cstore. By
|
// This is a bit of an experiment at encapsulating the data in cstore. By
|
||||||
// keeping all the data in a non-exported tag variant, it's impossible for
|
// keeping all the data in a non-exported enum variant, it's impossible for
|
||||||
// other modules to access the cstore's private data. This could also be
|
// other modules to access the cstore's private data. This could also be
|
||||||
// achieved with an obj, but at the expense of a vtable. Not sure if this is a
|
// achieved with an obj, but at the expense of a vtable. Not sure if this is a
|
||||||
// good pattern or not.
|
// good pattern or not.
|
||||||
tag cstore { private(cstore_private); }
|
enum cstore { private(cstore_private); }
|
||||||
|
|
||||||
type cstore_private =
|
type cstore_private =
|
||||||
@{metas: map::hashmap<ast::crate_num, crate_metadata>,
|
@{metas: map::hashmap<ast::crate_num, crate_metadata>,
|
||||||
|
@ -252,7 +252,7 @@ fn get_tag_variants(cdata: cmd, id: ast::node_id, tcx: ty::ctxt)
|
|||||||
ty::ty_fn(f) {
|
ty::ty_fn(f) {
|
||||||
for a: ty::arg in f.inputs { arg_tys += [a.ty]; }
|
for a: ty::arg in f.inputs { arg_tys += [a.ty]; }
|
||||||
}
|
}
|
||||||
_ { /* Nullary tag variant. */ }
|
_ { /* Nullary enum variant. */ }
|
||||||
}
|
}
|
||||||
alt variant_disr_val(item) {
|
alt variant_disr_val(item) {
|
||||||
some(val) { disr_val = val; }
|
some(val) { disr_val = val; }
|
||||||
@ -347,7 +347,7 @@ fn item_family_to_str(fam: u8) -> str {
|
|||||||
't' { ret "type"; }
|
't' { ret "type"; }
|
||||||
'm' { ret "mod"; }
|
'm' { ret "mod"; }
|
||||||
'n' { ret "native mod"; }
|
'n' { ret "native mod"; }
|
||||||
'v' { ret "tag"; }
|
'v' { ret "enum"; }
|
||||||
'i' { ret "impl"; }
|
'i' { ret "impl"; }
|
||||||
'I' { ret "iface"; }
|
'I' { ret "iface"; }
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ type ctxt =
|
|||||||
// Whatever format you choose should not contain pipe characters.
|
// Whatever format you choose should not contain pipe characters.
|
||||||
type ty_abbrev = {pos: uint, len: uint, s: @str};
|
type ty_abbrev = {pos: uint, len: uint, s: @str};
|
||||||
|
|
||||||
tag abbrev_ctxt { ac_no_abbrevs; ac_use_abbrevs(hashmap<ty::t, ty_abbrev>); }
|
enum abbrev_ctxt { ac_no_abbrevs; ac_use_abbrevs(hashmap<ty::t, ty_abbrev>); }
|
||||||
|
|
||||||
fn cx_uses_abbrevs(cx: @ctxt) -> bool {
|
fn cx_uses_abbrevs(cx: @ctxt) -> bool {
|
||||||
alt cx.abbrevs {
|
alt cx.abbrevs {
|
||||||
|
@ -15,13 +15,13 @@ import pat_util::*;
|
|||||||
// getting input from one, to be more precise). It is a pass that checks
|
// getting input from one, to be more precise). It is a pass that checks
|
||||||
// whether aliases are used in a safe way.
|
// whether aliases are used in a safe way.
|
||||||
|
|
||||||
tag copied { not_allowed; copied; not_copied; }
|
enum copied { not_allowed; copied; not_copied; }
|
||||||
tag invalid_reason { overwritten; val_taken; }
|
enum invalid_reason { overwritten; val_taken; }
|
||||||
type invalid = {reason: invalid_reason,
|
type invalid = {reason: invalid_reason,
|
||||||
node_id: node_id,
|
node_id: node_id,
|
||||||
sp: span, path: @ast::path};
|
sp: span, path: @ast::path};
|
||||||
|
|
||||||
tag unsafe_ty { contains(ty::t); mut_contains(ty::t); }
|
enum unsafe_ty { contains(ty::t); mut_contains(ty::t); }
|
||||||
|
|
||||||
type binding = @{node_id: node_id,
|
type binding = @{node_id: node_id,
|
||||||
span: span,
|
span: span,
|
||||||
@ -46,7 +46,7 @@ fn mk_binding(cx: ctx, id: node_id, span: span, root_var: option::t<node_id>,
|
|||||||
mutable copied: not_copied};
|
mutable copied: not_copied};
|
||||||
}
|
}
|
||||||
|
|
||||||
tag local_info { local(uint); }
|
enum local_info { local(uint); }
|
||||||
|
|
||||||
type copy_map = std::map::hashmap<node_id, ()>;
|
type copy_map = std::map::hashmap<node_id, ()>;
|
||||||
type ref_map = std::map::hashmap<node_id, node_id>;
|
type ref_map = std::map::hashmap<node_id, node_id>;
|
||||||
|
@ -4,7 +4,7 @@ import syntax::ast::*;
|
|||||||
import syntax::ast_util;
|
import syntax::ast_util;
|
||||||
import syntax::{visit, codemap};
|
import syntax::{visit, codemap};
|
||||||
|
|
||||||
tag ast_node {
|
enum ast_node {
|
||||||
node_item(@item);
|
node_item(@item);
|
||||||
node_native_item(@native_item);
|
node_native_item(@native_item);
|
||||||
node_method(@method);
|
node_method(@method);
|
||||||
|
@ -12,7 +12,7 @@ export cap_move;
|
|||||||
export cap_drop;
|
export cap_drop;
|
||||||
export cap_ref;
|
export cap_ref;
|
||||||
|
|
||||||
tag capture_mode {
|
enum capture_mode {
|
||||||
cap_copy; //< Copy the value into the closure.
|
cap_copy; //< Copy the value into the closure.
|
||||||
cap_move; //< Move the value into the closure.
|
cap_move; //< Move the value into the closure.
|
||||||
cap_drop; //< Drop value after creating closure.
|
cap_drop; //< Drop value after creating closure.
|
||||||
|
@ -108,7 +108,7 @@ type retval_md = {id: ast::node_id};
|
|||||||
|
|
||||||
type metadata_cache = hashmap<int, [debug_metadata]>;
|
type metadata_cache = hashmap<int, [debug_metadata]>;
|
||||||
|
|
||||||
tag debug_metadata {
|
enum debug_metadata {
|
||||||
file_metadata(@metadata<file_md>);
|
file_metadata(@metadata<file_md>);
|
||||||
compile_unit_metadata(@metadata<compile_unit_md>);
|
compile_unit_metadata(@metadata<compile_unit_md>);
|
||||||
subprogram_metadata(@metadata<subprogram_md>);
|
subprogram_metadata(@metadata<subprogram_md>);
|
||||||
|
@ -26,8 +26,8 @@ import std::list;
|
|||||||
// Marks expr_paths that are last uses.
|
// Marks expr_paths that are last uses.
|
||||||
type last_uses = std::map::hashmap<node_id, ()>;
|
type last_uses = std::map::hashmap<node_id, ()>;
|
||||||
|
|
||||||
tag seen { unset; seen(node_id); }
|
enum seen { unset; seen(node_id); }
|
||||||
tag block_type { func; loop; }
|
enum block_type { func; loop; }
|
||||||
|
|
||||||
type set = [{def: node_id, exprs: list<node_id>}];
|
type set = [{def: node_id, exprs: list<node_id>}];
|
||||||
type bl = @{type: block_type, mutable second: bool, mutable exits: [set]};
|
type bl = @{type: block_type, mutable second: bool, mutable exits: [set]};
|
||||||
|
@ -5,7 +5,7 @@ import syntax::visit;
|
|||||||
import syntax::ast_util;
|
import syntax::ast_util;
|
||||||
import driver::session::session;
|
import driver::session::session;
|
||||||
|
|
||||||
tag deref_t { unbox; field; index; }
|
enum deref_t { unbox; field; index; }
|
||||||
|
|
||||||
type deref = @{mut: bool, kind: deref_t, outer_t: ty::t};
|
type deref = @{mut: bool, kind: deref_t, outer_t: ty::t};
|
||||||
|
|
||||||
@ -121,7 +121,7 @@ fn check_crate(tcx: ty::ctxt, crate: @crate) -> mut_map {
|
|||||||
ret cx.mut_map;
|
ret cx.mut_map;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag msg { msg_assign; msg_move_out; msg_mut_ref; }
|
enum msg { msg_assign; msg_move_out; msg_mut_ref; }
|
||||||
|
|
||||||
fn mk_err(cx: @ctx, span: syntax::codemap::span, msg: msg, name: str) {
|
fn mk_err(cx: @ctx, span: syntax::codemap::span, msg: msg, name: str) {
|
||||||
cx.tcx.sess.span_err(span, alt msg {
|
cx.tcx.sess.span_err(span, alt msg {
|
||||||
|
@ -30,7 +30,7 @@ export _impl, iscopes, method_info;
|
|||||||
// locates all names (in expressions, types, and alt patterns) and resolves
|
// locates all names (in expressions, types, and alt patterns) and resolves
|
||||||
// them, storing the resulting def in the AST nodes.
|
// them, storing the resulting def in the AST nodes.
|
||||||
|
|
||||||
tag scope {
|
enum scope {
|
||||||
scope_crate;
|
scope_crate;
|
||||||
scope_item(@ast::item);
|
scope_item(@ast::item);
|
||||||
scope_bare_fn(ast::fn_decl, node_id, [ast::ty_param]);
|
scope_bare_fn(ast::fn_decl, node_id, [ast::ty_param]);
|
||||||
@ -44,7 +44,7 @@ tag scope {
|
|||||||
|
|
||||||
type scopes = list<scope>;
|
type scopes = list<scope>;
|
||||||
|
|
||||||
tag import_state {
|
enum import_state {
|
||||||
todo(ast::node_id, ast::ident, @[ast::ident], codemap::span, scopes);
|
todo(ast::node_id, ast::ident, @[ast::ident], codemap::span, scopes);
|
||||||
is_glob(@[ast::ident], scopes, codemap::span);
|
is_glob(@[ast::ident], scopes, codemap::span);
|
||||||
resolving(span);
|
resolving(span);
|
||||||
@ -56,7 +56,7 @@ tag import_state {
|
|||||||
ast::ident, codemap::span);
|
ast::ident, codemap::span);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag glob_import_state {
|
enum glob_import_state {
|
||||||
glob_resolving(span);
|
glob_resolving(span);
|
||||||
glob_resolved(option::t<def>, /* value */
|
glob_resolved(option::t<def>, /* value */
|
||||||
option::t<def>, /* type */
|
option::t<def>, /* type */
|
||||||
@ -98,12 +98,12 @@ fn new_exp_hash() -> exp_map {
|
|||||||
ret std::map::mk_hashmap::<key, def>(hash, eq);
|
ret std::map::mk_hashmap::<key, def>(hash, eq);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag mod_index_entry {
|
enum mod_index_entry {
|
||||||
mie_view_item(@ast::view_item);
|
mie_view_item(@ast::view_item);
|
||||||
mie_import_ident(node_id, codemap::span);
|
mie_import_ident(node_id, codemap::span);
|
||||||
mie_item(@ast::item);
|
mie_item(@ast::item);
|
||||||
mie_native_item(@ast::native_item);
|
mie_native_item(@ast::native_item);
|
||||||
mie_tag_variant(/* tag item */@ast::item, /* variant index */uint);
|
mie_tag_variant(/* enum item */@ast::item, /* variant index */uint);
|
||||||
}
|
}
|
||||||
|
|
||||||
type mod_index = hashmap<ident, list<mod_index_entry>>;
|
type mod_index = hashmap<ident, list<mod_index_entry>>;
|
||||||
@ -151,14 +151,14 @@ type env =
|
|||||||
|
|
||||||
// Used to distinguish between lookups from outside and from inside modules,
|
// Used to distinguish between lookups from outside and from inside modules,
|
||||||
// since export restrictions should only be applied for the former.
|
// since export restrictions should only be applied for the former.
|
||||||
tag dir { inside; outside; }
|
enum dir { inside; outside; }
|
||||||
|
|
||||||
// There are two types of ns_value tag: "definitely a tag";
|
// There are two types of ns_value enum: "definitely a enum";
|
||||||
// and "any value". This is so that lookup can behave differently
|
// and "any value". This is so that lookup can behave differently
|
||||||
// when looking up a variable name that's not yet in scope to check
|
// when looking up a variable name that's not yet in scope to check
|
||||||
// if it's already bound to a tag.
|
// if it's already bound to a enum.
|
||||||
tag namespace { ns_val(ns_value_type); ns_type; ns_module; }
|
enum namespace { ns_val(ns_value_type); ns_type; ns_module; }
|
||||||
tag ns_value_type { ns_a_tag; ns_any_value; }
|
enum ns_value_type { ns_a_tag; ns_any_value; }
|
||||||
|
|
||||||
fn resolve_crate(sess: session, amap: ast_map::map, crate: @ast::crate) ->
|
fn resolve_crate(sess: session, amap: ast_map::map, crate: @ast::crate) ->
|
||||||
{def_map: def_map, exp_map: exp_map, impl_map: impl_map} {
|
{def_map: def_map, exp_map: exp_map, impl_map: impl_map} {
|
||||||
@ -186,7 +186,7 @@ fn resolve_crate(sess: session, amap: ast_map::map, crate: @ast::crate) ->
|
|||||||
resolve_names(e, crate);
|
resolve_names(e, crate);
|
||||||
resolve_impls(e, crate);
|
resolve_impls(e, crate);
|
||||||
// check_for_collisions must happen after resolve_names so we
|
// check_for_collisions must happen after resolve_names so we
|
||||||
// don't complain if a pattern uses the same nullary tag twice
|
// don't complain if a pattern uses the same nullary enum twice
|
||||||
check_for_collisions(e, *crate);
|
check_for_collisions(e, *crate);
|
||||||
if sess.opts.warn_unused_imports {
|
if sess.opts.warn_unused_imports {
|
||||||
check_unused_imports(e);
|
check_unused_imports(e);
|
||||||
@ -415,13 +415,13 @@ fn resolve_names(e: @env, c: @ast::crate) {
|
|||||||
}
|
}
|
||||||
_ {
|
_ {
|
||||||
e.sess.span_err(p.span,
|
e.sess.span_err(p.span,
|
||||||
"not a tag variant: " +
|
"not a enum variant: " +
|
||||||
ast_util::path_name(p));
|
ast_util::path_name(p));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Here we determine whether a given pat_ident binds a new
|
/* Here we determine whether a given pat_ident binds a new
|
||||||
variable a refers to a nullary tag. */
|
variable a refers to a nullary enum. */
|
||||||
ast::pat_ident(p, none) {
|
ast::pat_ident(p, none) {
|
||||||
let fnd = lookup_in_scope(*e, sc, p.span, path_to_ident(p),
|
let fnd = lookup_in_scope(*e, sc, p.span, path_to_ident(p),
|
||||||
ns_val(ns_a_tag));
|
ns_val(ns_a_tag));
|
||||||
@ -557,13 +557,13 @@ fn visit_expr_with_scope(x: @ast::expr, sc: scopes, v: vt<scopes>) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This is only for irrefutable patterns (e.g. ones that appear in a let)
|
// This is only for irrefutable patterns (e.g. ones that appear in a let)
|
||||||
// So if x occurs, and x is already known to be a tag, that's always an error
|
// So if x occurs, and x is already known to be a enum, that's always an error
|
||||||
fn visit_local_with_scope(e: @env, loc: @local, sc:scopes, v:vt<scopes>) {
|
fn visit_local_with_scope(e: @env, loc: @local, sc:scopes, v:vt<scopes>) {
|
||||||
// Check whether the given local has the same name as a tag that's
|
// Check whether the given local has the same name as a enum that's
|
||||||
// in scope
|
// in scope
|
||||||
// We disallow this, in order to make alt patterns consisting of
|
// We disallow this, in order to make alt patterns consisting of
|
||||||
// a single identifier unambiguous (does the pattern "foo" refer
|
// a single identifier unambiguous (does the pattern "foo" refer
|
||||||
// to tag foo, or is it binding a new name foo?)
|
// to enum foo, or is it binding a new name foo?)
|
||||||
alt loc.node.pat.node {
|
alt loc.node.pat.node {
|
||||||
pat_ident(an_ident,_) {
|
pat_ident(an_ident,_) {
|
||||||
// Be sure to pass ns_a_tag to lookup_in_scope so that
|
// Be sure to pass ns_a_tag to lookup_in_scope so that
|
||||||
@ -571,10 +571,10 @@ fn visit_local_with_scope(e: @env, loc: @local, sc:scopes, v:vt<scopes>) {
|
|||||||
alt lookup_in_scope(*e, sc, loc.span,
|
alt lookup_in_scope(*e, sc, loc.span,
|
||||||
path_to_ident(an_ident), ns_val(ns_a_tag)) {
|
path_to_ident(an_ident), ns_val(ns_a_tag)) {
|
||||||
some(ast::def_variant(tag_id,variant_id)) {
|
some(ast::def_variant(tag_id,variant_id)) {
|
||||||
// Declaration shadows a tag that's in scope.
|
// Declaration shadows a enum that's in scope.
|
||||||
// That's an error.
|
// That's an error.
|
||||||
e.sess.span_err(loc.span,
|
e.sess.span_err(loc.span,
|
||||||
#fmt("Declaration of %s shadows a tag that's in scope",
|
#fmt("Declaration of %s shadows a enum that's in scope",
|
||||||
path_to_ident(an_ident)));
|
path_to_ident(an_ident)));
|
||||||
}
|
}
|
||||||
_ {}
|
_ {}
|
||||||
@ -742,14 +742,14 @@ fn ns_name(ns: namespace) -> str {
|
|||||||
ns_val(v) {
|
ns_val(v) {
|
||||||
alt (v) {
|
alt (v) {
|
||||||
ns_any_value { "name" }
|
ns_any_value { "name" }
|
||||||
ns_a_tag { "tag" }
|
ns_a_tag { "enum" }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ns_module { ret "modulename" }
|
ns_module { ret "modulename" }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag ctxt { in_mod(def); in_scope(scopes); }
|
enum ctxt { in_mod(def); in_scope(scopes); }
|
||||||
|
|
||||||
fn unresolved_err(e: env, cx: ctxt, sp: span, name: ident, kind: str) {
|
fn unresolved_err(e: env, cx: ctxt, sp: span, name: ident, kind: str) {
|
||||||
fn find_fn_or_mod_scope(sc: scopes) -> option::t<scope> {
|
fn find_fn_or_mod_scope(sc: scopes) -> option::t<scope> {
|
||||||
@ -967,8 +967,8 @@ fn lookup_in_scope(e: env, sc: scopes, sp: span, name: ident, ns: namespace)
|
|||||||
}
|
}
|
||||||
ns_val(v) {
|
ns_val(v) {
|
||||||
alt(v) {
|
alt(v) {
|
||||||
/* If we were looking for a tag, at this point
|
/* If we were looking for a enum, at this point
|
||||||
we know it's bound to a non-tag value, and
|
we know it's bound to a non-enum value, and
|
||||||
we can return none instead of failing */
|
we can return none instead of failing */
|
||||||
ns_a_tag { ret none; }
|
ns_a_tag { ret none; }
|
||||||
_ { "attempted dynamic environment-capture" }
|
_ { "attempted dynamic environment-capture" }
|
||||||
@ -1468,7 +1468,7 @@ fn ns_for_def(d: def) -> namespace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if we're searching for a value, it's ok if we found
|
// if we're searching for a value, it's ok if we found
|
||||||
// a tag
|
// a enum
|
||||||
fn ns_ok(wanted:namespace, actual:namespace) -> bool {
|
fn ns_ok(wanted:namespace, actual:namespace) -> bool {
|
||||||
alt actual {
|
alt actual {
|
||||||
ns_val(ns_a_tag) {
|
ns_val(ns_a_tag) {
|
||||||
|
@ -98,8 +98,8 @@ fn mk_global(ccx: @crate_ctxt, name: str, llval: ValueRef, internal: bool) ->
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Computes a set of variants of a tag that are guaranteed to have size and
|
// Computes a set of variants of a enum that are guaranteed to have size and
|
||||||
// alignment at least as large as any other variant of the tag. This is an
|
// alignment at least as large as any other variant of the enum. This is an
|
||||||
// important performance optimization.
|
// important performance optimization.
|
||||||
//
|
//
|
||||||
// TODO: Use this in dynamic_size_of() as well.
|
// TODO: Use this in dynamic_size_of() as well.
|
||||||
@ -180,7 +180,7 @@ fn largest_variants(ccx: @crate_ctxt, tag_id: ast::def_id) -> [uint] {
|
|||||||
ret result;
|
ret result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Computes the static size of a tag, without using mk_tup(), which is
|
// Computes the static size of a enum, without using mk_tup(), which is
|
||||||
// bad for performance.
|
// bad for performance.
|
||||||
//
|
//
|
||||||
// TODO: Migrate trans over to use this.
|
// TODO: Migrate trans over to use this.
|
||||||
@ -217,8 +217,8 @@ fn compute_static_tag_size(ccx: @crate_ctxt, largest_variants: [uint],
|
|||||||
if max_align < variant_align { max_align = variant_align; }
|
if max_align < variant_align { max_align = variant_align; }
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add space for the tag if applicable.
|
// Add space for the enum if applicable.
|
||||||
// FIXME (issue #792): This is wrong. If the tag starts with an 8 byte
|
// FIXME (issue #792): This is wrong. If the enum starts with an 8 byte
|
||||||
// aligned quantity, we don't align it.
|
// aligned quantity, we don't align it.
|
||||||
if vec::len(*variants) > 1u {
|
if vec::len(*variants) > 1u {
|
||||||
let variant_t = T_tag_variant(ccx);
|
let variant_t = T_tag_variant(ccx);
|
||||||
@ -230,7 +230,7 @@ fn compute_static_tag_size(ccx: @crate_ctxt, largest_variants: [uint],
|
|||||||
ret {size: max_size, align: max_align};
|
ret {size: max_size, align: max_align};
|
||||||
}
|
}
|
||||||
|
|
||||||
tag tag_kind { tk_unit; tk_enum; tk_complex; }
|
enum tag_kind { tk_unit; tk_enum; tk_complex; }
|
||||||
|
|
||||||
fn tag_kind(ccx: @crate_ctxt, did: ast::def_id) -> tag_kind {
|
fn tag_kind(ccx: @crate_ctxt, did: ast::def_id) -> tag_kind {
|
||||||
let variants = ty::tag_variants(ccx.tcx, did);
|
let variants = ty::tag_variants(ccx.tcx, did);
|
||||||
@ -469,7 +469,7 @@ fn shape_of_variant(ccx: @crate_ctxt, v: ty::variant_info,
|
|||||||
//}
|
//}
|
||||||
|
|
||||||
fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
||||||
// Loop over all the tag variants and write their shapes into a data
|
// Loop over all the enum variants and write their shapes into a data
|
||||||
// buffer. As we do this, it's possible for us to discover new tags, so we
|
// buffer. As we do this, it's possible for us to discover new tags, so we
|
||||||
// must do this first.
|
// must do this first.
|
||||||
let i = 0u;
|
let i = 0u;
|
||||||
@ -495,7 +495,7 @@ fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Now calculate the sizes of the header space (which contains offsets to
|
// Now calculate the sizes of the header space (which contains offsets to
|
||||||
// info records for each tag) and the info space (which contains offsets
|
// info records for each enum) and the info space (which contains offsets
|
||||||
// to each variant shape). As we do so, build up the header.
|
// to each variant shape). As we do so, build up the header.
|
||||||
|
|
||||||
let header = [];
|
let header = [];
|
||||||
@ -512,7 +512,7 @@ fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Construct the info tables, which contain offsets to the shape of each
|
// Construct the info tables, which contain offsets to the shape of each
|
||||||
// variant. Also construct the largest-variant table for each tag, which
|
// variant. Also construct the largest-variant table for each enum, which
|
||||||
// contains the variants that the size-of operation needs to look at.
|
// contains the variants that the size-of operation needs to look at.
|
||||||
|
|
||||||
let lv_table = [];
|
let lv_table = [];
|
||||||
@ -530,7 +530,7 @@ fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
|||||||
add_u16(lv_table, vec::len(lv) as u16);
|
add_u16(lv_table, vec::len(lv) as u16);
|
||||||
for v: uint in lv { add_u16(lv_table, v as u16); }
|
for v: uint in lv { add_u16(lv_table, v as u16); }
|
||||||
|
|
||||||
// Determine whether the tag has dynamic size.
|
// Determine whether the enum has dynamic size.
|
||||||
let dynamic = false;
|
let dynamic = false;
|
||||||
for variant: ty::variant_info in *variants {
|
for variant: ty::variant_info in *variants {
|
||||||
for typ: ty::t in variant.args {
|
for typ: ty::t in variant.args {
|
||||||
@ -538,7 +538,7 @@ fn gen_tag_shapes(ccx: @crate_ctxt) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we can, write in the static size and alignment of the tag.
|
// If we can, write in the static size and alignment of the enum.
|
||||||
// Otherwise, write a placeholder.
|
// Otherwise, write a placeholder.
|
||||||
let size_align;
|
let size_align;
|
||||||
if dynamic {
|
if dynamic {
|
||||||
|
@ -498,7 +498,7 @@ fn simplify_type(ccx: @crate_ctxt, typ: ty::t) -> ty::t {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Computes the size of the data part of a non-dynamically-sized tag.
|
// Computes the size of the data part of a non-dynamically-sized enum.
|
||||||
fn static_size_of_tag(cx: @crate_ctxt, sp: span, t: ty::t)
|
fn static_size_of_tag(cx: @crate_ctxt, sp: span, t: ty::t)
|
||||||
: type_has_static_size(cx, t) -> uint {
|
: type_has_static_size(cx, t) -> uint {
|
||||||
if cx.tag_sizes.contains_key(t) { ret cx.tag_sizes.get(t); }
|
if cx.tag_sizes.contains_key(t) { ret cx.tag_sizes.get(t); }
|
||||||
@ -526,7 +526,7 @@ fn static_size_of_tag(cx: @crate_ctxt, sp: span, t: ty::t)
|
|||||||
ret max_size;
|
ret max_size;
|
||||||
}
|
}
|
||||||
_ {
|
_ {
|
||||||
cx.tcx.sess.span_fatal(sp, "non-tag passed to static_size_of_tag()");
|
cx.tcx.sess.span_fatal(sp, "non-enum passed to static_size_of_tag()");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -736,9 +736,9 @@ fn GEP_tup_like(bcx: @block_ctxt, t: ty::t, base: ValueRef, ixs: [int])
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Replacement for the LLVM 'GEP' instruction when field indexing into a tag.
|
// Replacement for the LLVM 'GEP' instruction when field indexing into a enum.
|
||||||
// This function uses GEP_tup_like() above and automatically performs casts as
|
// This function uses GEP_tup_like() above and automatically performs casts as
|
||||||
// appropriate. @llblobptr is the data part of a tag value; its actual type is
|
// appropriate. @llblobptr is the data part of a enum value; its actual type is
|
||||||
// meaningless, as it will be cast away.
|
// meaningless, as it will be cast away.
|
||||||
fn GEP_tag(cx: @block_ctxt, llblobptr: ValueRef, tag_id: ast::def_id,
|
fn GEP_tag(cx: @block_ctxt, llblobptr: ValueRef, tag_id: ast::def_id,
|
||||||
variant_id: ast::def_id, ty_substs: [ty::t],
|
variant_id: ast::def_id, ty_substs: [ty::t],
|
||||||
@ -1470,7 +1470,7 @@ fn maybe_name_value(cx: @crate_ctxt, v: ValueRef, s: str) {
|
|||||||
|
|
||||||
|
|
||||||
// Used only for creating scalar comparison glue.
|
// Used only for creating scalar comparison glue.
|
||||||
tag scalar_type { nil_type; signed_int; unsigned_int; floating_point; }
|
enum scalar_type { nil_type; signed_int; unsigned_int; floating_point; }
|
||||||
|
|
||||||
|
|
||||||
fn compare_scalar_types(cx: @block_ctxt, lhs: ValueRef, rhs: ValueRef,
|
fn compare_scalar_types(cx: @block_ctxt, lhs: ValueRef, rhs: ValueRef,
|
||||||
@ -1658,14 +1658,14 @@ fn iter_structural_ty(cx: @block_ctxt, av: ValueRef, t: ty::t,
|
|||||||
// NB: we must hit the discriminant first so that structural
|
// NB: we must hit the discriminant first so that structural
|
||||||
// comparison know not to proceed when the discriminants differ.
|
// comparison know not to proceed when the discriminants differ.
|
||||||
cx = f(cx, lldiscrim_a_ptr, ty::mk_int(bcx_tcx(cx)));
|
cx = f(cx, lldiscrim_a_ptr, ty::mk_int(bcx_tcx(cx)));
|
||||||
let unr_cx = new_sub_block_ctxt(cx, "tag-iter-unr");
|
let unr_cx = new_sub_block_ctxt(cx, "enum-iter-unr");
|
||||||
Unreachable(unr_cx);
|
Unreachable(unr_cx);
|
||||||
let llswitch = Switch(cx, lldiscrim_a, unr_cx.llbb, n_variants);
|
let llswitch = Switch(cx, lldiscrim_a, unr_cx.llbb, n_variants);
|
||||||
let next_cx = new_sub_block_ctxt(cx, "tag-iter-next");
|
let next_cx = new_sub_block_ctxt(cx, "enum-iter-next");
|
||||||
for variant: ty::variant_info in *variants {
|
for variant: ty::variant_info in *variants {
|
||||||
let variant_cx =
|
let variant_cx =
|
||||||
new_sub_block_ctxt(cx,
|
new_sub_block_ctxt(cx,
|
||||||
"tag-iter-variant-" +
|
"enum-iter-variant-" +
|
||||||
int::to_str(variant.disr_val, 10u));
|
int::to_str(variant.disr_val, 10u));
|
||||||
AddCase(llswitch, C_int(ccx, variant.disr_val), variant_cx.llbb);
|
AddCase(llswitch, C_int(ccx, variant.disr_val), variant_cx.llbb);
|
||||||
variant_cx =
|
variant_cx =
|
||||||
@ -1938,7 +1938,7 @@ fn memmove_ty(bcx: @block_ctxt, dst: ValueRef, src: ValueRef, t: ty::t) ->
|
|||||||
ret call_memmove(bcx, dst, src, llsz).bcx;
|
ret call_memmove(bcx, dst, src, llsz).bcx;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag copy_action { INIT; DROP_EXISTING; }
|
enum copy_action { INIT; DROP_EXISTING; }
|
||||||
|
|
||||||
// These are the types that are passed by pointer.
|
// These are the types that are passed by pointer.
|
||||||
fn type_is_structural_or_param(tcx: ty::ctxt, t: ty::t) -> bool {
|
fn type_is_structural_or_param(tcx: ty::ctxt, t: ty::t) -> bool {
|
||||||
@ -2244,7 +2244,7 @@ fn autoderef(cx: @block_ctxt, v: ValueRef, t: ty::t) -> result_t {
|
|||||||
t1 = mt.ty;
|
t1 = mt.ty;
|
||||||
|
|
||||||
// Since we're changing levels of box indirection, we may have
|
// Since we're changing levels of box indirection, we may have
|
||||||
// to cast this pointer, since statically-sized tag types have
|
// to cast this pointer, since statically-sized enum types have
|
||||||
// different types depending on whether they're behind a box
|
// different types depending on whether they're behind a box
|
||||||
// or not.
|
// or not.
|
||||||
if check type_has_static_size(ccx, t1) {
|
if check type_has_static_size(ccx, t1) {
|
||||||
@ -2330,7 +2330,7 @@ fn trans_binary(cx: @block_ctxt, op: ast::binop, a: @ast::expr, b: @ast::expr,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag dest {
|
enum dest {
|
||||||
by_val(@mutable ValueRef);
|
by_val(@mutable ValueRef);
|
||||||
save_in(ValueRef);
|
save_in(ValueRef);
|
||||||
ignore;
|
ignore;
|
||||||
@ -2495,14 +2495,14 @@ type generic_info = {
|
|||||||
origins: option::t<typeck::dict_res>
|
origins: option::t<typeck::dict_res>
|
||||||
};
|
};
|
||||||
|
|
||||||
tag lval_kind {
|
enum lval_kind {
|
||||||
temporary; //< Temporary value passed by value if of immediate type
|
temporary; //< Temporary value passed by value if of immediate type
|
||||||
owned; //< Non-temporary value passed by pointer
|
owned; //< Non-temporary value passed by pointer
|
||||||
owned_imm; //< Non-temporary value passed by value
|
owned_imm; //< Non-temporary value passed by value
|
||||||
}
|
}
|
||||||
type local_var_result = {val: ValueRef, kind: lval_kind};
|
type local_var_result = {val: ValueRef, kind: lval_kind};
|
||||||
type lval_result = {bcx: @block_ctxt, val: ValueRef, kind: lval_kind};
|
type lval_result = {bcx: @block_ctxt, val: ValueRef, kind: lval_kind};
|
||||||
tag callee_env {
|
enum callee_env {
|
||||||
null_env;
|
null_env;
|
||||||
is_closure;
|
is_closure;
|
||||||
self_env(ValueRef);
|
self_env(ValueRef);
|
||||||
@ -2896,7 +2896,7 @@ fn trans_cast(cx: @block_ctxt, e: @ast::expr, id: ast::node_id,
|
|||||||
check (type_has_static_size(ccx, t_out));
|
check (type_has_static_size(ccx, t_out));
|
||||||
let ll_t_out = type_of(ccx, e.span, t_out);
|
let ll_t_out = type_of(ccx, e.span, t_out);
|
||||||
|
|
||||||
tag kind { pointer; integral; float; tag_; other; }
|
enum kind { pointer; integral; float; tag_; other; }
|
||||||
fn t_kind(tcx: ty::ctxt, t: ty::t) -> kind {
|
fn t_kind(tcx: ty::ctxt, t: ty::t) -> kind {
|
||||||
ret if ty::type_is_fp(tcx, t) {
|
ret if ty::type_is_fp(tcx, t) {
|
||||||
float
|
float
|
||||||
@ -3540,7 +3540,7 @@ fn trans_expr(bcx: @block_ctxt, e: @ast::expr, dest: dest) -> @block_ctxt {
|
|||||||
ret trans_ret(bcx, ex);
|
ret trans_ret(bcx, ex);
|
||||||
}
|
}
|
||||||
ast::expr_be(ex) {
|
ast::expr_be(ex) {
|
||||||
// Ideally, the expr_be tag would have a precondition
|
// Ideally, the expr_be enum would have a precondition
|
||||||
// that is_call_expr(ex) -- but we don't support that
|
// that is_call_expr(ex) -- but we don't support that
|
||||||
// yet
|
// yet
|
||||||
// FIXME
|
// FIXME
|
||||||
@ -4409,7 +4409,7 @@ fn finish_fn(fcx: @fn_ctxt, lltop: BasicBlockRef) {
|
|||||||
RetVoid(ret_cx);
|
RetVoid(ret_cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag self_arg { impl_self(ty::t); no_self; }
|
enum self_arg { impl_self(ty::t); no_self; }
|
||||||
|
|
||||||
// trans_closure: Builds an LLVM function out of a source function.
|
// trans_closure: Builds an LLVM function out of a source function.
|
||||||
// If the function closes over its environment a closure will be
|
// If the function closes over its environment a closure will be
|
||||||
@ -4557,7 +4557,7 @@ fn trans_tag_variant(cx: @local_ctxt, tag_id: ast::node_id,
|
|||||||
let lltop = bcx.llbb;
|
let lltop = bcx.llbb;
|
||||||
bcx = copy_args_to_allocas(fcx, bcx, fn_args, arg_tys);
|
bcx = copy_args_to_allocas(fcx, bcx, fn_args, arg_tys);
|
||||||
|
|
||||||
// Cast the tag to a type we can GEP into.
|
// Cast the enum to a type we can GEP into.
|
||||||
let llblobptr =
|
let llblobptr =
|
||||||
if is_degen {
|
if is_degen {
|
||||||
fcx.llretptr
|
fcx.llretptr
|
||||||
@ -4576,7 +4576,7 @@ fn trans_tag_variant(cx: @local_ctxt, tag_id: ast::node_id,
|
|||||||
let rslt = GEP_tag(bcx, llblobptr, t_id, v_id, ty_param_substs, i);
|
let rslt = GEP_tag(bcx, llblobptr, t_id, v_id, ty_param_substs, i);
|
||||||
bcx = rslt.bcx;
|
bcx = rslt.bcx;
|
||||||
let lldestptr = rslt.val;
|
let lldestptr = rslt.val;
|
||||||
// If this argument to this function is a tag, it'll have come in to
|
// If this argument to this function is a enum, it'll have come in to
|
||||||
// this function as an opaque blob due to the way that type_of()
|
// this function as an opaque blob due to the way that type_of()
|
||||||
// works. So we have to cast to the destination's view of the type.
|
// works. So we have to cast to the destination's view of the type.
|
||||||
let llarg = alt fcx.llargs.find(va.id) { some(local_mem(x)) { x } };
|
let llarg = alt fcx.llargs.find(va.id) { some(local_mem(x)) { x } };
|
||||||
@ -5222,7 +5222,7 @@ fn collect_item(ccx: @crate_ctxt, abi: @mutable option::t<ast::native_abi>,
|
|||||||
for variant in variants {
|
for variant in variants {
|
||||||
if vec::len(variant.node.args) != 0u {
|
if vec::len(variant.node.args) != 0u {
|
||||||
register_fn(ccx, i.span, new_pt + [variant.node.name],
|
register_fn(ccx, i.span, new_pt + [variant.node.name],
|
||||||
"tag", tps, variant.node.id);
|
"enum", tps, variant.node.id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,8 @@ import syntax::print::pprust::pat_to_str;
|
|||||||
|
|
||||||
import trans_common::*;
|
import trans_common::*;
|
||||||
|
|
||||||
// An option identifying a branch (either a literal, a tag variant or a range)
|
// An option identifying a branch (either a literal, a enum variant or a range)
|
||||||
tag opt {
|
enum opt {
|
||||||
lit(@ast::expr);
|
lit(@ast::expr);
|
||||||
var(/* disr val */int, /* variant dids */{tg: def_id, var: def_id});
|
var(/* disr val */int, /* variant dids */{tg: def_id, var: def_id});
|
||||||
range(@ast::expr, @ast::expr);
|
range(@ast::expr, @ast::expr);
|
||||||
@ -34,7 +34,7 @@ fn opt_eq(a: opt, b: opt) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag opt_result {
|
enum opt_result {
|
||||||
single_result(result);
|
single_result(result);
|
||||||
range_result(result, result);
|
range_result(result, result);
|
||||||
}
|
}
|
||||||
@ -284,7 +284,7 @@ fn extract_variant_args(bcx: @block_ctxt, pat_id: ast::node_id,
|
|||||||
let r =
|
let r =
|
||||||
// invariant needed:
|
// invariant needed:
|
||||||
// how do we know it even makes sense to pass in ty_param_substs
|
// how do we know it even makes sense to pass in ty_param_substs
|
||||||
// here? What if it's [] and the tag type has variables in it?
|
// here? What if it's [] and the enum type has variables in it?
|
||||||
trans::GEP_tag(bcx, blobptr, vdefs_tg, vdefs_var, ty_param_substs,
|
trans::GEP_tag(bcx, blobptr, vdefs_tg, vdefs_var, ty_param_substs,
|
||||||
i);
|
i);
|
||||||
bcx = r.bcx;
|
bcx = r.bcx;
|
||||||
@ -472,7 +472,7 @@ fn compile_submatch(bcx: @block_ctxt, m: match, vals: [ValueRef], f: mk_fail,
|
|||||||
|
|
||||||
// Decide what kind of branch we need
|
// Decide what kind of branch we need
|
||||||
let opts = get_options(ccx, m, col);
|
let opts = get_options(ccx, m, col);
|
||||||
tag branch_kind { no_branch; single; switch; compare; }
|
enum branch_kind { no_branch; single; switch; compare; }
|
||||||
let kind = no_branch;
|
let kind = no_branch;
|
||||||
let test_val = val;
|
let test_val = val;
|
||||||
if vec::len(opts) > 0u {
|
if vec::len(opts) > 0u {
|
||||||
|
@ -109,7 +109,7 @@ import trans::{
|
|||||||
//
|
//
|
||||||
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
tag environment_value {
|
enum environment_value {
|
||||||
// Evaluate expr and store result in env (used for bind).
|
// Evaluate expr and store result in env (used for bind).
|
||||||
env_expr(@ast::expr);
|
env_expr(@ast::expr);
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ fn new_namegen() -> namegen {
|
|||||||
|
|
||||||
type derived_tydesc_info = {lltydesc: ValueRef, escapes: bool};
|
type derived_tydesc_info = {lltydesc: ValueRef, escapes: bool};
|
||||||
|
|
||||||
tag tydesc_kind {
|
enum tydesc_kind {
|
||||||
tk_static; // Static (monomorphic) type descriptor
|
tk_static; // Static (monomorphic) type descriptor
|
||||||
tk_param; // Type parameter.
|
tk_param; // Type parameter.
|
||||||
tk_derived; // Derived from a typaram or another derived tydesc.
|
tk_derived; // Derived from a typaram or another derived tydesc.
|
||||||
@ -131,7 +131,7 @@ type local_ctxt =
|
|||||||
// Types used for llself.
|
// Types used for llself.
|
||||||
type val_self_pair = {v: ValueRef, t: ty::t};
|
type val_self_pair = {v: ValueRef, t: ty::t};
|
||||||
|
|
||||||
tag local_val { local_mem(ValueRef); local_imm(ValueRef); }
|
enum local_val { local_mem(ValueRef); local_imm(ValueRef); }
|
||||||
|
|
||||||
type fn_ty_param = {desc: ValueRef, dicts: option::t<[ValueRef]>};
|
type fn_ty_param = {desc: ValueRef, dicts: option::t<[ValueRef]>};
|
||||||
|
|
||||||
@ -242,7 +242,7 @@ type fn_ctxt =
|
|||||||
sp: span,
|
sp: span,
|
||||||
lcx: @local_ctxt};
|
lcx: @local_ctxt};
|
||||||
|
|
||||||
tag cleanup {
|
enum cleanup {
|
||||||
clean(fn@(@block_ctxt) -> @block_ctxt);
|
clean(fn@(@block_ctxt) -> @block_ctxt);
|
||||||
clean_temp(ValueRef, fn@(@block_ctxt) -> @block_ctxt);
|
clean_temp(ValueRef, fn@(@block_ctxt) -> @block_ctxt);
|
||||||
}
|
}
|
||||||
@ -331,7 +331,7 @@ fn get_res_dtor(ccx: @crate_ctxt, sp: span, did: ast::def_id, inner_t: ty::t)
|
|||||||
did), f_t);
|
did), f_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag block_kind {
|
enum block_kind {
|
||||||
|
|
||||||
|
|
||||||
// A scope block is a basic block created by translating a block { ... }
|
// A scope block is a basic block created by translating a block { ... }
|
||||||
@ -387,8 +387,8 @@ type block_ctxt =
|
|||||||
fcx: @fn_ctxt};
|
fcx: @fn_ctxt};
|
||||||
|
|
||||||
// FIXME: we should be able to use option::t<@block_parent> here but
|
// FIXME: we should be able to use option::t<@block_parent> here but
|
||||||
// the infinite-tag check in rustboot gets upset.
|
// the infinite-enum check in rustboot gets upset.
|
||||||
tag block_parent { parent_none; parent_some(@block_ctxt); }
|
enum block_parent { parent_none; parent_some(@block_ctxt); }
|
||||||
|
|
||||||
type result = {bcx: @block_ctxt, val: ValueRef};
|
type result = {bcx: @block_ctxt, val: ValueRef};
|
||||||
type result_t = {bcx: @block_ctxt, val: ValueRef, ty: ty::t};
|
type result_t = {bcx: @block_ctxt, val: ValueRef, ty: ty::t};
|
||||||
@ -885,7 +885,7 @@ pure fn type_is_tup_like(cx: @block_ctxt, t: ty::t) -> bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Used to identify cached dictionaries
|
// Used to identify cached dictionaries
|
||||||
tag dict_param {
|
enum dict_param {
|
||||||
dict_param_dict(dict_id);
|
dict_param_dict(dict_id);
|
||||||
dict_param_ty(ty::t);
|
dict_param_ty(ty::t);
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ import syntax::print::pprust::{constr_args_to_str, lit_to_str};
|
|||||||
|
|
||||||
// Used to communicate which operands should be invalidated
|
// Used to communicate which operands should be invalidated
|
||||||
// to helper functions
|
// to helper functions
|
||||||
tag oper_type {
|
enum oper_type {
|
||||||
oper_move;
|
oper_move;
|
||||||
oper_swap;
|
oper_swap;
|
||||||
oper_assign;
|
oper_assign;
|
||||||
@ -198,7 +198,7 @@ type pred_args = spanned<pred_args_>;
|
|||||||
// for this local.
|
// for this local.
|
||||||
type constr_arg_use = spanned<constr_arg_general_<inst>>;
|
type constr_arg_use = spanned<constr_arg_general_<inst>>;
|
||||||
|
|
||||||
tag constraint {
|
enum constraint {
|
||||||
cinit(uint, span, ident);
|
cinit(uint, span, ident);
|
||||||
|
|
||||||
// FIXME: really only want it to be mutable during collect_locals.
|
// FIXME: really only want it to be mutable during collect_locals.
|
||||||
@ -211,7 +211,7 @@ tag constraint {
|
|||||||
// predicate need not be local.
|
// predicate need not be local.
|
||||||
// FIXME: would be nice to give both a def_id field,
|
// FIXME: would be nice to give both a def_id field,
|
||||||
// and give ninit a constraint saying it's local.
|
// and give ninit a constraint saying it's local.
|
||||||
tag tsconstr {
|
enum tsconstr {
|
||||||
ninit(node_id, ident);
|
ninit(node_id, ident);
|
||||||
npred(@path, def_id, [@constr_arg_use]);
|
npred(@path, def_id, [@constr_arg_use]);
|
||||||
}
|
}
|
||||||
@ -780,7 +780,7 @@ fn replace(subst: subst, d: pred_args) -> [constr_arg_general_<inst>] {
|
|||||||
ret rslt;
|
ret rslt;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag if_ty { if_check; plain_if; }
|
enum if_ty { if_check; plain_if; }
|
||||||
|
|
||||||
fn local_node_id_to_def_id_strict(fcx: fn_ctxt, sp: span, i: node_id) ->
|
fn local_node_id_to_def_id_strict(fcx: fn_ctxt, sp: span, i: node_id) ->
|
||||||
def_id {
|
def_id {
|
||||||
|
@ -30,7 +30,7 @@ export to_str;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
type t = {uncertain: bitv::t, val: bitv::t, nbits: uint};
|
type t = {uncertain: bitv::t, val: bitv::t, nbits: uint};
|
||||||
tag trit { ttrue; tfalse; dont_care; }
|
enum trit { ttrue; tfalse; dont_care; }
|
||||||
|
|
||||||
fn create_tritv(len: uint) -> t {
|
fn create_tritv(len: uint) -> t {
|
||||||
ret {uncertain: bitv::create(len, true),
|
ret {uncertain: bitv::create(len, true),
|
||||||
|
@ -235,7 +235,7 @@ type raw_t = {struct: sty,
|
|||||||
|
|
||||||
type t = uint;
|
type t = uint;
|
||||||
|
|
||||||
tag closure_kind {
|
enum closure_kind {
|
||||||
ck_any;
|
ck_any;
|
||||||
ck_block;
|
ck_block;
|
||||||
ck_box;
|
ck_box;
|
||||||
@ -250,7 +250,7 @@ type fn_ty = {proto: ast::proto,
|
|||||||
|
|
||||||
// NB: If you change this, you'll probably want to change the corresponding
|
// NB: If you change this, you'll probably want to change the corresponding
|
||||||
// AST structure in front/ast::rs as well.
|
// AST structure in front/ast::rs as well.
|
||||||
tag sty {
|
enum sty {
|
||||||
ty_nil;
|
ty_nil;
|
||||||
ty_bot;
|
ty_bot;
|
||||||
ty_bool;
|
ty_bool;
|
||||||
@ -271,7 +271,7 @@ tag sty {
|
|||||||
ty_tup([t]);
|
ty_tup([t]);
|
||||||
ty_var(int); // type variable
|
ty_var(int); // type variable
|
||||||
|
|
||||||
ty_param(uint, def_id); // fn/tag type param
|
ty_param(uint, def_id); // fn/enum type param
|
||||||
|
|
||||||
ty_type; // type_desc*
|
ty_type; // type_desc*
|
||||||
ty_send_type; // type_desc* that has been cloned into exchange heap
|
ty_send_type; // type_desc* that has been cloned into exchange heap
|
||||||
@ -288,7 +288,7 @@ type type_constr = constr_general<@path>;
|
|||||||
type constr = constr_general<uint>;
|
type constr = constr_general<uint>;
|
||||||
|
|
||||||
// Data structures used in type unification
|
// Data structures used in type unification
|
||||||
tag type_err {
|
enum type_err {
|
||||||
terr_mismatch;
|
terr_mismatch;
|
||||||
terr_ret_style_mismatch(ast::ret_style, ast::ret_style);
|
terr_ret_style_mismatch(ast::ret_style, ast::ret_style);
|
||||||
terr_box_mutability;
|
terr_box_mutability;
|
||||||
@ -303,7 +303,7 @@ tag type_err {
|
|||||||
terr_constr_mismatch(@type_constr, @type_constr);
|
terr_constr_mismatch(@type_constr, @type_constr);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag param_bound {
|
enum param_bound {
|
||||||
bound_copy;
|
bound_copy;
|
||||||
bound_send;
|
bound_send;
|
||||||
bound_iface(t);
|
bound_iface(t);
|
||||||
@ -712,7 +712,7 @@ fn walk_ty(cx: ctxt, walker: ty_walk, ty: t) {
|
|||||||
walker(ty);
|
walker(ty);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag fold_mode {
|
enum fold_mode {
|
||||||
fm_var(fn@(int) -> t);
|
fm_var(fn@(int) -> t);
|
||||||
fm_param(fn@(uint, def_id) -> t);
|
fm_param(fn@(uint, def_id) -> t);
|
||||||
fm_general(fn@(t) -> t);
|
fm_general(fn@(t) -> t);
|
||||||
@ -973,7 +973,7 @@ fn type_needs_drop(cx: ctxt, ty: t) -> bool {
|
|||||||
ret result;
|
ret result;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag kind { kind_sendable; kind_copyable; kind_noncopyable; }
|
enum kind { kind_sendable; kind_copyable; kind_noncopyable; }
|
||||||
|
|
||||||
// Using these query functons is preferable to direct comparison or matching
|
// Using these query functons is preferable to direct comparison or matching
|
||||||
// against the kind constants, as we may modify the kind hierarchy in the
|
// against the kind constants, as we may modify the kind hierarchy in the
|
||||||
@ -1245,7 +1245,7 @@ fn type_is_tag(cx: ctxt, ty: t) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Whether a type is enum like, that is a tag type with only nullary
|
// Whether a type is enum like, that is a enum type with only nullary
|
||||||
// constructors
|
// constructors
|
||||||
fn type_is_c_like_enum(cx: ctxt, ty: t) -> bool {
|
fn type_is_c_like_enum(cx: ctxt, ty: t) -> bool {
|
||||||
alt struct(cx, ty) {
|
alt struct(cx, ty) {
|
||||||
@ -1732,16 +1732,16 @@ mod unify {
|
|||||||
export var_bindings;
|
export var_bindings;
|
||||||
export precise, in_bindings;
|
export precise, in_bindings;
|
||||||
|
|
||||||
tag result { ures_ok(t); ures_err(type_err); }
|
enum result { ures_ok(t); ures_err(type_err); }
|
||||||
tag union_result { unres_ok; unres_err(type_err); }
|
enum union_result { unres_ok; unres_err(type_err); }
|
||||||
tag fixup_result {
|
enum fixup_result {
|
||||||
fix_ok(t); // fixup succeeded
|
fix_ok(t); // fixup succeeded
|
||||||
fix_err(int); // fixup failed because a type variable was unresolved
|
fix_err(int); // fixup failed because a type variable was unresolved
|
||||||
}
|
}
|
||||||
type var_bindings =
|
type var_bindings =
|
||||||
{sets: ufind::ufind, types: smallintmap::smallintmap<t>};
|
{sets: ufind::ufind, types: smallintmap::smallintmap<t>};
|
||||||
|
|
||||||
tag unify_style {
|
enum unify_style {
|
||||||
precise;
|
precise;
|
||||||
in_bindings(@var_bindings);
|
in_bindings(@var_bindings);
|
||||||
}
|
}
|
||||||
@ -2041,7 +2041,7 @@ mod unify {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Specifies the allowable subtyping between expected and actual types
|
// Specifies the allowable subtyping between expected and actual types
|
||||||
tag variance {
|
enum variance {
|
||||||
// Actual may be a subtype of expected
|
// Actual may be a subtype of expected
|
||||||
covariant;
|
covariant;
|
||||||
// Actual may be a supertype of expected
|
// Actual may be a supertype of expected
|
||||||
@ -2676,7 +2676,7 @@ fn tag_variants(cx: ctxt, id: ast::def_id) -> @[variant_info] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Returns information about the tag variant with the given ID:
|
// Returns information about the enum variant with the given ID:
|
||||||
fn tag_variant_with_id(cx: ctxt, tag_id: ast::def_id, variant_id: ast::def_id)
|
fn tag_variant_with_id(cx: ctxt, tag_id: ast::def_id, variant_id: ast::def_id)
|
||||||
-> variant_info {
|
-> variant_info {
|
||||||
let variants = tag_variants(cx, tag_id);
|
let variants = tag_variants(cx, tag_id);
|
||||||
|
@ -23,7 +23,7 @@ export check_crate;
|
|||||||
export method_map, method_origin, method_static, method_param, method_iface;
|
export method_map, method_origin, method_static, method_param, method_iface;
|
||||||
export dict_map, dict_res, dict_origin, dict_static, dict_param, dict_iface;
|
export dict_map, dict_res, dict_origin, dict_static, dict_param, dict_iface;
|
||||||
|
|
||||||
tag method_origin {
|
enum method_origin {
|
||||||
method_static(ast::def_id);
|
method_static(ast::def_id);
|
||||||
// iface id, method num, param num, bound num
|
// iface id, method num, param num, bound num
|
||||||
method_param(ast::def_id, uint, uint, uint);
|
method_param(ast::def_id, uint, uint, uint);
|
||||||
@ -33,7 +33,7 @@ type method_map = hashmap<ast::node_id, method_origin>;
|
|||||||
|
|
||||||
// Resolutions for bounds of all parameters, left to right, for a given path.
|
// Resolutions for bounds of all parameters, left to right, for a given path.
|
||||||
type dict_res = @[dict_origin];
|
type dict_res = @[dict_origin];
|
||||||
tag dict_origin {
|
enum dict_origin {
|
||||||
dict_static(ast::def_id, [ty::t], dict_res);
|
dict_static(ast::def_id, [ty::t], dict_res);
|
||||||
// Param number, bound number
|
// Param number, bound number
|
||||||
dict_param(uint, uint);
|
dict_param(uint, uint);
|
||||||
@ -44,7 +44,7 @@ type dict_map = hashmap<ast::node_id, dict_res>;
|
|||||||
type ty_table = hashmap<ast::def_id, ty::t>;
|
type ty_table = hashmap<ast::def_id, ty::t>;
|
||||||
|
|
||||||
// Used for typechecking the methods of an impl
|
// Used for typechecking the methods of an impl
|
||||||
tag self_info {
|
enum self_info {
|
||||||
self_impl(ty::t);
|
self_impl(ty::t);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -231,7 +231,7 @@ fn default_arg_mode_for_ty(tcx: ty::ctxt, m: ast::mode,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag mode { m_collect; m_check; m_check_tyvar(@fn_ctxt); }
|
enum mode { m_collect; m_check; m_check_tyvar(@fn_ctxt); }
|
||||||
|
|
||||||
fn ast_ty_to_ty(tcx: ty::ctxt, mode: mode, &&ast_ty: @ast::ty) -> ty::t {
|
fn ast_ty_to_ty(tcx: ty::ctxt, mode: mode, &&ast_ty: @ast::ty) -> ty::t {
|
||||||
fn getter(tcx: ty::ctxt, mode: mode, id: ast::def_id)
|
fn getter(tcx: ty::ctxt, mode: mode, id: ast::def_id)
|
||||||
@ -263,7 +263,7 @@ fn ast_ty_to_ty(tcx: ty::ctxt, mode: mode, &&ast_ty: @ast::ty) -> ty::t {
|
|||||||
some(none) {
|
some(none) {
|
||||||
tcx.sess.span_fatal(ast_ty.span,
|
tcx.sess.span_fatal(ast_ty.span,
|
||||||
"illegal recursive type \
|
"illegal recursive type \
|
||||||
insert a tag in the cycle, \
|
insert a enum in the cycle, \
|
||||||
if this is desired)");
|
if this is desired)");
|
||||||
}
|
}
|
||||||
none { }
|
none { }
|
||||||
@ -650,7 +650,7 @@ mod collect {
|
|||||||
// Create a set of parameter types shared among all the variants.
|
// Create a set of parameter types shared among all the variants.
|
||||||
|
|
||||||
for variant: ast::variant in variants {
|
for variant: ast::variant in variants {
|
||||||
// Nullary tag constructors get turned into constants; n-ary tag
|
// Nullary enum constructors get turned into constants; n-ary enum
|
||||||
// constructors get turned into functions.
|
// constructors get turned into functions.
|
||||||
|
|
||||||
let result_ty = if vec::len(variant.node.args) == 0u {
|
let result_ty = if vec::len(variant.node.args) == 0u {
|
||||||
@ -921,7 +921,7 @@ fn are_compatible(fcx: @fn_ctxt, expected: ty::t, actual: ty::t) -> bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Returns the types of the arguments to a tag variant.
|
// Returns the types of the arguments to a enum variant.
|
||||||
fn variant_arg_types(ccx: @crate_ctxt, _sp: span, vid: ast::def_id,
|
fn variant_arg_types(ccx: @crate_ctxt, _sp: span, vid: ast::def_id,
|
||||||
tag_ty_params: [ty::t]) -> [ty::t] {
|
tag_ty_params: [ty::t]) -> [ty::t] {
|
||||||
let result: [ty::t] = [];
|
let result: [ty::t] = [];
|
||||||
@ -1243,10 +1243,10 @@ fn check_pat(fcx: @fn_ctxt, map: pat_util::pat_id_map, pat: @ast::pat,
|
|||||||
let tag_tpt = ty::lookup_item_type(fcx.ccx.tcx, v_def_ids.tg);
|
let tag_tpt = ty::lookup_item_type(fcx.ccx.tcx, v_def_ids.tg);
|
||||||
let path_tpot = instantiate_path(fcx, path, tag_tpt, pat.span);
|
let path_tpot = instantiate_path(fcx, path, tag_tpt, pat.span);
|
||||||
|
|
||||||
// Take the tag type params out of `expected`.
|
// Take the enum type params out of `expected`.
|
||||||
alt structure_of(fcx, pat.span, expected) {
|
alt structure_of(fcx, pat.span, expected) {
|
||||||
ty::ty_tag(_, expected_tps) {
|
ty::ty_tag(_, expected_tps) {
|
||||||
// Unify with the expected tag type.
|
// Unify with the expected enum type.
|
||||||
let ctor_ty =
|
let ctor_ty =
|
||||||
ty::ty_param_substs_opt_and_ty_to_monotype(fcx.ccx.tcx,
|
ty::ty_param_substs_opt_and_ty_to_monotype(fcx.ccx.tcx,
|
||||||
path_tpot);
|
path_tpot);
|
||||||
@ -1257,7 +1257,7 @@ fn check_pat(fcx: @fn_ctxt, map: pat_util::pat_id_map, pat: @ast::pat,
|
|||||||
path_tpot =
|
path_tpot =
|
||||||
{substs: some::<[ty::t]>(path_tpt.substs), ty: path_tpt.ty};
|
{substs: some::<[ty::t]>(path_tpt.substs), ty: path_tpt.ty};
|
||||||
|
|
||||||
// Get the number of arguments in this tag variant.
|
// Get the number of arguments in this enum variant.
|
||||||
let arg_types =
|
let arg_types =
|
||||||
variant_arg_types(fcx.ccx, pat.span, v_def_ids.var,
|
variant_arg_types(fcx.ccx, pat.span, v_def_ids.var,
|
||||||
expected_tps);
|
expected_tps);
|
||||||
@ -1267,7 +1267,7 @@ fn check_pat(fcx: @fn_ctxt, map: pat_util::pat_id_map, pat: @ast::pat,
|
|||||||
|
|
||||||
let arg_len = vec::len::<ty::t>(arg_types);
|
let arg_len = vec::len::<ty::t>(arg_types);
|
||||||
if arg_len != subpats_len {
|
if arg_len != subpats_len {
|
||||||
// TODO: note definition of tag variant
|
// TODO: note definition of enum variant
|
||||||
// TODO (issue #448): Wrap a #fmt string over multiple
|
// TODO (issue #448): Wrap a #fmt string over multiple
|
||||||
// lines...
|
// lines...
|
||||||
let s =
|
let s =
|
||||||
@ -1287,7 +1287,7 @@ fn check_pat(fcx: @fn_ctxt, map: pat_util::pat_id_map, pat: @ast::pat,
|
|||||||
i += 1u;
|
i += 1u;
|
||||||
}
|
}
|
||||||
} else if subpats_len > 0u {
|
} else if subpats_len > 0u {
|
||||||
// TODO: note definition of tag variant
|
// TODO: note definition of enum variant
|
||||||
fcx.ccx.tcx.sess.span_fatal
|
fcx.ccx.tcx.sess.span_fatal
|
||||||
(pat.span,
|
(pat.span,
|
||||||
#fmt["this pattern has %u field%s, \
|
#fmt["this pattern has %u field%s, \
|
||||||
@ -1305,7 +1305,7 @@ fn check_pat(fcx: @fn_ctxt, map: pat_util::pat_id_map, pat: @ast::pat,
|
|||||||
// can never tell.
|
// can never tell.
|
||||||
fcx.ccx.tcx.sess.span_fatal
|
fcx.ccx.tcx.sess.span_fatal
|
||||||
(pat.span,
|
(pat.span,
|
||||||
#fmt["mismatched types: expected `%s` but found tag",
|
#fmt["mismatched types: expected `%s` but found enum",
|
||||||
ty_to_str(fcx.ccx.tcx, expected)]);
|
ty_to_str(fcx.ccx.tcx, expected)]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ type def_id = {crate: crate_num, node: node_id};
|
|||||||
const local_crate: crate_num = 0;
|
const local_crate: crate_num = 0;
|
||||||
const crate_node_id: node_id = 0;
|
const crate_node_id: node_id = 0;
|
||||||
|
|
||||||
tag ty_param_bound {
|
enum ty_param_bound {
|
||||||
bound_copy;
|
bound_copy;
|
||||||
bound_send;
|
bound_send;
|
||||||
bound_iface(@ty);
|
bound_iface(@ty);
|
||||||
@ -32,7 +32,7 @@ tag ty_param_bound {
|
|||||||
|
|
||||||
type ty_param = {ident: ident, id: node_id, bounds: @[ty_param_bound]};
|
type ty_param = {ident: ident, id: node_id, bounds: @[ty_param_bound]};
|
||||||
|
|
||||||
tag def {
|
enum def {
|
||||||
def_fn(def_id, purity);
|
def_fn(def_id, purity);
|
||||||
def_self(def_id);
|
def_self(def_id);
|
||||||
def_mod(def_id);
|
def_mod(def_id);
|
||||||
@ -40,7 +40,7 @@ tag def {
|
|||||||
def_const(def_id);
|
def_const(def_id);
|
||||||
def_arg(def_id, mode);
|
def_arg(def_id, mode);
|
||||||
def_local(def_id, let_style);
|
def_local(def_id, let_style);
|
||||||
def_variant(def_id /* tag */, def_id /* variant */);
|
def_variant(def_id /* enum */, def_id /* variant */);
|
||||||
def_ty(def_id);
|
def_ty(def_id);
|
||||||
def_ty_param(def_id, uint);
|
def_ty_param(def_id, uint);
|
||||||
def_binding(def_id);
|
def_binding(def_id);
|
||||||
@ -62,13 +62,13 @@ type crate_ =
|
|||||||
attrs: [attribute],
|
attrs: [attribute],
|
||||||
config: crate_cfg};
|
config: crate_cfg};
|
||||||
|
|
||||||
tag crate_directive_ {
|
enum crate_directive_ {
|
||||||
cdir_src_mod(ident, [attribute]);
|
cdir_src_mod(ident, [attribute]);
|
||||||
cdir_dir_mod(ident, [@crate_directive], [attribute]);
|
cdir_dir_mod(ident, [@crate_directive], [attribute]);
|
||||||
|
|
||||||
// NB: cdir_view_item is *not* processed by the rest of the compiler; the
|
// NB: cdir_view_item is *not* processed by the rest of the compiler; the
|
||||||
// attached view_items are sunk into the crate's module during parsing,
|
// attached view_items are sunk into the crate's module during parsing,
|
||||||
// and processed (resolved, imported, etc.) there. This tag-variant exists
|
// and processed (resolved, imported, etc.) there. This enum-variant exists
|
||||||
// only to preserve the view items in order in case we decide to
|
// only to preserve the view items in order in case we decide to
|
||||||
// pretty-print crates in the future.
|
// pretty-print crates in the future.
|
||||||
cdir_view_item(@view_item);
|
cdir_view_item(@view_item);
|
||||||
@ -80,7 +80,7 @@ type crate_directive = spanned<crate_directive_>;
|
|||||||
|
|
||||||
type meta_item = spanned<meta_item_>;
|
type meta_item = spanned<meta_item_>;
|
||||||
|
|
||||||
tag meta_item_ {
|
enum meta_item_ {
|
||||||
meta_word(ident);
|
meta_word(ident);
|
||||||
meta_list(ident, [@meta_item]);
|
meta_list(ident, [@meta_item]);
|
||||||
meta_name_value(ident, lit);
|
meta_name_value(ident, lit);
|
||||||
@ -95,12 +95,12 @@ type pat = {id: node_id, node: pat_, span: span};
|
|||||||
|
|
||||||
type field_pat = {ident: ident, pat: @pat};
|
type field_pat = {ident: ident, pat: @pat};
|
||||||
|
|
||||||
tag pat_ {
|
enum pat_ {
|
||||||
pat_wild;
|
pat_wild;
|
||||||
// A pat_ident may either be a new bound variable,
|
// A pat_ident may either be a new bound variable,
|
||||||
// or a nullary tag (in which case the second field
|
// or a nullary enum (in which case the second field
|
||||||
// is none).
|
// is none).
|
||||||
// In the nullary tag case, the parser can't determine
|
// In the nullary enum case, the parser can't determine
|
||||||
// which it is. The resolver determines this, and
|
// which it is. The resolver determines this, and
|
||||||
// records this pattern's node_id in an auxiliary
|
// records this pattern's node_id in an auxiliary
|
||||||
// set (of "pat_idents that refer to nullary tags")
|
// set (of "pat_idents that refer to nullary tags")
|
||||||
@ -117,9 +117,9 @@ tag pat_ {
|
|||||||
pat_range(@expr, @expr);
|
pat_range(@expr, @expr);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag mutability { mut; imm; maybe_mut; }
|
enum mutability { mut; imm; maybe_mut; }
|
||||||
|
|
||||||
tag proto {
|
enum proto {
|
||||||
proto_bare; // native fn
|
proto_bare; // native fn
|
||||||
proto_any; // fn
|
proto_any; // fn
|
||||||
proto_uniq; // fn~
|
proto_uniq; // fn~
|
||||||
@ -134,7 +134,7 @@ pure fn is_blockish(p: ast::proto) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag binop {
|
enum binop {
|
||||||
add;
|
add;
|
||||||
subtract;
|
subtract;
|
||||||
mul;
|
mul;
|
||||||
@ -156,17 +156,17 @@ tag binop {
|
|||||||
gt;
|
gt;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag unop {
|
enum unop {
|
||||||
box(mutability);
|
box(mutability);
|
||||||
uniq(mutability);
|
uniq(mutability);
|
||||||
deref; not; neg;
|
deref; not; neg;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag mode { by_ref; by_val; by_mut_ref; by_move; by_copy; mode_infer; }
|
enum mode { by_ref; by_val; by_mut_ref; by_move; by_copy; mode_infer; }
|
||||||
|
|
||||||
type stmt = spanned<stmt_>;
|
type stmt = spanned<stmt_>;
|
||||||
|
|
||||||
tag stmt_ {
|
enum stmt_ {
|
||||||
stmt_decl(@decl, node_id);
|
stmt_decl(@decl, node_id);
|
||||||
|
|
||||||
// expr without trailing semi-colon (must have unit type):
|
// expr without trailing semi-colon (must have unit type):
|
||||||
@ -176,7 +176,7 @@ tag stmt_ {
|
|||||||
stmt_semi(@expr, node_id);
|
stmt_semi(@expr, node_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag init_op { init_assign; init_move; }
|
enum init_op { init_assign; init_move; }
|
||||||
|
|
||||||
type initializer = {op: init_op, expr: @expr};
|
type initializer = {op: init_op, expr: @expr};
|
||||||
|
|
||||||
@ -187,9 +187,9 @@ type local = spanned<local_>;
|
|||||||
|
|
||||||
type decl = spanned<decl_>;
|
type decl = spanned<decl_>;
|
||||||
|
|
||||||
tag let_style { let_copy; let_ref; }
|
enum let_style { let_copy; let_ref; }
|
||||||
|
|
||||||
tag decl_ { decl_local([(let_style, @local)]); decl_item(@item); }
|
enum decl_ { decl_local([(let_style, @local)]); decl_item(@item); }
|
||||||
|
|
||||||
type arm = {pats: [@pat], guard: option::t<@expr>, body: blk};
|
type arm = {pats: [@pat], guard: option::t<@expr>, body: blk};
|
||||||
|
|
||||||
@ -197,13 +197,13 @@ type field_ = {mut: mutability, ident: ident, expr: @expr};
|
|||||||
|
|
||||||
type field = spanned<field_>;
|
type field = spanned<field_>;
|
||||||
|
|
||||||
tag blk_check_mode { default_blk; unchecked_blk; unsafe_blk; }
|
enum blk_check_mode { default_blk; unchecked_blk; unsafe_blk; }
|
||||||
|
|
||||||
tag expr_check_mode { claimed_expr; checked_expr; }
|
enum expr_check_mode { claimed_expr; checked_expr; }
|
||||||
|
|
||||||
type expr = {id: node_id, node: expr_, span: span};
|
type expr = {id: node_id, node: expr_, span: span};
|
||||||
|
|
||||||
tag expr_ {
|
enum expr_ {
|
||||||
expr_vec([@expr], mutability);
|
expr_vec([@expr], mutability);
|
||||||
expr_rec([field], option::t<@expr>);
|
expr_rec([field], option::t<@expr>);
|
||||||
expr_call(@expr, [@expr], bool);
|
expr_call(@expr, [@expr], bool);
|
||||||
@ -267,7 +267,7 @@ type capture_clause = {
|
|||||||
/*
|
/*
|
||||||
// Says whether this is a block the user marked as
|
// Says whether this is a block the user marked as
|
||||||
// "unchecked"
|
// "unchecked"
|
||||||
tag blk_sort {
|
enum blk_sort {
|
||||||
blk_unchecked; // declared as "exception to effect-checking rules"
|
blk_unchecked; // declared as "exception to effect-checking rules"
|
||||||
blk_checked; // all typing rules apply
|
blk_checked; // all typing rules apply
|
||||||
}
|
}
|
||||||
@ -275,7 +275,7 @@ tag blk_sort {
|
|||||||
|
|
||||||
type mac = spanned<mac_>;
|
type mac = spanned<mac_>;
|
||||||
|
|
||||||
tag mac_ {
|
enum mac_ {
|
||||||
mac_invoc(@path, @expr, option::t<str>);
|
mac_invoc(@path, @expr, option::t<str>);
|
||||||
mac_embed_type(@ty);
|
mac_embed_type(@ty);
|
||||||
mac_embed_block(blk);
|
mac_embed_block(blk);
|
||||||
@ -284,7 +284,7 @@ tag mac_ {
|
|||||||
|
|
||||||
type lit = spanned<lit_>;
|
type lit = spanned<lit_>;
|
||||||
|
|
||||||
tag lit_ {
|
enum lit_ {
|
||||||
lit_str(str);
|
lit_str(str);
|
||||||
lit_int(i64, int_ty);
|
lit_int(i64, int_ty);
|
||||||
lit_uint(u64, uint_ty);
|
lit_uint(u64, uint_ty);
|
||||||
@ -303,15 +303,15 @@ type ty_field = spanned<ty_field_>;
|
|||||||
|
|
||||||
type ty_method = {ident: ident, decl: fn_decl, tps: [ty_param], span: span};
|
type ty_method = {ident: ident, decl: fn_decl, tps: [ty_param], span: span};
|
||||||
|
|
||||||
tag int_ty { ty_i; ty_char; ty_i8; ty_i16; ty_i32; ty_i64; }
|
enum int_ty { ty_i; ty_char; ty_i8; ty_i16; ty_i32; ty_i64; }
|
||||||
|
|
||||||
tag uint_ty { ty_u; ty_u8; ty_u16; ty_u32; ty_u64; }
|
enum uint_ty { ty_u; ty_u8; ty_u16; ty_u32; ty_u64; }
|
||||||
|
|
||||||
tag float_ty { ty_f; ty_f32; ty_f64; }
|
enum float_ty { ty_f; ty_f32; ty_f64; }
|
||||||
|
|
||||||
type ty = spanned<ty_>;
|
type ty = spanned<ty_>;
|
||||||
|
|
||||||
tag ty_ {
|
enum ty_ {
|
||||||
ty_nil;
|
ty_nil;
|
||||||
ty_bot; /* return type of ! functions and type of
|
ty_bot; /* return type of ! functions and type of
|
||||||
ret/fail/break/cont. there is no syntax
|
ret/fail/break/cont. there is no syntax
|
||||||
@ -354,7 +354,7 @@ so that the typestate pass doesn't have to map a function name onto its decl.
|
|||||||
So, the constr_arg type is parameterized: it's instantiated with uint for
|
So, the constr_arg type is parameterized: it's instantiated with uint for
|
||||||
declarations, and ident for uses.
|
declarations, and ident for uses.
|
||||||
*/
|
*/
|
||||||
tag constr_arg_general_<T> { carg_base; carg_ident(T); carg_lit(@lit); }
|
enum constr_arg_general_<T> { carg_base; carg_ident(T); carg_lit(@lit); }
|
||||||
|
|
||||||
type fn_constr_arg = constr_arg_general_<uint>;
|
type fn_constr_arg = constr_arg_general_<uint>;
|
||||||
type sp_constr_arg<T> = spanned<constr_arg_general_<T>>;
|
type sp_constr_arg<T> = spanned<constr_arg_general_<T>>;
|
||||||
@ -389,13 +389,13 @@ type fn_decl =
|
|||||||
cf: ret_style,
|
cf: ret_style,
|
||||||
constraints: [@constr]};
|
constraints: [@constr]};
|
||||||
|
|
||||||
tag purity {
|
enum purity {
|
||||||
pure_fn; // declared with "pure fn"
|
pure_fn; // declared with "pure fn"
|
||||||
unsafe_fn; // declared with "unsafe fn"
|
unsafe_fn; // declared with "unsafe fn"
|
||||||
impure_fn; // declared with "fn"
|
impure_fn; // declared with "fn"
|
||||||
}
|
}
|
||||||
|
|
||||||
tag ret_style {
|
enum ret_style {
|
||||||
noreturn; // functions with return type _|_ that always
|
noreturn; // functions with return type _|_ that always
|
||||||
// raise an error or exit (i.e. never return to the caller)
|
// raise an error or exit (i.e. never return to the caller)
|
||||||
return_val; // everything else
|
return_val; // everything else
|
||||||
@ -406,7 +406,7 @@ type method = {ident: ident, tps: [ty_param], decl: fn_decl, body: blk,
|
|||||||
|
|
||||||
type _mod = {view_items: [@view_item], items: [@item]};
|
type _mod = {view_items: [@view_item], items: [@item]};
|
||||||
|
|
||||||
tag native_abi {
|
enum native_abi {
|
||||||
native_abi_rust_intrinsic;
|
native_abi_rust_intrinsic;
|
||||||
native_abi_cdecl;
|
native_abi_cdecl;
|
||||||
native_abi_stdcall;
|
native_abi_stdcall;
|
||||||
@ -433,7 +433,7 @@ type import_ident_ = {name: ident, id: node_id};
|
|||||||
|
|
||||||
type import_ident = spanned<import_ident_>;
|
type import_ident = spanned<import_ident_>;
|
||||||
|
|
||||||
tag view_item_ {
|
enum view_item_ {
|
||||||
view_item_use(ident, [@meta_item], node_id);
|
view_item_use(ident, [@meta_item], node_id);
|
||||||
view_item_import(ident, @simple_path, node_id);
|
view_item_import(ident, @simple_path, node_id);
|
||||||
view_item_import_glob(@simple_path, node_id);
|
view_item_import_glob(@simple_path, node_id);
|
||||||
@ -448,14 +448,14 @@ type attribute = spanned<attribute_>;
|
|||||||
// Distinguishes between attributes that decorate items and attributes that
|
// Distinguishes between attributes that decorate items and attributes that
|
||||||
// are contained as statements within items. These two cases need to be
|
// are contained as statements within items. These two cases need to be
|
||||||
// distinguished for pretty-printing.
|
// distinguished for pretty-printing.
|
||||||
tag attr_style { attr_outer; attr_inner; }
|
enum attr_style { attr_outer; attr_inner; }
|
||||||
|
|
||||||
type attribute_ = {style: attr_style, value: meta_item};
|
type attribute_ = {style: attr_style, value: meta_item};
|
||||||
|
|
||||||
type item = {ident: ident, attrs: [attribute],
|
type item = {ident: ident, attrs: [attribute],
|
||||||
id: node_id, node: item_, span: span};
|
id: node_id, node: item_, span: span};
|
||||||
|
|
||||||
tag item_ {
|
enum item_ {
|
||||||
item_const(@ty, @expr);
|
item_const(@ty, @expr);
|
||||||
item_fn(fn_decl, [ty_param], blk);
|
item_fn(fn_decl, [ty_param], blk);
|
||||||
item_mod(_mod);
|
item_mod(_mod);
|
||||||
@ -476,7 +476,7 @@ type native_item =
|
|||||||
id: node_id,
|
id: node_id,
|
||||||
span: span};
|
span: span};
|
||||||
|
|
||||||
tag native_item_ {
|
enum native_item_ {
|
||||||
native_item_ty;
|
native_item_ty;
|
||||||
native_item_fn(fn_decl, [ty_param]);
|
native_item_fn(fn_decl, [ty_param]);
|
||||||
}
|
}
|
||||||
|
@ -201,7 +201,7 @@ fn ternary_to_if(e: @expr) -> @expr {
|
|||||||
|
|
||||||
// FIXME this doesn't handle big integer/float literals correctly (nor does
|
// FIXME this doesn't handle big integer/float literals correctly (nor does
|
||||||
// the rest of our literal handling)
|
// the rest of our literal handling)
|
||||||
tag const_val {
|
enum const_val {
|
||||||
const_float(float);
|
const_float(float);
|
||||||
const_int(i64);
|
const_int(i64);
|
||||||
const_uint(u64);
|
const_uint(u64);
|
||||||
|
@ -65,7 +65,7 @@ fn lookup_byte_pos(map: codemap, pos: uint) -> loc {
|
|||||||
ret lookup_pos(map, pos, lookup);
|
ret lookup_pos(map, pos, lookup);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag opt_span {
|
enum opt_span {
|
||||||
|
|
||||||
//hack (as opposed to option::t), to make `span` compile
|
//hack (as opposed to option::t), to make `span` compile
|
||||||
os_none;
|
os_none;
|
||||||
|
@ -11,7 +11,7 @@ type macro_def = {ident: str, ext: syntax_extension};
|
|||||||
type macro_definer =
|
type macro_definer =
|
||||||
fn@(ext_ctxt, span, @ast::expr, option::t<str>) -> macro_def;
|
fn@(ext_ctxt, span, @ast::expr, option::t<str>) -> macro_def;
|
||||||
|
|
||||||
tag syntax_extension {
|
enum syntax_extension {
|
||||||
normal(syntax_expander);
|
normal(syntax_expander);
|
||||||
macro_defining(macro_definer);
|
macro_defining(macro_definer);
|
||||||
}
|
}
|
||||||
|
@ -25,10 +25,10 @@ fn path_to_ident(pth: @path) -> option::t<ident> {
|
|||||||
type clause = {params: binders, body: @expr};
|
type clause = {params: binders, body: @expr};
|
||||||
|
|
||||||
/* logically, an arb_depth should contain only one kind of matchable */
|
/* logically, an arb_depth should contain only one kind of matchable */
|
||||||
tag arb_depth<T> { leaf(T); seq(@[arb_depth<T>], span); }
|
enum arb_depth<T> { leaf(T); seq(@[arb_depth<T>], span); }
|
||||||
|
|
||||||
|
|
||||||
tag matchable {
|
enum matchable {
|
||||||
match_expr(@expr);
|
match_expr(@expr);
|
||||||
match_path(@path);
|
match_path(@path);
|
||||||
match_ident(ast::spanned<ident>);
|
match_ident(ast::spanned<ident>);
|
||||||
|
@ -510,7 +510,7 @@ fn next_token_inner(rdr: reader) -> token::token {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag cmnt_style {
|
enum cmnt_style {
|
||||||
isolated; // No code on either side of each line of the comment
|
isolated; // No code on either side of each line of the comment
|
||||||
trailing; // Code exists to the left of the comment
|
trailing; // Code exists to the left of the comment
|
||||||
mixed; // Code before /* foo */ and after the comment
|
mixed; // Code before /* foo */ and after the comment
|
||||||
|
@ -13,14 +13,14 @@ import front::attr;
|
|||||||
import lexer::reader;
|
import lexer::reader;
|
||||||
import driver::diagnostic;
|
import driver::diagnostic;
|
||||||
|
|
||||||
tag restriction {
|
enum restriction {
|
||||||
UNRESTRICTED;
|
UNRESTRICTED;
|
||||||
RESTRICT_STMT_EXPR;
|
RESTRICT_STMT_EXPR;
|
||||||
RESTRICT_NO_CALL_EXPRS;
|
RESTRICT_NO_CALL_EXPRS;
|
||||||
RESTRICT_NO_BAR_OP;
|
RESTRICT_NO_BAR_OP;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag file_type { CRATE_FILE; SOURCE_FILE; }
|
enum file_type { CRATE_FILE; SOURCE_FILE; }
|
||||||
|
|
||||||
type parse_sess = @{
|
type parse_sess = @{
|
||||||
cm: codemap::codemap,
|
cm: codemap::codemap,
|
||||||
@ -147,7 +147,7 @@ fn bad_expr_word_table() -> hashmap<str, ()> {
|
|||||||
"cont", "ret", "be", "fail", "type", "resource", "check",
|
"cont", "ret", "be", "fail", "type", "resource", "check",
|
||||||
"assert", "claim", "native", "fn", "pure",
|
"assert", "claim", "native", "fn", "pure",
|
||||||
"unsafe", "block", "import", "export", "let", "const",
|
"unsafe", "block", "import", "export", "let", "const",
|
||||||
"log", "copy", "sendfn", "impl", "iface", "enum"] {
|
"log", "copy", "sendfn", "impl", "iface", "tag", "enum"] {
|
||||||
words.insert(word, ());
|
words.insert(word, ());
|
||||||
}
|
}
|
||||||
words
|
words
|
||||||
@ -719,9 +719,9 @@ fn mk_lit_u32(p: parser, i: u32) -> @ast::expr {
|
|||||||
// parsing because `(while{...})+3` parses differently from `while{...}+3`.
|
// parsing because `(while{...})+3` parses differently from `while{...}+3`.
|
||||||
//
|
//
|
||||||
// To reflect the fact that the @ast::expr is not a true expr that should be
|
// To reflect the fact that the @ast::expr is not a true expr that should be
|
||||||
// part of the AST, we wrap such expressions in the pexpr tag. They
|
// part of the AST, we wrap such expressions in the pexpr enum. They
|
||||||
// can then be converted to true expressions by a call to `to_expr()`.
|
// can then be converted to true expressions by a call to `to_expr()`.
|
||||||
tag pexpr {
|
enum pexpr {
|
||||||
pexpr(@ast::expr);
|
pexpr(@ast::expr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1508,7 +1508,7 @@ fn parse_pat(p: parser) -> @ast::pat {
|
|||||||
}
|
}
|
||||||
_ { args = []; }
|
_ { args = []; }
|
||||||
}
|
}
|
||||||
// at this point, we're not sure whether it's a tag or a bind
|
// at this point, we're not sure whether it's a enum or a bind
|
||||||
if vec::len(args) == 0u &&
|
if vec::len(args) == 0u &&
|
||||||
vec::len(tag_path.node.idents) == 1u {
|
vec::len(tag_path.node.idents) == 1u {
|
||||||
pat = ast::pat_ident(tag_path, none);
|
pat = ast::pat_ident(tag_path, none);
|
||||||
@ -2026,7 +2026,7 @@ fn parse_item_tag(p: parser, attrs: [ast::attribute]) -> @ast::item {
|
|||||||
// Newtype syntax
|
// Newtype syntax
|
||||||
if p.token == token::EQ {
|
if p.token == token::EQ {
|
||||||
if p.bad_expr_words.contains_key(id) {
|
if p.bad_expr_words.contains_key(id) {
|
||||||
p.fatal("found " + id + " in tag constructor position");
|
p.fatal("found " + id + " in enum constructor position");
|
||||||
}
|
}
|
||||||
p.bump();
|
p.bump();
|
||||||
let ty = parse_ty(p, false);
|
let ty = parse_ty(p, false);
|
||||||
|
@ -5,7 +5,7 @@ import lexer::reader;
|
|||||||
|
|
||||||
type str_num = uint;
|
type str_num = uint;
|
||||||
|
|
||||||
tag binop {
|
enum binop {
|
||||||
PLUS;
|
PLUS;
|
||||||
MINUS;
|
MINUS;
|
||||||
STAR;
|
STAR;
|
||||||
@ -19,7 +19,7 @@ tag binop {
|
|||||||
ASR;
|
ASR;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag token {
|
enum token {
|
||||||
/* Expression-operator symbols. */
|
/* Expression-operator symbols. */
|
||||||
EQ;
|
EQ;
|
||||||
LT;
|
LT;
|
||||||
|
@ -55,13 +55,13 @@ import io::writer_util;
|
|||||||
* line (which it can't) and so naturally place the content on its own line to
|
* line (which it can't) and so naturally place the content on its own line to
|
||||||
* avoid combining it with other lines and making matters even worse.
|
* avoid combining it with other lines and making matters even worse.
|
||||||
*/
|
*/
|
||||||
tag breaks { consistent; inconsistent; }
|
enum breaks { consistent; inconsistent; }
|
||||||
|
|
||||||
type break_t = {offset: int, blank_space: int};
|
type break_t = {offset: int, blank_space: int};
|
||||||
|
|
||||||
type begin_t = {offset: int, breaks: breaks};
|
type begin_t = {offset: int, breaks: breaks};
|
||||||
|
|
||||||
tag token { STRING(str, int); BREAK(break_t); BEGIN(begin_t); END; EOF; }
|
enum token { STRING(str, int); BREAK(break_t); BEGIN(begin_t); END; EOF; }
|
||||||
|
|
||||||
fn tok_str(t: token) -> str {
|
fn tok_str(t: token) -> str {
|
||||||
alt t {
|
alt t {
|
||||||
@ -91,7 +91,7 @@ fn buf_str(toks: [mutable token], szs: [mutable int], left: uint, right: uint,
|
|||||||
ret s;
|
ret s;
|
||||||
}
|
}
|
||||||
|
|
||||||
tag print_stack_break { fits; broken(breaks); }
|
enum print_stack_break { fits; broken(breaks); }
|
||||||
|
|
||||||
type print_stack_elt = {offset: int, pbreak: print_stack_break};
|
type print_stack_elt = {offset: int, pbreak: print_stack_break};
|
||||||
|
|
||||||
|
@ -12,8 +12,8 @@ import pp::{break_offset, word, printer,
|
|||||||
import driver::diagnostic;
|
import driver::diagnostic;
|
||||||
|
|
||||||
// The ps is stored here to prevent recursive type.
|
// The ps is stored here to prevent recursive type.
|
||||||
// FIXME use a nominal tag instead
|
// FIXME use a nominal enum instead
|
||||||
tag ann_node {
|
enum ann_node {
|
||||||
node_block(ps, ast::blk);
|
node_block(ps, ast::blk);
|
||||||
node_item(ps, @ast::item);
|
node_item(ps, @ast::item);
|
||||||
node_expr(ps, @ast::expr);
|
node_expr(ps, @ast::expr);
|
||||||
@ -565,7 +565,7 @@ fn print_block_with_attrs(s: ps, blk: ast::blk, attrs: [ast::attribute]) {
|
|||||||
print_possibly_embedded_block_(s, blk, block_normal, indent_unit, attrs);
|
print_possibly_embedded_block_(s, blk, block_normal, indent_unit, attrs);
|
||||||
}
|
}
|
||||||
|
|
||||||
tag embed_type { block_macro; block_block_fn; block_normal; }
|
enum embed_type { block_macro; block_block_fn; block_normal; }
|
||||||
|
|
||||||
fn print_possibly_embedded_block(s: ps, blk: ast::blk, embedded: embed_type,
|
fn print_possibly_embedded_block(s: ps, blk: ast::blk, embedded: embed_type,
|
||||||
indented: uint) {
|
indented: uint) {
|
||||||
|
@ -12,10 +12,10 @@ import codemap::span;
|
|||||||
// override the context), or prevent deeper traversal by doing nothing.
|
// override the context), or prevent deeper traversal by doing nothing.
|
||||||
|
|
||||||
// Our typesystem doesn't do circular types, so the visitor record can not
|
// Our typesystem doesn't do circular types, so the visitor record can not
|
||||||
// hold functions that take visitors. A vt tag is used to break the cycle.
|
// hold functions that take visitors. A vt enum is used to break the cycle.
|
||||||
tag vt<E> { mk_vt(visitor<E>); }
|
enum vt<E> { mk_vt(visitor<E>); }
|
||||||
|
|
||||||
tag fn_kind {
|
enum fn_kind {
|
||||||
fk_item_fn(ident, [ty_param]); //< an item declared with fn()
|
fk_item_fn(ident, [ty_param]); //< an item declared with fn()
|
||||||
fk_method(ident, [ty_param]);
|
fk_method(ident, [ty_param]);
|
||||||
fk_res(ident, [ty_param]);
|
fk_res(ident, [ty_param]);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user