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 OsStr
s at all!
First, obtain an iterator over OsStr
s 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 Options
getargs::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 {
// ...
}
}
To unlock From<&str>
and PartialEq<&str>
impls for &OsArgument
, you must
enable the unstable os_str_bytes
feature, which depends on Nightly. This is
because earlier versions of Rust didn't provide guarantees that OS strings are a
superset of UTF-8 (even though getargs-os
relied on this anyway in the past).
Since the feature now exists, I don't want to make getargs-os
unconditionally
require Nightly, but new features relying on this guarantee will be gated behind
the os_str_bytes
feature until it is stabilized.