From 795b6adc9adc171900fdcae2f1a73c27bc2f7dc2 Mon Sep 17 00:00:00 2001 From: Eduard Burtescu Date: Thu, 22 Sep 2016 20:03:28 +0300 Subject: [PATCH] Don't let a type parameter named "Self" unchanged past HIR lowering. --- src/librustc/hir/lowering.rs | 11 ++++++++++- src/test/compile-fail/issue-36638.rs | 19 +++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) create mode 100644 src/test/compile-fail/issue-36638.rs 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 or the MIT license +// , 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); +//~^ ERROR expected identifier, found keyword `Self` + +trait Bar {} +//~^ ERROR expected identifier, found keyword `Self` + +fn main() {}