* io.c (rb_io_s_pipe): allow specifying read-side encoding.
* io.c (io_enc_str): wrong encoding destination. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14537 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
f5512ba7a3
commit
93444eea15
@ -1,3 +1,9 @@
|
|||||||
|
Mon Dec 24 01:46:43 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
|
* io.c (rb_io_s_pipe): allow specifying read-side encoding.
|
||||||
|
|
||||||
|
* io.c (io_enc_str): wrong encoding destination.
|
||||||
|
|
||||||
Mon Dec 24 01:03:17 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Mon Dec 24 01:03:17 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* string.c (rb_str_comparable): comparison including broken
|
* string.c (rb_str_comparable): comparison including broken
|
||||||
|
53
io.c
53
io.c
@ -1304,8 +1304,8 @@ io_enc_str(VALUE str, rb_io_t *fptr)
|
|||||||
/* two encodings, so transcode from enc2 to enc */
|
/* two encodings, so transcode from enc2 to enc */
|
||||||
/* the methods in transcode.c are static, so call indirectly */
|
/* the methods in transcode.c are static, so call indirectly */
|
||||||
str = rb_funcall(str, id_encode, 2,
|
str = rb_funcall(str, id_encode, 2,
|
||||||
rb_enc_from_encoding(fptr->enc2),
|
rb_enc_from_encoding(fptr->enc),
|
||||||
rb_enc_from_encoding(fptr->enc));
|
rb_enc_from_encoding(fptr->enc2));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* just one encoding, so associate it with the string */
|
/* just one encoding, so associate it with the string */
|
||||||
@ -3109,15 +3109,14 @@ mode_enc(rb_io_t *fptr, const char *estr)
|
|||||||
rb_warn("Unsupported encoding %s ignored", p1);
|
rb_warn("Unsupported encoding %s ignored", p1);
|
||||||
}
|
}
|
||||||
|
|
||||||
p1 = strchr(estr, ':');
|
if (p0) {
|
||||||
if (p0 && p1 && p1 < p0) {
|
enc2name = ALLOCA_N(char, p0-estr+1);
|
||||||
enc2name = ALLOCA_N(char, p0-p1);
|
strncpy(enc2name, estr, p0-estr);
|
||||||
strncpy(enc2name, p1+1, p0-p1-1);
|
enc2name[p0-estr] = '\0';
|
||||||
enc2name[p0-p1-1] = '\0';
|
|
||||||
idx2=rb_enc_find_index(enc2name);
|
idx2=rb_enc_find_index(enc2name);
|
||||||
if (idx2 == idx) {
|
if (idx2 == idx) {
|
||||||
rb_warn("Ignoring internal encoding %s: it is identical to external encoding %s",
|
rb_warn("Ignoring internal encoding %s: it is identical to external encoding %s",
|
||||||
enc2name, p0+1);
|
enc2name, p1);
|
||||||
}
|
}
|
||||||
else if (idx2 >= 0) {
|
else if (idx2 >= 0) {
|
||||||
fptr->enc2 = rb_enc_from_index(idx2);
|
fptr->enc2 = rb_enc_from_index(idx2);
|
||||||
@ -4071,7 +4070,7 @@ rb_io_reopen(int argc, VALUE *argv, VALUE file)
|
|||||||
rb_io_flags_mode(flags));
|
rb_io_flags_mode(flags));
|
||||||
}
|
}
|
||||||
fptr->mode = flags;
|
fptr->mode = flags;
|
||||||
rb_io_mode_enc(fptr, StringValuePtr(nmode));
|
rb_io_mode_enc(fptr, StringValueCStr(nmode));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fptr->path) {
|
if (fptr->path) {
|
||||||
@ -5526,13 +5525,16 @@ io_new_instance(VALUE args)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* call-seq:
|
* call-seq:
|
||||||
* IO.pipe -> array
|
* IO.pipe([encoding]) -> array
|
||||||
*
|
*
|
||||||
* Creates a pair of pipe endpoints (connected to each other) and
|
* Creates a pair of pipe endpoints (connected to each other) and
|
||||||
* returns them as a two-element array of <code>IO</code> objects:
|
* returns them as a two-element array of <code>IO</code> objects:
|
||||||
* <code>[</code> <i>read_file</i>, <i>write_file</i> <code>]</code>. Not
|
* <code>[</code> <i>read_file</i>, <i>write_file</i> <code>]</code>. Not
|
||||||
* available on all platforms.
|
* available on all platforms.
|
||||||
*
|
*
|
||||||
|
* If optional argument is specified, read string from pipe is tagged
|
||||||
|
* the encoding specified.
|
||||||
|
*
|
||||||
* In the example below, the two processes close the ends of the pipe
|
* In the example below, the two processes close the ends of the pipe
|
||||||
* that they are not using. This is not just a cosmetic nicety. The
|
* that they are not using. This is not just a cosmetic nicety. The
|
||||||
* read end of a pipe will not generate an end of file condition if
|
* read end of a pipe will not generate an end of file condition if
|
||||||
@ -5561,12 +5563,16 @@ io_new_instance(VALUE args)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
rb_io_s_pipe(VALUE klass)
|
rb_io_s_pipe(int argc, VALUE *argv, VALUE klass)
|
||||||
{
|
{
|
||||||
#ifndef __human68k__
|
#ifdef __human68k__
|
||||||
|
rb_notimplement();
|
||||||
|
return Qnil; /* not reached */
|
||||||
|
#else
|
||||||
int pipes[2], state;
|
int pipes[2], state;
|
||||||
VALUE r, w, args[3];
|
VALUE r, w, args[3], estr, tmp;
|
||||||
|
|
||||||
|
rb_scan_args(argc, argv, "01", &estr);
|
||||||
if (pipe(pipes) == -1)
|
if (pipe(pipes) == -1)
|
||||||
rb_sys_fail(0);
|
rb_sys_fail(0);
|
||||||
|
|
||||||
@ -5579,6 +5585,18 @@ rb_io_s_pipe(VALUE klass)
|
|||||||
close(pipes[1]);
|
close(pipes[1]);
|
||||||
rb_jump_tag(state);
|
rb_jump_tag(state);
|
||||||
}
|
}
|
||||||
|
if (argc == 1) {
|
||||||
|
rb_io_t *fptr;
|
||||||
|
|
||||||
|
GetOpenFile(r, fptr);
|
||||||
|
tmp = rb_check_string_type(estr);
|
||||||
|
if (!NIL_P(tmp)) {
|
||||||
|
mode_enc(fptr, StringValueCStr(tmp));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
fptr->enc = rb_to_encoding(estr);
|
||||||
|
}
|
||||||
|
}
|
||||||
args[1] = INT2NUM(pipes[1]);
|
args[1] = INT2NUM(pipes[1]);
|
||||||
args[2] = INT2FIX(O_WRONLY);
|
args[2] = INT2FIX(O_WRONLY);
|
||||||
w = rb_protect(io_new_instance, (VALUE)args, &state);
|
w = rb_protect(io_new_instance, (VALUE)args, &state);
|
||||||
@ -5590,9 +5608,6 @@ rb_io_s_pipe(VALUE klass)
|
|||||||
rb_io_synchronized(RFILE(w)->fptr);
|
rb_io_synchronized(RFILE(w)->fptr);
|
||||||
|
|
||||||
return rb_assoc_new(r, w);
|
return rb_assoc_new(r, w);
|
||||||
#else
|
|
||||||
rb_notimplement();
|
|
||||||
return Qnil; /* not reached */
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5654,13 +5669,11 @@ open_key_args(int argc, VALUE *argv, struct foreach_arg *arg)
|
|||||||
}
|
}
|
||||||
v = rb_hash_aref(opt, encoding);
|
v = rb_hash_aref(opt, encoding);
|
||||||
if (!NIL_P(v)) {
|
if (!NIL_P(v)) {
|
||||||
rb_encoding *enc;
|
|
||||||
rb_io_t *fptr;
|
rb_io_t *fptr;
|
||||||
|
|
||||||
enc = rb_to_encoding(v);
|
|
||||||
arg->io = rb_io_open(RSTRING_PTR(argv[0]), "r");
|
arg->io = rb_io_open(RSTRING_PTR(argv[0]), "r");
|
||||||
GetOpenFile(arg->io, fptr);
|
GetOpenFile(arg->io, fptr);
|
||||||
fptr->enc = enc;
|
fptr->enc = rb_to_encoding(v);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6334,7 +6347,7 @@ Init_IO(void)
|
|||||||
rb_define_singleton_method(rb_cIO, "readlines", rb_io_s_readlines, -1);
|
rb_define_singleton_method(rb_cIO, "readlines", rb_io_s_readlines, -1);
|
||||||
rb_define_singleton_method(rb_cIO, "read", rb_io_s_read, -1);
|
rb_define_singleton_method(rb_cIO, "read", rb_io_s_read, -1);
|
||||||
rb_define_singleton_method(rb_cIO, "select", rb_f_select, -1);
|
rb_define_singleton_method(rb_cIO, "select", rb_f_select, -1);
|
||||||
rb_define_singleton_method(rb_cIO, "pipe", rb_io_s_pipe, 0);
|
rb_define_singleton_method(rb_cIO, "pipe", rb_io_s_pipe, -1);
|
||||||
rb_define_singleton_method(rb_cIO, "try_convert", rb_io_s_try_convert, 1);
|
rb_define_singleton_method(rb_cIO, "try_convert", rb_io_s_try_convert, 1);
|
||||||
|
|
||||||
rb_define_method(rb_cIO, "initialize", rb_io_initialize, -1);
|
rb_define_method(rb_cIO, "initialize", rb_io_initialize, -1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user