summaryrefslogtreecommitdiff
path: root/parse.y
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-09-02 08:53:40 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-09-02 08:53:40 +0000
commit93ea04ecec7639ca8d0e58948e78461434782ecc (patch)
tree2b99bbeb2848263426213b45f1525844d86d24a1 /parse.y
parenta056098cb719312452eca309bec914406f9e5ca3 (diff)
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
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y8
1 files changed, 5 insertions, 3 deletions
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