Inline this thing

If a function returns one of several enum variants, but we’re only interested in one, then just return its contents and have it apply the Mode “wrapper” later.
This commit is contained in:
Benjamin Sago 2017-06-26 08:38:56 +01:00
parent 65d94636d7
commit 4be0a36d4e

View File

@ -53,13 +53,11 @@ impl Mode {
Err(Useless("oneline", true, "long")) Err(Useless("oneline", true, "long"))
} }
else { else {
let details = details::Options { Ok(details::Options {
columns: Some(Columns::deduce(matches)?), columns: Some(Columns::deduce(matches)?),
header: matches.opt_present("header"), header: matches.opt_present("header"),
xattr: xattr::ENABLED && matches.opt_present("extended"), xattr: xattr::ENABLED && matches.opt_present("extended"),
}; })
Ok(Mode::Details(details))
} }
}; };
@ -133,21 +131,15 @@ impl Mode {
}; };
if matches.opt_present("long") { if matches.opt_present("long") {
let view = long()?; let details = long()?;
if matches.opt_present("grid") { if matches.opt_present("grid") {
if let Mode::Details(details) = view { match other_options_scan()? {
let others = other_options_scan()?; Mode::Grid(grid) => return Ok(Mode::GridDetails(grid, details)),
match others { others => return Ok(others),
Mode::Grid(grid) => return Ok(Mode::GridDetails(grid, details)), };
_ => return Ok(others),
};
}
else {
unreachable!()
}
} }
else { else {
return Ok(view); return Ok(Mode::Details(details));
} }
} }