diff options
| author | Eduard Burtescu <edy.burt@gmail.com> | 2016-09-22 20:03:28 +0300 |
|---|---|---|
| committer | Eduard Burtescu <edy.burt@gmail.com> | 2016-09-22 20:03:28 +0300 |
| commit | 795b6adc9adc171900fdcae2f1a73c27bc2f7dc2 (patch) | |
| tree | 12d6fab60559e5a6a99308dc9276dad497fd4fc4 /src | |
| parent | b2627b080a2cdf29dbabcecac89ecf80fa56ca63 (diff) | |
| download | rust-795b6adc9adc171900fdcae2f1a73c27bc2f7dc2.tar.gz rust-795b6adc9adc171900fdcae2f1a73c27bc2f7dc2.zip | |
Don't let a type parameter named "Self" unchanged past HIR lowering.
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc/hir/lowering.rs | 11 | ||||
| -rw-r--r-- | src/test/compile-fail/issue-36638.rs | 19 |
2 files changed, 29 insertions, 1 deletions
diff --git a/src/librustc/hir/lowering.rs b/src/librustc/hir/lowering.rs index 37b5eac3cce..29dedeeeb03 100644 --- a/src/librustc/hir/lowering.rs +++ b/src/librustc/hir/lowering.rs @@ -391,9 +391,18 @@ impl<'a> LoweringContext<'a> { } fn lower_ty_param(&mut self, tp: &TyParam) -> hir::TyParam { + let mut name = tp.ident.name; + + // Don't expose `Self` (recovered "keyword used as ident" parse error). + // `rustc::ty` expects `Self` to be only used for a trait's `Self`. + // Instead, use gensym("Self") to create a distinct name that looks the same. + if name == token::keywords::SelfType.name() { + name = token::gensym("Self"); + } + hir::TyParam { id: tp.id, - name: tp.ident.name, + name: name, bounds: self.lower_bounds(&tp.bounds), default: tp.default.as_ref().map(|x| self.lower_ty(x)), span: tp.span, diff --git a/src/test/compile-fail/issue-36638.rs b/src/test/compile-fail/issue-36638.rs new file mode 100644 index 00000000000..5e43536ef3f --- /dev/null +++ b/src/test/compile-fail/issue-36638.rs @@ -0,0 +1,19 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// compile-flags: -Z continue-parse-after-error + +struct Foo<Self>(Self); +//~^ ERROR expected identifier, found keyword `Self` + +trait Bar<Self> {} +//~^ ERROR expected identifier, found keyword `Self` + +fn main() {} |
