about summary refs log tree commit diff
diff options
context:
space:
mode:
authorYuki Okushi <huyuumi.dev@gmail.com>2020-06-27 20:34:27 +0900
committerYuki Okushi <huyuumi.dev@gmail.com>2020-06-28 04:49:51 +0900
commit1d16aed7f0993a07dcd7302487fa5781468b5f69 (patch)
treec88fe5d97631d2d0ad68e5f223bb6c44975321a3
parent7125ce7ab7047ed00f488e16e569b037789d7d84 (diff)
downloadrust-1d16aed7f0993a07dcd7302487fa5781468b5f69.tar.gz
rust-1d16aed7f0993a07dcd7302487fa5781468b5f69.zip
Add test for issue-72352
-rw-r--r--src/test/ui/const-generics/issues/issue-72352.rs21
-rw-r--r--src/test/ui/const-generics/issues/issue-72352.stderr8
2 files changed, 29 insertions, 0 deletions
diff --git a/src/test/ui/const-generics/issues/issue-72352.rs b/src/test/ui/const-generics/issues/issue-72352.rs
new file mode 100644
index 00000000000..e977af8deb7
--- /dev/null
+++ b/src/test/ui/const-generics/issues/issue-72352.rs
@@ -0,0 +1,21 @@
+#![feature(const_generics)]
+#![allow(incomplete_features)]
+
+use std::ffi::{CStr, CString};
+
+unsafe fn unsafely_do_the_thing<const F: fn(&CStr) -> usize>(ptr: *const i8) -> usize {
+    //~^ ERROR: using function pointers as const generic parameters is forbidden
+    F(CStr::from_ptr(ptr))
+}
+
+fn safely_do_the_thing(s: &CStr) -> usize {
+    s.to_bytes().len()
+}
+
+fn main() {
+    let baguette = CString::new("baguette").unwrap();
+    let ptr = baguette.as_ptr();
+    println!("{}", unsafe {
+        unsafely_do_the_thing::<safely_do_the_thing>(ptr)
+    });
+}
diff --git a/src/test/ui/const-generics/issues/issue-72352.stderr b/src/test/ui/const-generics/issues/issue-72352.stderr
new file mode 100644
index 00000000000..bc48da10393
--- /dev/null
+++ b/src/test/ui/const-generics/issues/issue-72352.stderr
@@ -0,0 +1,8 @@
+error: using function pointers as const generic parameters is forbidden
+  --> $DIR/issue-72352.rs:6:42
+   |
+LL | unsafe fn unsafely_do_the_thing<const F: fn(&CStr) -> usize>(ptr: *const i8) -> usize {
+   |                                          ^^^^^^^^^^^^^^^^^^
+
+error: aborting due to previous error
+