[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