summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-06-21 15:08:57 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-06-21 15:08:57 +0000
commita9730c786e52db80a19c62e30a567739bdf45c41 (patch)
tree28557f7f3b7cb8fa3d0b5116b99c5d8cfaadc9c8 /io.c
parent5f2183f6b37dd24ece0f06636fd83c894d060f84 (diff)
* io.c (rb_io_binmode_p, argf_binmode_p, Init_IO): new method
IO#binmode? and ARGF.binmode? [ruby-dev:35148] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@17507 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/io.c b/io.c
index 44c7de5aec..8bed3446fe 100644
--- a/io.c
+++ b/io.c
@@ -3167,6 +3167,20 @@ rb_io_binmode_m(VALUE io)
return io;
}
+/*
+ * call-seq:
+ * ios.binmode? => true or false
+ *
+ * Returns <code>true</code> if <em>ios</em> is binmode.
+ */
+static VALUE
+rb_io_binmode_p(VALUE io)
+{
+ rb_io_t *fptr;
+ GetOpenFile(io, fptr);
+ return fptr->mode & FMODE_BINMODE ? Qtrue : Qfalse;
+}
+
static const char*
rb_io_flags_mode(int flags)
{
@@ -7378,6 +7392,12 @@ argf_binmode_m(VALUE argf)
}
static VALUE
+argf_binmode_p(VALUE argf)
+{
+ return argf_binmode ? Qtrue : Qfalse;
+}
+
+static VALUE
argf_skip(VALUE argf)
{
if (next_p != -1) {
@@ -7703,6 +7723,7 @@ Init_IO(void)
rb_define_method(rb_cIO, "isatty", rb_io_isatty, 0);
rb_define_method(rb_cIO, "tty?", rb_io_isatty, 0);
rb_define_method(rb_cIO, "binmode", rb_io_binmode_m, 0);
+ rb_define_method(rb_cIO, "binmode?", rb_io_binmode_p, 0);
rb_define_method(rb_cIO, "sysseek", rb_io_sysseek, -1);
rb_define_method(rb_cIO, "ioctl", rb_io_ioctl, -1);
@@ -7769,6 +7790,7 @@ Init_IO(void)
rb_define_method(rb_cARGF, "eof", argf_eof, 0);
rb_define_method(rb_cARGF, "eof?", argf_eof, 0);
rb_define_method(rb_cARGF, "binmode", argf_binmode_m, 0);
+ rb_define_method(rb_cARGF, "binmode?", argf_binmode_p, 0);
rb_define_method(rb_cARGF, "filename", argf_filename, 0);
rb_define_method(rb_cARGF, "path", argf_filename, 0);