aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGraydon Hoare <[email protected]>2011-04-27 13:06:19 -0700
committerGraydon Hoare <[email protected]>2011-04-27 13:06:19 -0700
commit4c7886de8008b07e892ea741be08291dae38f7bd (patch)
tree32623b15f45c4f81d2ff167e9caddf1d5b2740cd /src
parentstdlib: Real fix for _uint.parse_buf(). (diff)
downloadrust-4c7886de8008b07e892ea741be08291dae38f7bd.tar.xz
rust-4c7886de8008b07e892ea741be08291dae38f7bd.zip
Fix _str.bytes to trivial version.
Diffstat (limited to 'src')
-rw-r--r--src/lib/_str.rs6
-rw-r--r--src/rt/rust_builtin.cpp26
2 files changed, 28 insertions, 4 deletions
diff --git a/src/lib/_str.rs b/src/lib/_str.rs
index 41a86cf3..44f14fb6 100644
--- a/src/lib/_str.rs
+++ b/src/lib/_str.rs
@@ -5,6 +5,7 @@ import _vec.rustrt.vbuf;
native "rust" mod rustrt {
type sbuf;
fn str_buf(str s) -> sbuf;
+ fn str_vec(str s) -> vec[u8];
fn str_byte_len(str s) -> uint;
fn str_alloc(uint n_bytes) -> str;
fn str_from_vec(vec[mutable? u8] b) -> str;
@@ -126,10 +127,7 @@ fn buf(str s) -> sbuf {
}
fn bytes(str s) -> vec[u8] {
- fn ith(str s, uint i) -> u8 {
- ret s.(i);
- }
- ret _vec.init_fn[u8](bind ith(s, _), byte_len(s));
+ ret rustrt.str_vec(s);
}
fn from_bytes(vec[u8] v) : is_utf8(v) -> str {
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)
{