]> git.lizzy.rs Git - rust.git/commitdiff
add some compile-fail tests
authorRalf Jung <post@ralfj.de>
Sun, 16 Sep 2018 14:47:37 +0000 (16:47 +0200)
committerRalf Jung <post@ralfj.de>
Sun, 16 Sep 2018 15:29:53 +0000 (17:29 +0200)
tests/compile-fail/copy_null.rs [new file with mode: 0644]
tests/compile-fail/copy_unaligned.rs [new file with mode: 0644]

diff --git a/tests/compile-fail/copy_null.rs b/tests/compile-fail/copy_null.rs
new file mode 100644 (file)
index 0000000..e46e327
--- /dev/null
@@ -0,0 +1,18 @@
+// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+//error-pattern: invalid use of NULL pointer
+
+fn main() {
+    let mut data = [0u16; 4];
+    let ptr = &mut data[0] as *mut u16;
+    // Even copying 0 elements from NULL should error
+    unsafe { ptr.copy_from(std::ptr::null(), 0); }
+}
diff --git a/tests/compile-fail/copy_unaligned.rs b/tests/compile-fail/copy_unaligned.rs
new file mode 100644 (file)
index 0000000..0f04dc6
--- /dev/null
@@ -0,0 +1,18 @@
+// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+//error-pattern: tried to access memory with alignment 1, but alignment 2 is required
+
+fn main() {
+    let mut data = [0u16; 8];
+    let ptr = (&mut data[0] as *mut u16 as *mut u8).wrapping_add(1) as *mut u16;
+    // Even copying 0 elements to something unaligned should error
+    unsafe { ptr.copy_from(&data[5], 0); }
+}