From e79002a022da8387de96b393f564627eda41613f Mon Sep 17 00:00:00 2001 From: matz Date: Thu, 21 Sep 2006 00:43:16 +0000 Subject: * 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 --- ChangeLog | 4 ++++ string.c | 37 +++++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+) diff --git a/ChangeLog b/ChangeLog index a60a4ef75a..6028f3e354 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Thu Sep 21 09:38:12 2006 Yukihiro Matsumoto + + * string.c (rb_str_lines): new method to split a string into lines. + Wed Sep 20 23:17:41 2006 Nobuyoshi Nakada * common.mk (pre-install-doc): create data directory before install. 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 str 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); -- cgit v1.2.3