cli
let args: Vec<String> = std::env::args().collect();
println!("{}", args.len());
vec e hashmap
let mut tags = vec!["ai", "film"];
tags.push("photo");
result e option
fn load(ok: bool) -> Result<String, String> {
if ok { Ok("ok".into()) } else { Err("fail".into()) }
}
ownership
let name = String::from("samir");
let moved = name;
esercizi
leggi gli argomenti della cli.
let args: Vec<String> = std::env::args().collect();
println!("{}", args.len());
panoramica
In questo capitolo su cli tools lavoriamo su cli, vec e hashmap, result e option, ownership per creare micro-pattern riutilizzabili.
lavora in sequenza: leggi, prova, modifica gli snippet e annota i trade-off principali.
badge: rust essentials
obiettivi
- capire e applicare cli in uno scenario reale
- capire e applicare vec e hashmap in uno scenario reale
- capire e applicare result e option in uno scenario reale
- capire e applicare ownership in uno scenario reale
scheda rapida
let args: Vec<String> = std::env::args().collect();
println!("{}", args.len());
adatta questo scheletro agli esempi della lezione.
tips
- gestisci sempre Result
- preferisci iterators
- usa cargo fmt
- separa moduli per dominio
- riduci mutabilità
- mantieni cli leggibile
tip: documenta ogni scelta architetturale.
mini progetto
crea una cli che stampa gli args.
- leggi args
- valida
- stampa
output atteso: cli pronta.
checklist
- ho eseguito gli snippet e controllato l'output
- ho annotato almeno 2 trade-off
- ho completato il mini progetto
- ho salvato un riepilogo personale