diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2016-11-28 14:22:12 -0800 |
---|---|---|
committer | Jeremy Evans <code@jeremyevans.net> | 2019-07-30 12:03:09 -0700 |
commit | d8562ab2a40658db0e6a44ce07cfbe616b9b4078 (patch) | |
tree | 30f12370c4908438981f8bab34e0bfb2944baded /io.c | |
parent | 369c36ef15c15ddc297e216522cc21599ed6a8e1 (diff) | |
download | bundler-d8562ab2a40658db0e6a44ce07cfbe616b9b4078.tar.gz |
Passing `binmode: true` to `IO.pipe` should behave like `binmode`
When passing `binmode: true` to `IO.pipe`, it should behave the same way
as calling `binmode` on each of the file handles. It should set the
file to binmode *and* set the encoding to binary on the file.
Before this commit, passing `binmode: true` to `IO.pipe` would make
`binmode?` return `true`, but the file's encoding would remain the same
as the default encoding. Passing `binmode: true` should make `binmode?`
return `true` *and* set the encoding to binary.
Diffstat (limited to 'io.c')
-rw-r--r-- | io.c | 6 |
1 files changed, 6 insertions, 0 deletions
@@ -10312,6 +10312,12 @@ rb_io_s_pipe(int argc, VALUE *argv, VALUE klass) rb_io_synchronized(fptr2); extract_binmode(opt, &fmode); + + if (fmode & FMODE_BINMODE) { + rb_io_ascii8bit_binmode(r); + rb_io_ascii8bit_binmode(w); + } + #if DEFAULT_TEXTMODE if ((fptr->mode & FMODE_TEXTMODE) && (fmode & FMODE_BINMODE)) { fptr->mode &= ~FMODE_TEXTMODE; |