]> git.lizzy.rs Git - rust.git/commit
auto merge of #7902 : huonw/rust/attr++, r=cmr,pcwalton
authorbors <bors@rust-lang.org>
Sun, 21 Jul 2013 03:25:31 +0000 (20:25 -0700)
committerbors <bors@rust-lang.org>
Sun, 21 Jul 2013 03:25:31 +0000 (20:25 -0700)
commitd029ebfc5f69f830fe24b4c8a979970d9a7d297d
tree80d9e825ff9f805d15c98441560c6decf85f0739
parent8476419fefda988f66ab6b2a1847e402133a0a29
parentcc760a647ac0094814f592d08813ebae0b3bec47
auto merge of #7902 : huonw/rust/attr++, r=cmr,pcwalton

This does a number of things, but especially dramatically reduce the
number of allocations performed for operations involving attributes/
meta items:

- Converts ast::meta_item & ast::attribute and other associated enums
  to CamelCase.
- Converts several standalone functions in syntax::attr into methods,
  defined on two traits AttrMetaMethods & AttributeMethods. The former
  is common to both MetaItem and Attribute since the latter is a thin
  wrapper around the former.
- Deletes functions that are unnecessary due to iterators.
- Converts other standalone functions to use iterators and the generic
  AttrMetaMethods rather than allocating a lot of new vectors (e.g. the
  old code would have to allocate a new vector to use functions that
  operated on &[meta_item] on &[attribute].)
- Moves the core algorithm of the #[cfg] matching to syntax::attr,
  similar to find_inline_attr and find_linkage_metas.

This doesn't have much of an effect on the speed of #[cfg] stripping,
despite hugely reducing the number of allocations performed; presumably
most of the time is spent in the ast folder rather than doing attribute
checks.

Also fixes the Eq instance of MetaItem_ to correctly ignore spans, so
that `rustc --cfg 'foo(bar)'` now works.
12 files changed:
src/librustc/metadata/csearch.rs
src/librustc/metadata/decoder.rs
src/librustc/metadata/encoder.rs
src/librustc/middle/kind.rs
src/librustc/middle/privacy.rs
src/librustc/middle/resolve.rs
src/librustc/middle/trans/base.rs
src/librustc/middle/ty.rs
src/libsyntax/ext/base.rs
src/libsyntax/parse/obsolete.rs
src/libsyntax/parse/parser.rs
src/libsyntax/print/pprust.rs