diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-07-23 06:48:52 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-07-23 06:48:52 +0000 |
commit | 2436525ed8cd7b95a3a98173afd23804fedf6676 (patch) | |
tree | ab7964c600ee4cae321c284523a4c832d682cc61 /string.c | |
parent | cabf75ae6aaf9daa87442cce10a993cf70c3cf7f (diff) |
* string.c (rb_str_lstrip_bang): strip NUL along with white
spaces. [ruby-talk:76659]
* string.c (rb_str_rstrip_bang): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4123 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r-- | string.c | 8 |
1 files changed, 3 insertions, 5 deletions
@@ -1643,6 +1643,7 @@ str_gsub(argc, argv, str, bang) bp += len; memcpy(bp, RSTRING(val)->ptr, RSTRING(val)->len); bp += RSTRING(val)->len; + offset = END(0); if (BEG(0) == END(0)) { /* * Always consume at least one character of the input string @@ -1654,9 +1655,6 @@ str_gsub(argc, argv, str, bang) bp += len; offset = END(0) + len; } - else { - offset = END(0); - } cp = RSTRING(str)->ptr + offset; if (offset > RSTRING(str)->len) break; beg = rb_reg_search(pat, str, offset, 0); @@ -2924,7 +2922,7 @@ rb_str_lstrip_bang(str) if (!s || RSTRING(str)->len == 0) return Qnil; e = t = s + RSTRING(str)->len; /* remove spaces at head */ - while (s < t && ISSPACE(*s)) s++; + while (s < t && (ISSPACE(*s) || !*s)) s++; RSTRING(str)->len = t-s; if (s > RSTRING(str)->ptr) { @@ -2956,7 +2954,7 @@ rb_str_rstrip_bang(str) e = t = s + RSTRING(str)->len; /* remove trailing spaces */ - while (s < t && ISSPACE(*(t-1))) t--; + while (s < t && (ISSPACE(*(t-1)) || !*(t-1))) t--; RSTRING(str)->len = t-s; if (t < e) { |