From 770f184787fa6b20899966afb393115e515dedd2 Mon Sep 17 00:00:00 2001 From: KOSAKI Motohiro Date: Sun, 26 Dec 2010 02:14:45 +0900 Subject: [PATCH] change arg check --- io.c | 25 ++++++++++++++++++++----- test/ruby/test_io.rb | 7 ++++++- 2 files changed, 26 insertions(+), 6 deletions(-) diff --git a/io.c b/io.c index 5197c7c..b2020c7 100644 --- a/io.c +++ b/io.c @@ -7387,10 +7387,10 @@ select_end(VALUE arg) } #endif -#ifdef HAVE_POSIX_FADVISE static VALUE sym_normal, sym_sequential, sym_random, sym_willneed, sym_dontneed, sym_noreuse; +#ifdef HAVE_POSIX_FADVISE struct io_advise_struct { int fd; off_t offset; @@ -7472,6 +7472,24 @@ do_io_advise(rb_io_t *fptr, VALUE advice, off_t offset, off_t len) #endif /* HAVE_POSIX_FADVISE */ +void advice_arg_check(VALUE advice) +{ + if (!SYMBOL_P(advice)) + rb_raise(rb_eTypeError, "advice must be a Symbol"); + + + if (advice != sym_normal && + advice != sym_sequential && + advice != sym_random && + advice != sym_willneed && + advice != sym_dontneed && + advice != sym_noreuse) { + /* Unsupported advise */ + rb_raise(rb_eNotImpError, "Invalid advice: :%s", + RSTRING_PTR(rb_id2str(SYM2ID(advice)))); + } +} + /* * call-seq: * ios.advise(advice, offset=0, len=0) -> nil @@ -7521,8 +7539,7 @@ rb_io_advise(int argc, VALUE *argv, VALUE io) rb_io_t *fptr; rb_scan_args(argc, argv, "12", &advice, &offset, &len); - if (!SYMBOL_P(advice)) - rb_raise(rb_eTypeError, "advice must be a Symbol"); + advice_arg_check(advice); io = GetWriteIO(io); GetOpenFile(io, fptr); @@ -10521,12 +10538,10 @@ Init_IO(void) sym_textmode = ID2SYM(rb_intern("textmode")); sym_binmode = ID2SYM(rb_intern("binmode")); sym_autoclose = ID2SYM(rb_intern("autoclose")); -#ifdef HAVE_POSIX_FADVISE sym_normal = ID2SYM(rb_intern("normal")); sym_sequential = ID2SYM(rb_intern("sequential")); sym_random = ID2SYM(rb_intern("random")); sym_willneed = ID2SYM(rb_intern("willneed")); sym_dontneed = ID2SYM(rb_intern("dontneed")); sym_noreuse = ID2SYM(rb_intern("noreuse")); -#endif } diff --git a/test/ruby/test_io.rb b/test/ruby/test_io.rb index b3d543f..6cc2897 100644 --- a/test/ruby/test_io.rb +++ b/test/ruby/test_io.rb @@ -1763,10 +1763,15 @@ End end end end + end + + def test_invalid_advise + feature4204 = '[ruby-dev:42887]' + t = make_tempfile %w{Normal rand glark will_need zzzzzzzzzzzz \u2609}.map(&:to_sym).each do |adv| [[0,0], [0, 20], [400, 2]].each do |offset, len| open(make_tempfile.path) do |t| - assert_equal(t.advise(adv, offset, len), nil) + assert_raise(NotImplementedError, feature4204) { t.advise(adv, offset, len) } end end end -- 1.7.2.3