diff options
| author | Jubilee <workingjubilee@gmail.com> | 2025-07-04 23:26:23 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-07-04 23:26:23 -0700 |
| commit | 5f415da0b52fa8de667ce53ec5daf76fca6a0591 (patch) | |
| tree | 5c2c965d8d781e131a6f46dcb4e0c8e0748b4316 /tests/ui/drop | |
| parent | 069f571fad6c4f99aa1cdc9367bc51a758a9f5e6 (diff) | |
| parent | 066a281f60fd5071a50cf15a28ed40f15bef7563 (diff) | |
| download | rust-5f415da0b52fa8de667ce53ec5daf76fca6a0591.tar.gz rust-5f415da0b52fa8de667ce53ec5daf76fca6a0591.zip | |
Rollup merge of #143300 - Kivooeo:tf25, r=tgross35
`tests/ui`: A New Order [25/N] > [!NOTE] > > Intermediate commits are intended to help review, but will be squashed prior to merge. Some `tests/ui/` housekeeping, to trim down number of tests directly under `tests/ui/`. Part of rust-lang/rust#133895. r? `@tgross35`
Diffstat (limited to 'tests/ui/drop')
| -rw-r--r-- | tests/ui/drop/drop-once-on-move.rs | 35 | ||||
| -rw-r--r-- | tests/ui/drop/drop-scope-exit.rs | 37 |
2 files changed, 72 insertions, 0 deletions
diff --git a/tests/ui/drop/drop-once-on-move.rs b/tests/ui/drop/drop-once-on-move.rs new file mode 100644 index 00000000000..da018058076 --- /dev/null +++ b/tests/ui/drop/drop-once-on-move.rs @@ -0,0 +1,35 @@ +//! Check that types not implementing `Copy` are moved, not copied, during assignment +//! operations, and their `Drop` implementation is called exactly once when the +//! value goes out of scope. + +//@ run-pass + +#![allow(non_camel_case_types)] +use std::cell::Cell; + +#[derive(Debug)] +struct r<'a> { + i: &'a Cell<isize>, +} + +impl<'a> Drop for r<'a> { + fn drop(&mut self) { + self.i.set(self.i.get() + 1); + } +} + +fn r(i: &Cell<isize>) -> r<'_> { + r { i } +} + +pub fn main() { + let i = &Cell::new(0); + // Even though these look like copies, they are guaranteed not to be + { + let a = r(i); + let b = (a, 10); + let (c, _d) = b; + println!("{:?}", c); + } + assert_eq!(i.get(), 1); +} diff --git a/tests/ui/drop/drop-scope-exit.rs b/tests/ui/drop/drop-scope-exit.rs new file mode 100644 index 00000000000..4d003fec712 --- /dev/null +++ b/tests/ui/drop/drop-scope-exit.rs @@ -0,0 +1,37 @@ +//! Check that the `Drop` implementation is called when a value goes out of scope. + +//@ run-pass + +#![allow(non_camel_case_types)] +use std::cell::Cell; + +struct shrinky_pointer<'a> { + i: &'a Cell<isize>, +} + +impl<'a> Drop for shrinky_pointer<'a> { + fn drop(&mut self) { + println!("Hello!"); + self.i.set(self.i.get() - 1); + } +} + +impl<'a> shrinky_pointer<'a> { + pub fn look_at(&self) -> isize { + return self.i.get(); + } +} + +fn shrinky_pointer(i: &Cell<isize>) -> shrinky_pointer<'_> { + shrinky_pointer { i } +} + +pub fn main() { + let my_total = &Cell::new(10); + { + let pt = shrinky_pointer(my_total); + assert_eq!(pt.look_at(), 10); + } + println!("my_total = {}", my_total.get()); + assert_eq!(my_total.get(), 9); +} |
