diff --git a/ChangeLog b/ChangeLog index 087bc85540..ee7b795b3d 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,8 +1,10 @@ -Thu Feb 11 14:37:39 2010 Nobuyoshi Nakada +Thu Feb 11 14:43:16 2010 Nobuyoshi Nakada * marshal.c (r_object0): read sequentially since marshal source may not be possible to rewind. [ruby-dev:40386] + * marshal.c (r_object0): replace non-1.8 escapes directly. + Thu Feb 11 09:49:31 2010 Tanaka Akira * lib/resolv.rb: fix [ruby-core:28144] reported by Hans de Graaff. diff --git a/marshal.c b/marshal.c index 395254094f..e5ede8c659 100644 --- a/marshal.c +++ b/marshal.c @@ -1501,13 +1501,23 @@ r_object0(struct load_arg *arg, int *ivp, VALUE extmod) *ivp = FALSE; } if (!has_encoding) { - VALUE pat; - VALUE dst; - static const char rsrc[] = - "(? 0; *dst++ = *src++) { + switch (*src) { + case '\\': bs++; break; + case 'g': case 'h': case 'i': case 'j': case 'k': case 'l': + case 'm': case 'o': case 'p': case 'q': case 'u': case 'y': + case 'E': case 'F': case 'H': case 'I': case 'J': case 'K': + case 'L': case 'N': case 'O': case 'P': case 'Q': case 'R': + case 'S': case 'T': case 'U': case 'V': case 'X': case 'Y': + if (bs & 1) --dst; + default: bs = 0; break; + } + } + rb_str_set_len(str, dst - ptr); } v = r_entry(rb_reg_new_str(str, options), arg); v = r_leave(v, arg);