1 //! Syntax extensions in the Rust compiler.
3 #![doc(html_root_url = "https://doc.rust-lang.org/nightly/")]
5 #![deny(rust_2018_idioms)]
7 #![deny(unused_lifetimes)]
9 #![feature(in_band_lifetimes)]
10 #![feature(proc_macro_diagnostic)]
11 #![feature(proc_macro_internals)]
12 #![feature(proc_macro_span)]
13 #![feature(decl_macro)]
15 #![feature(rustc_diagnostic_macros)]
17 #![recursion_limit="256"]
19 extern crate proc_macro;
34 mod proc_macro_server;
40 pub mod proc_macro_decls;
41 pub mod proc_macro_impl;
43 use rustc_data_structures::sync::Lrc;
46 use syntax::ext::base::{MacroExpanderFn, NamedSyntaxExtension, SyntaxExtension};
47 use syntax::ext::hygiene::Transparency;
48 use syntax::edition::Edition;
49 use syntax::symbol::{sym, Symbol};
51 pub fn register_builtins(resolver: &mut dyn syntax::ext::base::Resolver,
52 user_exts: Vec<NamedSyntaxExtension>,
54 deriving::register_builtin_derives(resolver);
56 let mut register = |name, ext| {
57 resolver.add_builtin(ast::Ident::with_empty_ctxt(name), Lrc::new(ext));
59 macro_rules! register {
60 ($( $name:ident: $f:expr, )*) => { $(
61 register(Symbol::intern(stringify!($name)),
62 SyntaxExtension::LegacyBang {
63 expander: Box::new($f as MacroExpanderFn),
65 transparency: Transparency::SemiTransparent,
66 allow_internal_unstable: None,
67 allow_internal_unsafe: false,
68 local_inner_macros: false,
69 unstable_feature: None,
75 use syntax::ext::source_util::*;
78 __rust_unstable_column: expand_column_gated,
79 column: expand_column,
81 stringify: expand_stringify,
82 include: expand_include,
83 include_str: expand_include_str,
84 include_bytes: expand_include_bytes,
85 module_path: expand_mod,
88 global_asm: global_asm::expand_global_asm,
90 concat: concat::expand_syntax_ext,
91 concat_idents: concat_idents::expand_syntax_ext,
93 option_env: env::expand_option_env,
94 log_syntax: log_syntax::expand_syntax_ext,
95 trace_macros: trace_macros::expand_trace_macros,
96 compile_error: compile_error::expand_compile_error,
97 assert: assert::expand_assert,
100 register(sym::test_case, SyntaxExtension::LegacyAttr(Box::new(test_case::expand)));
101 register(sym::test, SyntaxExtension::LegacyAttr(Box::new(test::expand_test)));
102 register(sym::bench, SyntaxExtension::LegacyAttr(Box::new(test::expand_bench)));
104 // format_args uses `unstable` things internally.
105 register(Symbol::intern("format_args"),
106 SyntaxExtension::LegacyBang {
107 expander: Box::new(format::expand_format_args),
109 transparency: Transparency::SemiTransparent,
110 allow_internal_unstable: Some(vec![sym::fmt_internals].into()),
111 allow_internal_unsafe: false,
112 local_inner_macros: false,
113 unstable_feature: None,
116 register(sym::format_args_nl,
117 SyntaxExtension::LegacyBang {
118 expander: Box::new(format::expand_format_args_nl),
120 transparency: Transparency::SemiTransparent,
121 allow_internal_unstable: Some(vec![sym::fmt_internals].into()),
122 allow_internal_unsafe: false,
123 local_inner_macros: false,
124 unstable_feature: None,
128 for (name, ext) in user_exts {