diff options
| author | Patrick Walton <pcwalton@mimiga.net> | 2011-07-05 17:57:34 -0700 |
|---|---|---|
| committer | Patrick Walton <pcwalton@mimiga.net> | 2011-07-06 11:09:08 -0700 |
| commit | ec890fff23d80da97086e89f29ef7f8d14dbaab8 (patch) | |
| tree | 6375d90036e494fd2644d020df7f56fab36cd12e /src/comp/front | |
| parent | 3f6c9f8d8495bb83ee9afd3894f7dd16065419d2 (diff) | |
| download | rust-ec890fff23d80da97086e89f29ef7f8d14dbaab8.tar.gz rust-ec890fff23d80da97086e89f29ef7f8d14dbaab8.zip | |
Temp commit on the way to making meta_item into an interior vector
Diffstat (limited to 'src/comp/front')
| -rw-r--r-- | src/comp/front/attr.rs | 14 | ||||
| -rw-r--r-- | src/comp/front/config.rs | 10 |
2 files changed, 10 insertions, 14 deletions
diff --git a/src/comp/front/attr.rs b/src/comp/front/attr.rs index fe014fd27da..376158b426a 100644 --- a/src/comp/front/attr.rs +++ b/src/comp/front/attr.rs @@ -29,13 +29,11 @@ export mk_attr; // From a list of crate attributes get only the meta_items that impact crate // linkage -fn find_linkage_metas(&ast::attribute[] attrs) -> vec[@ast::meta_item] { - let vec[@ast::meta_item] metas = []; +fn find_linkage_metas(&ast::attribute[] attrs) -> (@ast::meta_item)[] { + let (@ast::meta_item)[] metas = ~[]; for (ast::attribute attr in find_attrs_by_name(attrs, "link")) { alt (attr.node.value.node) { - case (ast::meta_list(_, ?items)) { - metas += items; - } + case (ast::meta_list(_, ?items)) { metas += items; } case (_) { log "ignoring link attribute that has incorrect type"; } @@ -133,7 +131,7 @@ fn eq(@ast::meta_item a, @ast::meta_item b) -> bool { } } -fn contains(&vec[@ast::meta_item] haystack, @ast::meta_item needle) -> bool { +fn contains(&(@ast::meta_item)[] haystack, @ast::meta_item needle) -> bool { log #fmt("looking for %s", syntax::print::pprust::meta_item_to_str(*needle)); for (@ast::meta_item item in haystack) { @@ -222,8 +220,8 @@ fn mk_name_value_item(ast::ident name, ast::lit value) -> @ast::meta_item { ret @span(ast::meta_name_value(name, value)); } -fn mk_list_item(ast::ident name, - &vec[@ast::meta_item] items) -> @ast::meta_item { +fn mk_list_item(ast::ident name, &(@ast::meta_item)[] items) + -> @ast::meta_item { ret @span(ast::meta_list(name, items)); } diff --git a/src/comp/front/config.rs b/src/comp/front/config.rs index b8351282bec..dd6c6b574f3 100644 --- a/src/comp/front/config.rs +++ b/src/comp/front/config.rs @@ -109,9 +109,9 @@ fn in_cfg(&ast::crate_cfg cfg, &ast::attribute[] attrs) -> bool { // so we can match against them. This is the list of configurations for // which the item is valid auto item_cfg_metas = { - fn extract_metas(&vec[@ast::meta_item] inner_items, + fn extract_metas(&(@ast::meta_item)[] inner_items, &@ast::meta_item cfg_item) - -> vec[@ast::meta_item] { + -> (@ast::meta_item)[] { alt (cfg_item.node) { case (ast::meta_list(?name, ?items)) { @@ -122,13 +122,11 @@ fn in_cfg(&ast::crate_cfg cfg, &ast::attribute[] attrs) -> bool { } } auto cfg_metas = attr::attr_metas(item_cfg_attrs); - vec::foldl(extract_metas, [], cfg_metas) + ivec::foldl(extract_metas, ~[], cfg_metas) }; for (@ast::meta_item cfg_mi in item_cfg_metas) { - if (attr::contains(cfg, cfg_mi)) { - ret true; - } + if (attr::contains(cfg, cfg_mi)) { ret true; } } ret false; |
