| Crates.io | getargs-os |
| lib.rs | getargs-os |
| version | 0.1.1 |
| created_at | 2022-12-12 10:00:40.54589+00 |
| updated_at | 2023-06-27 23:01:56.706423+00 |
| description | Provides a way for `getargs` to parse OS strings |
| homepage | https://github.com/LoganDark/getargs-os |
| repository | https://github.com/LoganDark/getargs-os |
| max_upload_size | |
| id | 734908 |
| size | 17,485 |
Adds a newtype wrapper (OsArgument) around OsStr that allows it to be parsed
by getargs::Options.
In combination with the argv crate, this allows for
lowest-cost argument parsing across all platforms (zero-cost on Linux).
This is a separate crate from getargs because it requires (wildly) unsafe
code. std does not want us messing with OsStrs at all!
First, obtain an iterator over OsStrs somehow - I recommend
argv once again - then wrap them in OsArgument and
pass that to Options::new.
use getargs::Options;
use getargs_os::OsArgument;
let mut opts = Options::new(argv::iter().skip(1).map(<&OsArgument>::from));
Then use Optionsgetargs::Options as normal - check its documentation for more
usage examples.
You can use the os! macro to create new OS strings to compare arguments
against. This macro works on all operating systems. For example:
while let Some(arg) = opts.next_arg().expect("some ooga booga just happened") {
if arg == Arg::Long(os!("help")) {
// print help...
} else {
// ...
}
}