summaryrefslogtreecommitdiff
path: root/string.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-09-21 00:43:16 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-09-21 00:43:16 +0000
commite79002a022da8387de96b393f564627eda41613f (patch)
tree169db4217607eb897418a7f3ac3797d3fccce0d3 /string.c
parent3b9c22137883b0f53bea0b4e2c139f774b20bffb (diff)
* string.c (rb_str_lines): new method to split a string into lines.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@10976 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r--string.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/string.c b/string.c
index 4b5060507d..1fd5a64b39 100644
--- a/string.c
+++ b/string.c
@@ -3532,6 +3532,42 @@ rb_str_split(VALUE str, const char *sep0)
return rb_str_split_m(1, &sep, str);
}
+
+/*
+ * call-seq:
+ * str.lines => anArray
+ *
+ * Divides <i>str</i> into lines terminated by newlines.
+ *
+ * "foo\nbar\n".lines #=> ["foo\n", "bar\n"]
+ * "foo\nb ar".lines #=> ["foo\n", "b ar"]
+ */
+
+static VALUE
+rb_str_lines(VALUE str)
+{
+ VALUE ary = rb_ary_new();
+ char *p = RSTRING_PTR(str);
+ char *pend = p + RSTRING_LEN(str);
+ char *s = p;
+ VALUE line;
+
+ while (p < pend) {
+ if (*p == '\n') {
+ p++;
+ line = rb_str_new(s, p-s);
+ rb_ary_push(ary, line);
+ s = p;
+ }
+ p++;
+ }
+ if (p == pend && s < p) {
+ line = rb_str_new(s, p-s);
+ rb_ary_push(ary, line);
+ }
+ return ary;
+}
+
/*
* call-seq:
* str.each(separator=$/) {|substr| block } => str
@@ -4796,6 +4832,7 @@ Init_String(void)
rb_define_method(rb_cString, "hex", rb_str_hex, 0);
rb_define_method(rb_cString, "oct", rb_str_oct, 0);
rb_define_method(rb_cString, "split", rb_str_split_m, -1);
+ rb_define_method(rb_cString, "lines", rb_str_lines, 0);
rb_define_method(rb_cString, "reverse", rb_str_reverse, 0);
rb_define_method(rb_cString, "reverse!", rb_str_reverse_bang, 0);
rb_define_method(rb_cString, "concat", rb_str_concat, 1);