[macruby-changes] [4482] MacRuby/trunk/io.c
source_changes at macosforge.org
source_changes at macosforge.org
Mon Aug 30 23:38:59 PDT 2010
Revision: 4482
http://trac.macosforge.org/projects/ruby/changeset/4482
Author: lsansonetti at apple.com
Date: 2010-08-30 23:38:59 -0700 (Mon, 30 Aug 2010)
Log Message:
-----------
bring back the cached gets optim
Modified Paths:
--------------
MacRuby/trunk/io.c
Modified: MacRuby/trunk/io.c
===================================================================
--- MacRuby/trunk/io.c 2010-08-31 06:25:25 UTC (rev 4481)
+++ MacRuby/trunk/io.c 2010-08-31 06:38:59 UTC (rev 4482)
@@ -718,8 +718,7 @@
* So <code>IO#sysread</code> doesn't work with <code>IO#eof?</code>.
*/
-static inline long rb_io_read_internal(rb_io_t *io_struct, UInt8 *buffer,
- long len);
+static long rb_io_read_internal(rb_io_t *io_struct, UInt8 *buffer, long len);
VALUE
rb_io_eof(VALUE io, SEL sel)
@@ -970,7 +969,7 @@
}
}
-static inline long
+static long
rb_io_read_internal(rb_io_t *io_struct, UInt8 *buffer, long len)
{
assert(io_struct->read_fd != -1);
@@ -1376,10 +1375,12 @@
if (range.location != kCFNotFound) {
rb_io_create_buf(io_struct);
long rest_size = r - (range.location + 1);
- CFDataAppendBytes(io_struct->buf, bytes + range.location + 1, rest_size);
+ CFDataAppendBytes(io_struct->buf, bytes + range.location + 1,
+ rest_size);
r = range.location + 1;
}
- // Resize the buffer to whatever was actually read (can be different from asked size)
+ // Resize the buffer to whatever was actually read (can be different
+ // from asked size).
rb_bstr_resize(bstr, r);
}
else {
@@ -1387,7 +1388,6 @@
const long seplen = RSTRING_LEN(sep);
assert(seplen > 0);
-#if 0 // TODO
// Pre-cache if possible.
rb_io_read_internal(io_struct, NULL, 0);
if (io_struct->buf != NULL && CFDataGetLength(io_struct->buf) > 0) {
@@ -1414,12 +1414,11 @@
if (data_read == 0) {
return Qnil;
}
- CFDataAppendBytes(data, cache, data_read);
+
+ rb_bstr_concat(bstr, cache, data_read);
rb_io_read_update(io_struct, data_read);
}
- else
-#endif
- {
+ else {
// Read from IO (slow).
long s = 512;
long data_read = 0;
@@ -1553,13 +1552,15 @@
static VALUE
rb_io_readlines(VALUE io, SEL sel, int argc, VALUE *argv)
{
- VALUE array = rb_ary_new();
- VALUE line = rb_io_gets_m(io, sel, argc, argv);
- while (!NIL_P(line)) {
- rb_ary_push(array, line);
- line = rb_io_gets_m(io, sel, argc, argv);
+ VALUE lines = rb_ary_new();
+ while (true) {
+ VALUE line = rb_io_gets_m(io, 0, argc, argv);
+ if (NIL_P(line)) {
+ break;
+ }
+ rb_ary_push(lines, line);
}
- return array;
+ return lines;
}
/*
@@ -1595,11 +1596,13 @@
{
RETURN_ENUMERATOR(io, argc, argv);
- VALUE line = rb_io_gets_m(io, sel, argc, argv);
- while (!NIL_P(line)) {
+ while (true) {
+ VALUE line = rb_io_gets_m(io, sel, argc, argv);
+ if (NIL_P(line)) {
+ break;
+ }
rb_vm_yield(1, &line);
RETURN_IF_BROKEN();
- line = rb_io_gets_m(io, sel, argc, argv);
}
return io;
}
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.macosforge.org/pipermail/macruby-changes/attachments/20100830/a07af3c7/attachment.html>
More information about the macruby-changes
mailing list