Skip to content

Commit 8dbe632

Browse files
committed
auto merge of #19427 : scialex/rust/doc-attr-macros, r=sfackler
this allows one to, for example, use #[doc = $macro_var ] in macros.
2 parents 8a210af + d3bbfb4 commit 8dbe632

File tree

3 files changed

+48
-0
lines changed

3 files changed

+48
-0
lines changed

src/libsyntax/parse/parser.rs

+6
Original file line numberDiff line numberDiff line change
@@ -1648,6 +1648,12 @@ impl<'a> Parser<'a> {
16481648
/// Matches token_lit = LIT_INTEGER | ...
16491649
pub fn lit_from_token(&mut self, tok: &token::Token) -> Lit_ {
16501650
match *tok {
1651+
token::Interpolated(token::NtExpr(ref v)) => {
1652+
match v.node {
1653+
ExprLit(ref lit) => { lit.node.clone() }
1654+
_ => { self.unexpected_last(tok); }
1655+
}
1656+
}
16511657
token::Literal(lit, suf) => {
16521658
let (suffix_illegal, out) = match lit {
16531659
token::Byte(i) => (true, LitByte(parse::byte_lit(i.as_str()).val0())),
+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
#[doc = $not_there] //~ error: unexpected token: `$`
12+
fn main() { }
13+
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
// Copyright 2013-2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// ignore-pretty - token trees can't pretty print
12+
13+
#![feature(macro_rules)]
14+
15+
macro_rules! descriptions {
16+
($name:ident is $desc:expr) => {
17+
// Check that we will correctly expand attributes
18+
#[doc = $desc]
19+
#[allow(dead_code)]
20+
const $name : &'static str = $desc;
21+
}
22+
}
23+
24+
// item
25+
descriptions!(DOG is "an animal")
26+
descriptions!(RUST is "a language")
27+
28+
pub fn main() {
29+
}

0 commit comments

Comments
 (0)