Introdução
Neste laboratório, temos um exemplo de análise de argumentos usando correspondência de padrões em Rust. O programa recebe argumentos da linha de comando e executa diferentes operações com base no número e tipo de argumentos passados. Se nenhum argumento for passado, imprime uma mensagem. Se um único argumento for passado e puder ser analisado como o inteiro 42, imprime "This is the answer!". Se um comando e um argumento inteiro forem passados, executa uma operação de aumento ou diminuição no inteiro. Se qualquer outro número de argumentos for passado, exibe uma mensagem de ajuda explicando o uso correto do programa.
Nota: Se o laboratório não especificar um nome de arquivo, você pode usar qualquer nome de arquivo que desejar. Por exemplo, você pode usar
main.rs, compilar e executar comrustc main.rs && ./main.
Análise de Argumentos
A correspondência de padrões pode ser usada para analisar argumentos simples:
use std::env;
fn increase(number: i32) {
println!("{}", number + 1);
}
fn decrease(number: i32) {
println!("{}", number - 1);
}
fn help() {
println!("uso:
match_args <string>
Verifica se a string fornecida é a resposta.
match_args {{increase|decrease}} <inteiro>
Aumenta ou diminui o inteiro fornecido em um.");
}
fn main() {
let args: Vec<String> = env::args().collect();
match args.len() {
// nenhum argumento passado
1 => {
println!("Meu nome é 'match_args'. Tente passar alguns argumentos!");
},
// um argumento passado
2 => {
match args[1].parse() {
Ok(42) => println!("Esta é a resposta!"),
_ => println!("Esta não é a resposta."),
}
},
// um comando e um argumento passados
3 => {
let cmd = &args[1];
let num = &args[2];
// analisar o número
let number: i32 = match num.parse() {
Ok(n) => {
n
},
Err(_) => {
eprintln!("erro: segundo argumento não é um inteiro");
help();
return;
},
};
// analisar o comando
match &cmd[..] {
"increase" => increase(number),
"decrease" => decrease(number),
_ => {
eprintln!("erro: comando inválido");
help();
},
}
},
// todos os outros casos
_ => {
// mostrar uma mensagem de ajuda
help();
}
}
}
$ ./match_args Rust
Esta não é a resposta.
$ ./match_args 42
Esta é a resposta!
$ ./match_args fazer algo
erro: segundo argumento não é um inteiro
uso:
match_args <string>
Verifica se a string fornecida é a resposta.
match_args {increase|decrease} <inteiro>
Aumenta ou diminui o inteiro fornecido em um.
$ ./match_args fazer 42
erro: comando inválido
uso:
match_args <string>
Verifica se a string fornecida é a resposta.
match_args {increase|decrease} <inteiro>
Aumenta ou diminui o inteiro fornecido em um.
$ ./match_args increase 42
43
Resumo
Parabéns! Você concluiu o laboratório de Análise de Argumentos. Você pode praticar mais laboratórios no LabEx para aprimorar suas habilidades.