2018-02-22 13:09:53 +07:00
|
|
|
// move_semantics4.rs
|
2015-09-23 08:20:04 +06:00
|
|
|
// Refactor this code so that instead of having `vec0` and creating the vector
|
|
|
|
// in `fn main`, we instead create it within `fn fill_vec` and transfer the
|
2019-11-11 22:51:38 +07:00
|
|
|
// freshly created vector from fill_vec to its caller.
|
|
|
|
// Execute `rustlings hint move_semantics4` for hints!
|
2015-09-23 08:20:04 +06:00
|
|
|
|
2019-11-11 19:38:24 +07:00
|
|
|
// I AM NOT DONE
|
|
|
|
|
2018-11-10 02:31:14 +07:00
|
|
|
fn main() {
|
2015-09-23 08:20:04 +06:00
|
|
|
let vec0 = Vec::new();
|
|
|
|
|
|
|
|
let mut vec1 = fill_vec(vec0);
|
|
|
|
|
|
|
|
println!("{} has length {} content `{:?}`", "vec1", vec1.len(), vec1);
|
|
|
|
|
|
|
|
vec1.push(88);
|
|
|
|
|
|
|
|
println!("{} has length {} content `{:?}`", "vec1", vec1.len(), vec1);
|
|
|
|
}
|
|
|
|
|
2019-04-22 05:09:30 +07:00
|
|
|
// `fill_vec()` no longer take `vec: Vec<i32>` as argument
|
|
|
|
fn fill_vec() -> Vec<i32> {
|
2015-09-23 08:20:04 +06:00
|
|
|
let mut vec = vec;
|
|
|
|
|
|
|
|
vec.push(22);
|
|
|
|
vec.push(44);
|
|
|
|
vec.push(66);
|
|
|
|
|
|
|
|
vec
|
|
|
|
}
|