summaryrefslogtreecommitdiffstats
path: root/tests/ui/proc-macro/auxiliary/env.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-19 09:26:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-19 09:26:03 +0000
commit9918693037dce8aa4bb6f08741b6812923486c18 (patch)
tree21d2b40bec7e6a7ea664acee056eb3d08e15a1cf /tests/ui/proc-macro/auxiliary/env.rs
parentReleasing progress-linux version 1.75.0+dfsg1-5~progress7.99u1. (diff)
downloadrustc-9918693037dce8aa4bb6f08741b6812923486c18.tar.xz
rustc-9918693037dce8aa4bb6f08741b6812923486c18.zip
Merging upstream version 1.76.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/proc-macro/auxiliary/env.rs')
-rw-r--r--tests/ui/proc-macro/auxiliary/env.rs28
1 files changed, 28 insertions, 0 deletions
diff --git a/tests/ui/proc-macro/auxiliary/env.rs b/tests/ui/proc-macro/auxiliary/env.rs
new file mode 100644
index 000000000..58bcb08bf
--- /dev/null
+++ b/tests/ui/proc-macro/auxiliary/env.rs
@@ -0,0 +1,28 @@
+// force-host
+// no-prefer-dynamic
+
+#![crate_type = "proc-macro"]
+#![feature(proc_macro_tracked_env)]
+
+extern crate proc_macro;
+
+use proc_macro::TokenStream;
+use proc_macro::tracked_env::var;
+
+#[proc_macro]
+pub fn generate_const(input: TokenStream) -> TokenStream {
+ let the_const = match var("THE_CONST") {
+ Ok(x) if x == "12" => {
+ "const THE_CONST: u32 = 12;"
+ }
+ _ => {
+ "const THE_CONST: u32 = 0;"
+ }
+ };
+ let another = if var("ANOTHER").is_ok() {
+ "const ANOTHER: u32 = 1;"
+ } else {
+ "const ANOTHER: u32 = 2;"
+ };
+ format!("{the_const}{another}").parse().unwrap()
+}