diff options
| author | Santiago Pastorino <spastorino@gmail.com> | 2025-03-28 15:20:18 -0300 |
|---|---|---|
| committer | Santiago Pastorino <spastorino@gmail.com> | 2025-04-07 16:53:11 -0300 |
| commit | a0856eaff6dcf69456dd186bb310a88af210865a (patch) | |
| tree | a4614db029d30b9cc9d2264a049230933b2ed464 /tests/mir-opt/ergonomic-clones | |
| parent | 9f69c66a47d80cbced17d4d74d6e5c349db952d2 (diff) | |
| download | rust-a0856eaff6dcf69456dd186bb310a88af210865a.tar.gz rust-a0856eaff6dcf69456dd186bb310a88af210865a.zip | |
Add mir opt tests to be sure we generate copy, clones and moves when corresponds
Diffstat (limited to 'tests/mir-opt/ergonomic-clones')
| -rw-r--r-- | tests/mir-opt/ergonomic-clones/closure.rs | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/mir-opt/ergonomic-clones/closure.rs b/tests/mir-opt/ergonomic-clones/closure.rs new file mode 100644 index 00000000000..682f4844984 --- /dev/null +++ b/tests/mir-opt/ergonomic-clones/closure.rs @@ -0,0 +1,55 @@ +#![crate_type = "lib"] +#![feature(ergonomic_clones)] +#![allow(incomplete_features)] + +use std::clone::UseCloned; + +pub fn ergonomic_clone_closure_move() -> String { + // CHECK-LABEL: fn ergonomic_clone_closure_move( + // CHECK: _0 = move (_1.0: std::string::String); + // CHECK-NOT: <String as Clone>::clone + let s = String::from("hi"); + + let cl = use || s; + cl() +} + +#[derive(Clone)] +struct Foo; + +impl UseCloned for Foo {} + +pub fn ergonomic_clone_closure_use_cloned() -> Foo { + // CHECK-LABEL: fn ergonomic_clone_closure_use_cloned( + // CHECK: <Foo as Clone>::clone + let f = Foo; + + let f1 = use || f; + + let f2 = use || f; + + f +} + +pub fn ergonomic_clone_closure_copy() -> i32 { + // CHECK-LABEL: fn ergonomic_clone_closure_copy( + // CHECK: _0 = copy ((*_1).0: i32); + // CHECK-NOT: <i32 as Clone>::clone + let i = 1; + + let i1 = use || i; + + let i2 = use || i; + + i +} + +pub fn ergonomic_clone_closure_use_cloned_generics<T: UseCloned>(f: T) -> T { + // CHECK-LABEL: fn ergonomic_clone_closure_use_cloned_generics( + // CHECK: <T as Clone>::clone + let f1 = use || f; + + let f2 = use || f; + + f +} |
