From 93ea04ecec7639ca8d0e58948e78461434782ecc Mon Sep 17 00:00:00 2001 From: nobu Date: Mon, 2 Sep 2013 08:53:40 +0000 Subject: parse.y: force_encoding * parse.y (str_suffix_gen): String#b creates new string object, use force_encoding instead. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42775 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- parse.y | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'parse.y') diff --git a/parse.y b/parse.y index 31ed7598e6..a167d8c087 100644 --- a/parse.y +++ b/parse.y @@ -6006,12 +6006,12 @@ parser_str_options(struct parser_params *parser) switch (c) { #if STR_OPTION_FROZEN case 'f': - options |= STR_OPTION_FROZEN; + options |= STR_OPTION_FROZEN; break; #endif #if STR_OPTION_BINARY case 'b': - options |= STR_OPTION_BINARY; + options |= STR_OPTION_BINARY; break; #endif default: @@ -8576,7 +8576,9 @@ str_suffix_gen(struct parser_params *parser, NODE *node, long opt) else { #if STR_OPTION_BINARY if (opt & STR_OPTION_BINARY) { - node = NEW_CALL(node, rb_intern("b"), 0); + VALUE ascii8bit = rb_enc_from_encoding(rb_ascii8bit_encoding()); + NODE *args = NEW_LIST(NEW_LIT(ascii8bit)); + node = NEW_CALL(node, rb_intern("force_encoding"), args); } #endif #if STR_OPTION_FROZEN -- cgit v1.2.3