From d54a6d941312b2bd4e0c3f8209a8fd23175d180f Mon Sep 17 00:00:00 2001 From: Jeffrey Seyfried Date: Thu, 17 Aug 2017 11:44:28 -0700 Subject: Ensure that generic arguments don't end up in attribute paths. --- src/libsyntax/parse/parser.rs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'src/libsyntax/parse/parser.rs') diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 2b2f925306d..90a635fdf44 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -1776,7 +1776,13 @@ impl<'a> Parser<'a> { pub fn parse_path_common(&mut self, style: PathStyle, enable_warning: bool) -> PResult<'a, ast::Path> { - maybe_whole!(self, NtPath, |x| x); + maybe_whole!(self, NtPath, |path| { + if style == PathStyle::Mod && + path.segments.iter().any(|segment| segment.parameters.is_some()) { + self.diagnostic().span_err(path.span, "unexpected generic arguments in path"); + } + path + }); let lo = self.meta_var_span.unwrap_or(self.span); let mut segments = Vec::new(); -- cgit 1.4.1-3-g733a5