Skip to content

Commit dd81d1e

Browse files
committed
Auto merge of #26005 - Ms2ger:get_enum_variant_defs, r=Aatch
2 parents 52e530a + f2cca31 commit dd81d1e

File tree

2 files changed

+2
-50
lines changed

2 files changed

+2
-50
lines changed

src/librustc/metadata/csearch.rs

-7
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,6 @@
1313
use metadata::common::*;
1414
use metadata::cstore;
1515
use metadata::decoder;
16-
use middle::def;
1716
use middle::lang_items;
1817
use middle::ty;
1918

@@ -114,12 +113,6 @@ pub fn maybe_get_item_ast<'tcx>(tcx: &ty::ctxt<'tcx>, def: ast::DefId,
114113
decoder::maybe_get_item_ast(&*cdata, tcx, def.node, decode_inlined_item)
115114
}
116115

117-
pub fn get_enum_variant_defs(cstore: &cstore::CStore, enum_id: ast::DefId)
118-
-> Vec<(def::Def, ast::Name, ast::Visibility)> {
119-
let cdata = cstore.get_crate_data(enum_id.krate);
120-
decoder::get_enum_variant_defs(&*cstore.intr, &*cdata, enum_id.node)
121-
}
122-
123116
pub fn get_enum_variants<'tcx>(tcx: &ty::ctxt<'tcx>, def: ast::DefId)
124117
-> Vec<Rc<ty::VariantInfo<'tcx>>> {
125118
let cstore = &tcx.sess.cstore;

src/librustc/metadata/decoder.rs

+2-43
Original file line numberDiff line numberDiff line change
@@ -268,30 +268,6 @@ fn item_trait_ref<'tcx>(doc: rbml::Doc, tcx: &ty::ctxt<'tcx>, cdata: Cmd)
268268
doc_trait_ref(tp, tcx, cdata)
269269
}
270270

271-
struct EnumVariantIds<'a> {
272-
iter: reader::TaggedDocsIterator<'a>,
273-
cdata: Cmd<'a>,
274-
}
275-
276-
impl<'a> Iterator for EnumVariantIds<'a> {
277-
type Item = ast::DefId;
278-
279-
fn next(&mut self) -> Option<ast::DefId> {
280-
self.iter.next().map(|p| translated_def_id(self.cdata, p))
281-
}
282-
283-
fn size_hint(&self) -> (usize, Option<usize>) {
284-
self.iter.size_hint()
285-
}
286-
}
287-
288-
fn enum_variant_ids<'a>(item: rbml::Doc<'a>, cdata: Cmd<'a>) -> EnumVariantIds<'a> {
289-
EnumVariantIds {
290-
iter: reader::tagged_docs(item, tag_items_data_item_variant),
291-
cdata: cdata,
292-
}
293-
}
294-
295271
fn item_path(item_doc: rbml::Doc) -> Vec<ast_map::PathElem> {
296272
let path_doc = reader::get_doc(item_doc, tag_path);
297273
reader::docs(path_doc).filter_map(|(tag, elt_doc)| {
@@ -730,31 +706,14 @@ pub fn maybe_get_item_ast<'tcx>(cdata: Cmd, tcx: &ty::ctxt<'tcx>, id: ast::NodeI
730706
}
731707
}
732708

733-
pub fn get_enum_variant_defs(intr: &IdentInterner,
734-
cdata: Cmd,
735-
id: ast::NodeId)
736-
-> Vec<(def::Def, ast::Name, ast::Visibility)> {
737-
let data = cdata.data();
738-
let items = reader::get_doc(rbml::Doc::new(data), tag_items);
739-
let item = find_item(id, items);
740-
enum_variant_ids(item, cdata).map(|did| {
741-
let item = find_item(did.node, items);
742-
let name = item_name(intr, item);
743-
let visibility = item_visibility(item);
744-
match item_to_def_like(cdata, item, did) {
745-
DlDef(def @ def::DefVariant(..)) => (def, name, visibility),
746-
_ => unreachable!()
747-
}
748-
}).collect()
749-
}
750-
751709
pub fn get_enum_variants<'tcx>(intr: Rc<IdentInterner>, cdata: Cmd, id: ast::NodeId,
752710
tcx: &ty::ctxt<'tcx>) -> Vec<Rc<ty::VariantInfo<'tcx>>> {
753711
let data = cdata.data();
754712
let items = reader::get_doc(rbml::Doc::new(data), tag_items);
755713
let item = find_item(id, items);
756714
let mut disr_val = 0;
757-
enum_variant_ids(item, cdata).map(|did| {
715+
reader::tagged_docs(item, tag_items_data_item_variant).map(|p| {
716+
let did = translated_def_id(cdata, p);
758717
let item = find_item(did.node, items);
759718
let ctor_ty = item_type(ast::DefId { krate: cdata.cnum, node: id},
760719
item, tcx, cdata);

0 commit comments

Comments
 (0)