diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-12-21 00:04:30 -0800 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-12-21 09:27:38 -0800 |
| commit | b084cda4e9e0540b67d5db728b58acf8afba9f6e (patch) | |
| tree | 21c9dfe509c650c43d39e8fe6090eb86df827305 /src/libstd | |
| parent | 08ac8d7972af9977d4b0ac892f06f0d6837a6cc4 (diff) | |
| parent | a666105b4c273d128a0a15c3342412c69c89fb98 (diff) | |
| download | rust-b084cda4e9e0540b67d5db728b58acf8afba9f6e.tar.gz rust-b084cda4e9e0540b67d5db728b58acf8afba9f6e.zip | |
rollup merge of #20100: alexcrichton/issue-20091
Instead, just pass everything through as a Vec<u8> to get worried about later. Closes #20091
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/rt/args.rs | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/src/libstd/rt/args.rs b/src/libstd/rt/args.rs index 3a4705f58b4..b1f268597c7 100644 --- a/src/libstd/rt/args.rs +++ b/src/libstd/rt/args.rs @@ -44,12 +44,10 @@ pub fn clone() -> Option<Vec<Vec<u8>>> { imp::clone() } target_os = "freebsd", target_os = "dragonfly"))] mod imp { - use core::prelude::*; + use prelude::*; - use boxed::Box; - use vec::Vec; - use string::String; use mem; + use slice; use sync::{StaticMutex, MUTEX_INIT}; @@ -98,7 +96,12 @@ mod imp { unsafe fn load_argc_and_argv(argc: int, argv: *const *const u8) -> Vec<Vec<u8>> { Vec::from_fn(argc as uint, |i| { - String::from_raw_buf(*argv.offset(i as int)).into_bytes() + let arg = *argv.offset(i as int); + let mut len = 0u; + while *arg.offset(len as int) != 0 { + len += 1u; + } + slice::from_raw_buf(&arg, len).to_vec() }) } |
