Revert r52902,r52903,r52910,r52911,r52937,r52939

Reject IO::Console#getpass because it can't test portablly.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52945 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
naruse 2015-12-08 10:54:42 +00:00
Родитель d9c6135c5b
Коммит 958e153cdb
2 изменённых файлов: 5 добавлений и 103 удалений

Просмотреть файл

@ -73,7 +73,7 @@ getattr(int fd, conmode *t)
#define SET_LAST_ERROR (0) #define SET_LAST_ERROR (0)
#endif #endif
static ID id_getc, id_gets, id_console, id_close, id_min, id_time; static ID id_getc, id_console, id_close, id_min, id_time;
#ifndef HAVE_RB_F_SEND #ifndef HAVE_RB_F_SEND
static ID id___send__; static ID id___send__;
@ -845,78 +845,6 @@ io_getch(int argc, VALUE *argv, VALUE io)
return rb_funcall2(io, id_getc, argc, argv); return rb_funcall2(io, id_getc, argc, argv);
} }
static VALUE
puts_call(VALUE io)
{
return rb_io_write(io, rb_default_rs);
}
static VALUE
getpass_call(VALUE io)
{
return ttymode(io, rb_io_gets, set_noecho, NULL);
}
static void
prompt(int argc, VALUE *argv, VALUE io)
{
if (argc > 0 && !NIL_P(argv[0])) {
VALUE str = argv[0];
StringValueCStr(str);
rb_check_safe_obj(str);
rb_io_write(io, str);
}
}
static VALUE
str_chomp(VALUE str)
{
if (!NIL_P(str)) {
str = rb_funcallv(str, rb_intern("chomp!"), 0, 0);
}
return str;
}
/*
* call-seq:
* io.getpass(prompt=nil) -> string
*
* Reads and returns a line without echo back.
* Prints +prompt+ unless it is +nil+.
*
* You must require 'io/console' to use this method.
*/
static VALUE
console_getpass(int argc, VALUE *argv, VALUE io)
{
VALUE str, wio;
rb_check_arity(argc, 0, 1);
wio = rb_io_get_write_io(io);
if (wio == io && io == rb_stdin) wio = rb_stderr;
prompt(argc, argv, wio);
str = rb_ensure(getpass_call, io, puts_call, wio);
return str_chomp(str);
}
/*
* call-seq:
* io.getpass(prompt=nil) -> string
*
* See IO#getpass.
*/
static VALUE
io_getpass(int argc, VALUE *argv, VALUE io)
{
VALUE str;
rb_check_arity(argc, 0, 1);
prompt(argc, argv, io);
str = str_chomp(rb_funcallv(io, id_gets, 0, 0));
puts_call(io);
return str;
}
/* /*
* IO console methods * IO console methods
*/ */
@ -925,7 +853,6 @@ Init_console(void)
{ {
#undef rb_intern #undef rb_intern
id_getc = rb_intern("getc"); id_getc = rb_intern("getc");
id_gets = rb_intern("gets");
id_console = rb_intern("console"); id_console = rb_intern("console");
id_close = rb_intern("close"); id_close = rb_intern("close");
id_min = rb_intern("min"); id_min = rb_intern("min");
@ -957,11 +884,9 @@ InitVM_console(void)
rb_define_method(rb_cIO, "cursor", console_cursor_pos, 0); rb_define_method(rb_cIO, "cursor", console_cursor_pos, 0);
rb_define_method(rb_cIO, "cursor=", console_cursor_set, 1); rb_define_method(rb_cIO, "cursor=", console_cursor_set, 1);
rb_define_method(rb_cIO, "pressed?", console_key_pressed_p, 1); rb_define_method(rb_cIO, "pressed?", console_key_pressed_p, 1);
rb_define_method(rb_cIO, "getpass", console_getpass, -1);
rb_define_singleton_method(rb_cIO, "console", console_dev, -1); rb_define_singleton_method(rb_cIO, "console", console_dev, -1);
{ {
VALUE mReadable = rb_define_module_under(rb_cIO, "generic_readable"); VALUE mReadable = rb_define_module_under(rb_cIO, "generic_readable");
rb_define_method(mReadable, "getch", io_getch, -1); rb_define_method(mReadable, "getch", io_getch, -1);
rb_define_method(mReadable, "getpass", io_getpass, -1);
} }
} }

Просмотреть файл

@ -180,28 +180,6 @@ class TestIO_Console < Test::Unit::TestCase
} }
end end
def test_getpass
# run_pty("p IO.console.getpass('> ')") do |r, w|
# assert_equal("> ", r.readpartial(10))
# w.print "asdf\n"
# assert_equal("\r\n", r.gets)
# assert_equal("\"asdf\"", r.gets.chomp)
# end
helper {|m, s|
begin
th = Thread.start {
s.getpass("> ")
}
assert_equal("> ", m.readpartial(10))
m.print "asdf\n"
assert_equal("asdf", th.value)
assert_equal("\r\n", m.gets)
ensure
th.join rescue nil
end
}
end
def test_iflush def test_iflush
helper {|m, s| helper {|m, s|
m.print "a" m.print "a"
@ -292,18 +270,17 @@ class TestIO_Console < Test::Unit::TestCase
rescue RuntimeError rescue RuntimeError
skip $! skip $!
else else
result = []
n.times {result << r.gets.chomp}
Process.wait(pid)
if block_given? if block_given?
yield r, w, pid yield result
else else
result = []
n.times {result << r.gets.chomp}
Process.wait(pid)
result result
end end
ensure ensure
r.close if r r.close if r
w.close if w w.close if w
Process.wait(pid) if pid
end end
end if defined?(PTY) and defined?(IO::console) end if defined?(PTY) and defined?(IO::console)