diff options
| author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-01-30 06:04:37 +0000 |
|---|---|---|
| committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-01-30 06:04:37 +0000 |
| commit | f62e0f331c72caeb48d9dedc019c2298e1c66b46 (patch) | |
| tree | f88acf89af9e862592e8abd35f798ad8378e496b /string.c | |
| parent | cda14257bb4f7150ecb0c982bd7dc419f6cd375f (diff) | |
| download | ruby-f62e0f331c72caeb48d9dedc019c2298e1c66b46.tar.gz ruby-f62e0f331c72caeb48d9dedc019c2298e1c66b46.tar.xz ruby-f62e0f331c72caeb48d9dedc019c2298e1c66b46.zip | |
* string.c (rb_str_sub_bang): calling rb_str_modify() should be just
before actually modifying the string.
fixed: [ruby-dev:30211] (originally reported by zunda)
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@11597 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
| -rw-r--r-- | string.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -1966,7 +1966,6 @@ rb_str_sub_bang(argc, argv, str) pat = get_pat(argv[0], 1); if (rb_reg_search(pat, str, 0, 0) >= 0) { - rb_str_modify(str); match = rb_backref_get(); regs = RMATCH(match)->regs; @@ -1982,6 +1981,7 @@ rb_str_sub_bang(argc, argv, str) else { repl = rb_reg_regsub(repl, str, regs); } + rb_str_modify(str); if (OBJ_TAINTED(repl)) tainted = 1; plen = END(0) - BEG(0); if (RSTRING(repl)->len > plen) { |
