diff options
| author | Jeffrey Seyfried <jeffrey.seyfried@gmail.com> | 2016-06-02 07:34:19 +0000 |
|---|---|---|
| committer | Jeffrey Seyfried <jeffrey.seyfried@gmail.com> | 2016-06-02 07:34:19 +0000 |
| commit | daf916bf9a0a785497741e14a68ae57fd578db1b (patch) | |
| tree | dd943bc138858b81349ca9961fad63984472bd23 | |
| parent | c2cab1fd58d6373582da189bd2c20ed3f6a7042a (diff) | |
| download | rust-daf916bf9a0a785497741e14a68ae57fd578db1b.tar.gz rust-daf916bf9a0a785497741e14a68ae57fd578db1b.zip | |
Fix bug in the `syntax::config::StripUnconfigured` folder
| -rw-r--r-- | src/libsyntax/config.rs | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/src/libsyntax/config.rs b/src/libsyntax/config.rs index 14035d8d116..c164e89c52f 100644 --- a/src/libsyntax/config.rs +++ b/src/libsyntax/config.rs @@ -166,14 +166,6 @@ impl<T: CfgFolder> fold::Folder for T { }; let item = match item { - ast::ItemKind::Impl(u, o, a, b, c, items) => { - let items = items.into_iter().filter_map(|item| self.configure(item)).collect(); - ast::ItemKind::Impl(u, o, a, b, c, items) - } - ast::ItemKind::Trait(u, a, b, items) => { - let items = items.into_iter().filter_map(|item| self.configure(item)).collect(); - ast::ItemKind::Trait(u, a, b, items) - } ast::ItemKind::Struct(def, generics) => { ast::ItemKind::Struct(fold_struct(self, def), generics) } @@ -242,7 +234,17 @@ impl<T: CfgFolder> fold::Folder for T { } fn fold_item(&mut self, item: P<ast::Item>) -> SmallVector<P<ast::Item>> { - self.configure(item).map(|item| SmallVector::one(item.map(|i| self.fold_item_simple(i)))) + self.configure(item).map(|item| fold::noop_fold_item(item, self)) + .unwrap_or(SmallVector::zero()) + } + + fn fold_impl_item(&mut self, item: ast::ImplItem) -> SmallVector<ast::ImplItem> { + self.configure(item).map(|item| fold::noop_fold_impl_item(item, self)) + .unwrap_or(SmallVector::zero()) + } + + fn fold_trait_item(&mut self, item: ast::TraitItem) -> SmallVector<ast::TraitItem> { + self.configure(item).map(|item| fold::noop_fold_trait_item(item, self)) .unwrap_or(SmallVector::zero()) } } |
