aboutsummaryrefslogtreecommitdiff
path: root/syn-mid/examples/const_fn_test
diff options
context:
space:
mode:
Diffstat (limited to 'syn-mid/examples/const_fn_test')
-rw-r--r--syn-mid/examples/const_fn_test/Cargo.toml9
-rw-r--r--syn-mid/examples/const_fn_test/build.rs16
-rw-r--r--syn-mid/examples/const_fn_test/tests/test.rs25
3 files changed, 50 insertions, 0 deletions
diff --git a/syn-mid/examples/const_fn_test/Cargo.toml b/syn-mid/examples/const_fn_test/Cargo.toml
new file mode 100644
index 0000000..b3e2807
--- /dev/null
+++ b/syn-mid/examples/const_fn_test/Cargo.toml
@@ -0,0 +1,9 @@
+[package]
+name = "const_fn_test"
+version = "0.0.0"
+authors = ["Taiki Endo <te316e89@gmail.com>"]
+edition = "2018"
+publish = false
+
+[dependencies]
+const_fn = { path = "../const_fn" }
diff --git a/syn-mid/examples/const_fn_test/build.rs b/syn-mid/examples/const_fn_test/build.rs
new file mode 100644
index 0000000..bebf234
--- /dev/null
+++ b/syn-mid/examples/const_fn_test/build.rs
@@ -0,0 +1,16 @@
+use std::{env, process::Command};
+
+fn main() {
+ println!("cargo:rerun-if-changed=build.rs");
+
+ if is_nightly() {
+ println!("cargo:rustc-cfg=nightly");
+ }
+}
+
+fn is_nightly() -> bool {
+ env::var_os("RUSTC")
+ .and_then(|rustc| Command::new(rustc).arg("--version").output().ok())
+ .and_then(|output| String::from_utf8(output.stdout).ok())
+ .map_or(false, |version| version.contains("nightly"))
+}
diff --git a/syn-mid/examples/const_fn_test/tests/test.rs b/syn-mid/examples/const_fn_test/tests/test.rs
new file mode 100644
index 0000000..1b2c742
--- /dev/null
+++ b/syn-mid/examples/const_fn_test/tests/test.rs
@@ -0,0 +1,25 @@
+#![cfg_attr(nightly, feature(const_fn, const_vec_new))]
+#![warn(rust_2018_idioms)]
+#![allow(dead_code)]
+
+use const_fn::const_fn;
+
+#[const_fn(nightly)]
+fn const_vec_new<T>() -> Vec<T> {
+ let vec = Vec::new();
+ vec
+}
+
+#[test]
+fn test_stable() {
+ assert_eq!(const_vec_new::<u8>(), Vec::new());
+}
+
+#[cfg(nightly)]
+const CONST_UNSTABLE: Vec<u8> = const_vec_new();
+
+#[cfg(nightly)]
+#[test]
+fn test_unstable() {
+ assert_eq!(CONST_UNSTABLE, Vec::new());
+}