ruby-changes:57021
From: Nobuyoshi <ko1@a...>
Date: Wed, 14 Aug 2019 11:27:31 +0900 (JST)
Subject: [ruby-changes:57021] Nobuyoshi Nakada: e54d349a01 (master): [ruby/stringio] Added support for older versions
https://git.ruby-lang.org/ruby.git/commit/?id=e54d349a01 From e54d349a01043082169a88a2782e6739bdd52c4f Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada <nobu@r...> Date: Wed, 14 Aug 2019 03:02:30 +0900 Subject: [ruby/stringio] Added support for older versions https://github.com/ruby/stringio/commit/c4a13d41cd https://github.com/ruby/stringio/commit/359c9f395c diff --git a/ext/stringio/extconf.rb b/ext/stringio/extconf.rb index ad8650d..a933159 100644 --- a/ext/stringio/extconf.rb +++ b/ext/stringio/extconf.rb @@ -1,3 +1,4 @@ https://github.com/ruby/ruby/blob/trunk/ext/stringio/extconf.rb#L1 # frozen_string_literal: false require 'mkmf' +have_func("rb_io_extract_modeenc", "ruby/io.h") create_makefile('stringio') diff --git a/ext/stringio/stringio.c b/ext/stringio/stringio.c index dd5b4c8..24d5b81 100644 --- a/ext/stringio/stringio.c +++ b/ext/stringio/stringio.c @@ -26,6 +26,61 @@ https://github.com/ruby/ruby/blob/trunk/ext/stringio/stringio.c#L26 # define RB_INTEGER_TYPE_P(c) (FIXNUM_P(c) || RB_TYPE_P(c, T_BIGNUM)) #endif +#ifndef HAVE_RB_IO_EXTRACT_MODEENC +#define rb_io_extract_modeenc strio_extract_modeenc +static void +strio_extract_modeenc(VALUE *vmode_p, VALUE *vperm_p, VALUE opthash, + int *oflags_p, int *fmode_p, struct rb_io_enc_t *convconfig_p) +{ + VALUE mode = *vmode_p; + int fmode; + + convconfig_p->enc = convconfig_p->enc2 = 0; + if (NIL_P(mode)) { + fmode = FMODE_READABLE; + } + else if (FIXNUM_P(mode)) { + int flags = FIX2INT(mode); + fmode = rb_io_oflags_fmode(flags); + } + else { + const char *m = StringValueCStr(mode), *n, *e; + fmode = rb_io_modestr_fmode(m); + n = strchr(m, ':'); + if (n) { + long len; + char encname[ENCODING_MAXNAMELEN+1]; + if (fmode & FMODE_SETENC_BY_BOM) { + n = strchr(n, '|'); + } + e = strchr(++n, ':'); + len = e ? e - n : strlen(n); + if (len > 0 && len <= ENCODING_MAXNAMELEN) { + if (e) { + memcpy(encname, n, len); + encname[len] = '\0'; + n = encname; + } + convconfig_p->enc = rb_enc_find(n); + } + if (e && (len = strlen(++e)) > 0 && len <= ENCODING_MAXNAMELEN) { + convconfig_p->enc2 = rb_enc_find(e); + } + } + } + + if (!NIL_P(opthash)) { + rb_encoding *extenc = 0, *intenc = 0; + if (rb_io_extract_encoding_option(opthash, &extenc, &intenc, &fmode)) { + if (convconfig_p->enc || convconfig_p->enc2) { + rb_raise(rb_eArgError, "encoding specified twice"); + } + } + } + *fmode_p = fmode; +} +#endif + struct StringIO { VALUE string; rb_encoding *enc; -- cgit v0.10.2 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/