aboutsummaryrefslogtreecommitdiffstats
path: root/transcode.c
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-30 19:39:16 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-30 19:39:16 +0000
commitd9c5f88abc3377351d2bb8d065113dd0f1eba205 (patch)
tree835fd0251edab6c5a28adf404f77f3beaee1e916 /transcode.c
parent97a5808a148e1aca1a8b53f57290fd8ec9ec3a72 (diff)
downloadruby-d9c5f88abc3377351d2bb8d065113dd0f1eba205.tar.gz
* transcode.c (econv_putback): make max argument optional.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18967 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'transcode.c')
-rw-r--r--transcode.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/transcode.c b/transcode.c
index 6885bb5544..9c87a9fa0b 100644
--- a/transcode.c
+++ b/transcode.c
@@ -2727,12 +2727,14 @@ econv_insert_output(VALUE self, VALUE string)
}
static VALUE
-econv_putback(VALUE self, VALUE max)
+econv_putback(int argc, VALUE *argv, VALUE self)
{
rb_econv_t *ec = check_econv(self);
int n;
int putbackable;
- VALUE str;
+ VALUE str, max;
+
+ rb_scan_args(argc, argv, "01", &max);
if (NIL_P(max))
n = rb_econv_putbackable(ec);
@@ -2834,7 +2836,7 @@ Init_transcode(void)
rb_define_method(rb_cEncodingConverter, "finish", econv_finish, 0);
rb_define_method(rb_cEncodingConverter, "primitive_errinfo", econv_primitive_errinfo, 0);
rb_define_method(rb_cEncodingConverter, "insert_output", econv_insert_output, 1);
- rb_define_method(rb_cEncodingConverter, "putback", econv_putback, 1);
+ rb_define_method(rb_cEncodingConverter, "putback", econv_putback, -1);
rb_define_const(rb_cEncodingConverter, "INVALID_MASK", INT2FIX(ECONV_INVALID_MASK));
rb_define_const(rb_cEncodingConverter, "INVALID_IGNORE", INT2FIX(ECONV_INVALID_IGNORE));
rb_define_const(rb_cEncodingConverter, "INVALID_REPLACE", INT2FIX(ECONV_INVALID_REPLACE));