summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-28 09:46:44 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-28 09:46:44 +0000
commit6b54d4fd0b582d6fb002f5f373b30f044de7cd53 (patch)
tree51547a4868a95c14b263c258a6abe8b2140deff5 /ext
parent793e9423cd4c4c679959b7dd011040b5aba2d169 (diff)
* ext/readline/readline.c (readline_readline): set encoding to result.
* ext/readline/readline.c (readline_s_set_input, Init_readline): save input IO to hidden instance variable. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14767 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r--ext/readline/readline.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/ext/readline/readline.c b/ext/readline/readline.c
index 169a196166..045892f457 100644
--- a/ext/readline/readline.c
+++ b/ext/readline/readline.c
@@ -29,6 +29,7 @@
#endif
static VALUE mReadline;
+static VALUE id_var_input;
#define TOLOWER(c) (isupper(c) ? tolower(c) : c)
@@ -93,8 +94,20 @@ readline_readline(int argc, VALUE *argv, VALUE self)
if (RTEST(add_hist) && buff) {
add_history(buff);
}
- if (buff)
+ if (buff) {
+ rb_io_t *ifp;
+ rb_encoding* enc;
+ VALUE input = rb_ivar_get(self, id_var_input);
+ GetOpenFile(input, ifp);
+ if (ifp->enc)
+ enc = ifp->enc;
+ else if (ifp->mode & FMODE_BINMODE)
+ enc = rb_ascii8bit_encoding();
+ else
+ enc = rb_default_external_encoding();
result = rb_tainted_str_new2(buff);
+ rb_enc_associate(result, enc);
+ }
else
result = Qnil;
if (buff) free(buff);
@@ -110,6 +123,7 @@ readline_s_set_input(VALUE self, VALUE input)
Check_Type(input, T_FILE);
GetOpenFile(input, ifp);
rl_instream = rb_io_stdio_file(ifp);
+ rb_ivar_set(self, id_var_input, input);
return input;
}
@@ -755,6 +769,9 @@ Init_readline()
rb_define_singleton_method(mReadline, "filename_quote_characters",
readline_s_get_filename_quote_characters, 0);
+ id_var_input = rb_intern("#input");
+ rb_ivar_set(mReadline, id_var_input, rb_stdin);
+
history = rb_obj_alloc(rb_cObject);
rb_extend_object(history, rb_mEnumerable);
rb_define_singleton_method(history,"to_s", hist_to_s, 0);