diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | NEWS | 5 | ||||
-rw-r--r-- | ext/pathname/pathname.c | 44 | ||||
-rw-r--r-- | test/pathname/test_pathname.rb | 16 |
4 files changed, 71 insertions, 0 deletions
@@ -1,3 +1,9 @@ +Thu Apr 4 20:07:19 2013 Tanaka Akira <[email protected]> + + * ext/pathname/pathname.c (path_write): New method. + (path_binwrite): Ditto. + [ruby-core:49468] [Feature #7378] + Thu Apr 4 16:51:29 2013 Yuki Yugui Sonoda <[email protected]> * thread_pthread.c: Fixes wrong scopes of #if USE_SLEEPY_TIMER_THREAD @@ -41,6 +41,11 @@ with all sufficient information, see the ChangeLog file. * Net::SMTP * Added Net::SMTP#rset to implement the RSET command +* Pathname + * New methods: + * Pathname#write + * Pathname#binwrite + * Rinda::RingServer, Rinda::RingFinger * Rinda now supports multicast sockets. See Rinda::RingServer and Rinda::RingFinger for details. diff --git a/ext/pathname/pathname.c b/ext/pathname/pathname.c index fa67226e84..53f5e7cddd 100644 --- a/ext/pathname/pathname.c +++ b/ext/pathname/pathname.c @@ -346,6 +346,48 @@ path_binread(int argc, VALUE *argv, VALUE self) /* * call-seq: + * pathname.write(string, [offset] ) => fixnum + * pathname.write(string, [offset], open_args ) => fixnum + * + * Writes +contents+ to the file. + * + * See IO.write. + * + */ +static VALUE +path_write(int argc, VALUE *argv, VALUE self) +{ + VALUE args[4]; + int n; + + args[0] = get_strpath(self); + n = rb_scan_args(argc, argv, "03", &args[1], &args[2], &args[3]); + return rb_funcall2(rb_cIO, rb_intern("write"), 1+n, args); +} + +/* + * call-seq: + * pathname.binwrite(string, [offset] ) => fixnum + * pathname.binwrite(string, [offset], open_args ) => fixnum + * + * Writes +contents+ to the file, opening it in binary mode. + * + * See IO.binwrite. + * + */ +static VALUE +path_binwrite(int argc, VALUE *argv, VALUE self) +{ + VALUE args[4]; + int n; + + args[0] = get_strpath(self); + n = rb_scan_args(argc, argv, "03", &args[1], &args[2], &args[3]); + return rb_funcall2(rb_cIO, rb_intern("binwrite"), 1+n, args); +} + +/* + * call-seq: * pathname.readlines(sep=$/ [, open_args]) -> array * pathname.readlines(limit [, open_args]) -> array * pathname.readlines(sep, limit [, open_args]) -> array @@ -1334,6 +1376,8 @@ Init_pathname() rb_define_method(rb_cPathname, "read", path_read, -1); rb_define_method(rb_cPathname, "binread", path_binread, -1); rb_define_method(rb_cPathname, "readlines", path_readlines, -1); + rb_define_method(rb_cPathname, "write", path_write, -1); + rb_define_method(rb_cPathname, "binwrite", path_binwrite, -1); rb_define_method(rb_cPathname, "sysopen", path_sysopen, -1); rb_define_method(rb_cPathname, "atime", path_atime, 0); rb_define_method(rb_cPathname, "ctime", path_ctime, 0); diff --git a/test/pathname/test_pathname.rb b/test/pathname/test_pathname.rb index ccdc5bd8eb..ec9dfa1d59 100644 --- a/test/pathname/test_pathname.rb +++ b/test/pathname/test_pathname.rb @@ -716,6 +716,22 @@ class TestPathname < Test::Unit::TestCase } end + def test_write + with_tmpchdir('rubytest-pathname') {|dir| + path = Pathname("a") + path.write "abc" + assert_equal("abc", path.read) + } + end + + def test_binwrite + with_tmpchdir('rubytest-pathname') {|dir| + path = Pathname("a") + path.binwrite "abc\x80" + assert_equal("abc\x80".b, path.binread) + } + end + def test_sysopen with_tmpchdir('rubytest-pathname') {|dir| open("a", "w") {|f| f.write "abc" } |