lezione 10

cli tools

args, parsing e output.

livello: intermedio durata: 28 min output: cli pronto badge: rust essentials

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
start a brief