diff options
| author | Graydon Hoare <[email protected]> | 2011-04-27 13:06:19 -0700 |
|---|---|---|
| committer | Graydon Hoare <[email protected]> | 2011-04-27 13:06:19 -0700 |
| commit | 4c7886de8008b07e892ea741be08291dae38f7bd (patch) | |
| tree | 32623b15f45c4f81d2ff167e9caddf1d5b2740cd /src/rt | |
| parent | stdlib: Real fix for _uint.parse_buf(). (diff) | |
| download | rust-4c7886de8008b07e892ea741be08291dae38f7bd.tar.xz rust-4c7886de8008b07e892ea741be08291dae38f7bd.zip | |
Fix _str.bytes to trivial version.
Diffstat (limited to 'src/rt')
| -rw-r--r-- | src/rt/rust_builtin.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/rt/rust_builtin.cpp b/src/rt/rust_builtin.cpp index 30e2eb3d..5566835d 100644 --- a/src/rt/rust_builtin.cpp +++ b/src/rt/rust_builtin.cpp @@ -219,6 +219,32 @@ str_buf(rust_task *task, rust_str *s) return (char const *)&s->data[0]; } +extern "C" CDECL rust_vec* +str_vec(rust_task *task, rust_str *s) +{ + // FIXME: this should just upref s and return it, but we + // accidentally made too much of the language and runtime know + // and care about the difference between str and vec (trailing null); + // eliminate these differences and then rewrite this back to just + // the following: + // + // if (s->ref_count != CONST_REFCOUNT) + // s->ref(); + // return s; + + rust_str *v = + vec_alloc_with_data(task, + s->fill - 1, + s->fill - 1, + 1, + (s->fill - 1) ? (void*)s->data : NULL); + if (!v) { + task->fail(2); + return NULL; + } + return v; +} + extern "C" CDECL size_t str_byte_len(rust_task *task, rust_str *s) { |