mirror of
https://github.com/rust-lang/rustlings.git
synced 2024-12-24 00:00:02 +03:00
chore: Refactored to adhere to new rustlings version
This commit is contained in:
parent
1c27aeead9
commit
e59c65cf45
|
@ -26,6 +26,8 @@ bin = [
|
|||
{ name = "functions4_sol", path = "../solutions/02_functions/functions4.rs" },
|
||||
{ name = "functions5", path = "../exercises/02_functions/functions5.rs" },
|
||||
{ name = "functions5_sol", path = "../solutions/02_functions/functions5.rs" },
|
||||
{ name = "functions6", path = "../exercises/02_functions/functions6.rs" },
|
||||
{ name = "functions6_sol", path = "../solutions/02_functions/functions6.rs" },
|
||||
{ name = "if1", path = "../exercises/03_if/if1.rs" },
|
||||
{ name = "if1_sol", path = "../solutions/03_if/if1.rs" },
|
||||
{ name = "if2", path = "../exercises/03_if/if2.rs" },
|
||||
|
@ -60,6 +62,8 @@ bin = [
|
|||
{ name = "move_semantics4_sol", path = "../solutions/06_move_semantics/move_semantics4.rs" },
|
||||
{ name = "move_semantics5", path = "../exercises/06_move_semantics/move_semantics5.rs" },
|
||||
{ name = "move_semantics5_sol", path = "../solutions/06_move_semantics/move_semantics5.rs" },
|
||||
{ name = "move_semantics6", path = "../exercises/06_move_semantics/move_semantics6.rs" },
|
||||
{ name = "move_semantics6_sol", path = "../solutions/06_move_semantics/move_semantics6.rs" },
|
||||
{ name = "structs1", path = "../exercises/07_structs/structs1.rs" },
|
||||
{ name = "structs1_sol", path = "../solutions/07_structs/structs1.rs" },
|
||||
{ name = "structs2", path = "../exercises/07_structs/structs2.rs" },
|
||||
|
|
|
@ -8,13 +8,12 @@
|
|||
// Execute `rustlings hint functions6` or use the `hint` watch subcommand for
|
||||
// some hints.
|
||||
|
||||
// I AM NOT DONE
|
||||
|
||||
fn main() {
|
||||
// TODO: ensure the definition of captured variable
|
||||
let closure_1 = |input_var: u32| -> u32 {input_var + outer_var};
|
||||
println!("Closure#1 returns {}", closure_1(5));
|
||||
|
||||
let closure_2 = |input_var| println!("Closure#2 (input_var {})", input_var);
|
||||
closure_2(2);
|
||||
closure_2("5");
|
||||
closure_2("5"); // TODO: look at the captured variable type here
|
||||
}
|
||||
|
|
|
@ -9,18 +9,16 @@
|
|||
// Execute `rustlings hint move_semantics7` or use the `hint` watch subcommand
|
||||
// for a hint.
|
||||
|
||||
// I AM NOT DONE
|
||||
|
||||
fn main() {
|
||||
let mut counter = 0;
|
||||
|
||||
let mut increment = || {
|
||||
counter += 1;
|
||||
println!("counter: {}", counter);
|
||||
println!("counter equals {}", counter);
|
||||
};
|
||||
|
||||
increment();
|
||||
let _reborrowed_counter = &counter;
|
||||
let _reborrowed_counter = &counter; // TODO: figure out where to put this borrowing instruction
|
||||
increment();
|
||||
|
||||
assert_eq!(counter, 2);
|
||||
|
|
|
@ -189,8 +189,8 @@ There are two solutions:
|
|||
|
||||
[[exercises]]
|
||||
name = "functions6"
|
||||
path = "exercises/02_functions/functions6.rs"
|
||||
mode = "compile"
|
||||
dir = "02_functions"
|
||||
test = false
|
||||
hint = """
|
||||
Hint FIX #1: Closures can capture variables defined in the outer context.
|
||||
|
||||
|
@ -199,8 +199,7 @@ specified in the signature. But the closure cannot be reused with different
|
|||
input types.
|
||||
|
||||
Read more about closures in the rust book dedicated section:
|
||||
https://doc.rust-lang.org/book/ch13-01-closures.html
|
||||
"""
|
||||
https://doc.rust-lang.org/book/ch13-01-closures.html"""
|
||||
|
||||
# IF
|
||||
|
||||
|
@ -408,17 +407,15 @@ to be adjusted."""
|
|||
|
||||
[[exercises]]
|
||||
name = "move_semantics6"
|
||||
path = "exercises/06_move_semantics/move_semantics6.rs"
|
||||
mode = "compile"
|
||||
dir = "06_move_semantics"
|
||||
test = false
|
||||
hint = """
|
||||
When a closure capture a variable to modify it, it borrows that variable as a
|
||||
mutable reference. In this exercise, as the closure mutably borrows `counter`
|
||||
and is called later, any attempt to reborrow `counter` in between will lead to
|
||||
an error.
|
||||
When a closure captures a variable to modify it, it actually borrows that variable
|
||||
as a mutable reference. In this exercise, the closure mutably borrows the `counter`
|
||||
variable, thus, any attempt to borrow `counter` between closure calls leads to an error.
|
||||
|
||||
You cannot immutably borrow a variable if a mutable closure is
|
||||
called later in the scope.
|
||||
"""
|
||||
called later in the scope."""
|
||||
|
||||
# STRUCTS
|
||||
|
||||
|
|
9
solutions/02_functions/functions6.rs
Normal file
9
solutions/02_functions/functions6.rs
Normal file
|
@ -0,0 +1,9 @@
|
|||
fn main() {
|
||||
let outer_var = 1;
|
||||
let closure_1 = |input_var: u32| -> u32 { input_var + outer_var };
|
||||
println!("Closure#1 returns {}", closure_1(5));
|
||||
|
||||
let closure_2 = |input_var| println!("Closure#2 (input_var {})", input_var);
|
||||
closure_2(2);
|
||||
closure_2(5);
|
||||
}
|
14
solutions/06_move_semantics/move_semantics6.rs
Normal file
14
solutions/06_move_semantics/move_semantics6.rs
Normal file
|
@ -0,0 +1,14 @@
|
|||
fn main() {
|
||||
let mut counter = 0;
|
||||
|
||||
let mut increment = || {
|
||||
counter += 1;
|
||||
println!("counter equals {}", counter);
|
||||
};
|
||||
|
||||
increment();
|
||||
increment();
|
||||
let _reborrowed_counter = &counter;
|
||||
|
||||
assert_eq!(counter, 2);
|
||||
}
|
Loading…
Reference in a new issue